
* linux kernel (x509_cert) and process fuzzing example * rework filters * update to latest qemu * working for process and kernel fuzzing * new i2s mutator for binary only fuzzers * refactoring modules with new filtering interface * add state as parameter of harness * hide unused global in usermode * Script for stub bindings generation * do not try to check whether it is worth generating the bindings, always generate when the env variable is on. * add taplo to fmt_all.sh * Moved fuzzers (again) in a target-centric way. * fix rust 2024 warnings. * new libafl_qemu harness structure. * rename qemu_systemmode into qemu_baremetal * fix qemu baremetal makefile * fix formatter --------- Co-authored-by: Toka <tokazerkje@outlook.com>
32 lines
658 B
C
32 lines
658 B
C
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <stdint.h>
|
|
#include <stdarg.h>
|
|
#include <stdlib.h>
|
|
#include <stdint.h>
|
|
#include <unistd.h>
|
|
|
|
int LLVMFuzzerTestOneInput(const uint8_t *buf, size_t i) {
|
|
if (i < 15) return -1;
|
|
if (buf[0] != 'A') return 0;
|
|
int *icmp = (int *)(buf + 1);
|
|
if (*icmp != 0x69694141) return 0;
|
|
if (memcmp(buf + 5, "1234EF", 6) == 0) abort();
|
|
return 0;
|
|
}
|
|
|
|
#ifdef __AFL_COMPILER
|
|
int main(int argc, char *argv[]) {
|
|
unsigned char buf[1024];
|
|
ssize_t i;
|
|
while (__AFL_LOOP(1000)) {
|
|
i = read(0, (char *)buf, sizeof(buf) - 1);
|
|
if (i > 0) buf[i] = 0;
|
|
LLVMFuzzerTestOneInput(buf, i);
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
#endif
|