mirror of
				https://github.com/yuzu-emu/unicorn.git
				synced 2025-10-25 03:57:36 +00:00 
			
		
		
		
	* 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
		
			
				
	
	
		
			50 lines
		
	
	
		
			930 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			50 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;
 | |
| }
 | |
| 
 |