mirror of
https://github.com/yuzu-emu/unicorn
synced 2024-11-24 16:58:28 +00:00
86be817717
* Integration with oss-fuzz * Use CFLAGS even for linking as for fuzzing with asan * Do not abort on uc_emu_start error * Redirect fuzz output somewhere else than stdout * Use uc_open for every fuzz instance * Avoids timeouts from infinite loops Limiting the number of instructions * Moving fuzz to tests directory
49 lines
930 B
C
49 lines
930 B
C
#include <stdint.h>
|
|
#include <stdlib.h>
|
|
#include <stdio.h>
|
|
|
|
int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size);
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
FILE * fp;
|
|
uint8_t *Data;
|
|
size_t Size;
|
|
|
|
if (argc != 2) {
|
|
return 1;
|
|
}
|
|
//opens the file, get its size, and reads it into a buffer
|
|
fp = fopen(argv[1], "rb");
|
|
if (fp == NULL) {
|
|
return 2;
|
|
}
|
|
if (fseek(fp, 0L, SEEK_END) != 0) {
|
|
fclose(fp);
|
|
return 2;
|
|
}
|
|
Size = ftell(fp);
|
|
if (Size == (size_t) -1) {
|
|
fclose(fp);
|
|
return 2;
|
|
}
|
|
if (fseek(fp, 0L, SEEK_SET) != 0) {
|
|
fclose(fp);
|
|
return 2;
|
|
}
|
|
Data = malloc(Size);
|
|
if (Data == NULL) {
|
|
fclose(fp);
|
|
return 2;
|
|
}
|
|
if (fread(Data, Size, 1, fp) != 1) {
|
|
fclose(fp);
|
|
return 2;
|
|
}
|
|
|
|
//lauch fuzzer
|
|
LLVMFuzzerTestOneInput(Data, Size);
|
|
fclose(fp);
|
|
return 0;
|
|
}
|
|
|