/src/keystone/suite/fuzz/fuzz_asm_mips64be.c
| Line | Count | Source (jump to first uncovered line) | 
| 1 |  | #include <keystone/keystone.h> | 
| 2 |  |  | 
| 3 |  | #include <string.h> | 
| 4 |  |  | 
| 5 |  | FILE * outfile = NULL; | 
| 6 |  |  | 
| 7 |  |  | 
| 8 | 111k | int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) { | 
| 9 | 111k |     ks_engine *ks; | 
| 10 | 111k |     ks_err err; | 
| 11 | 111k |     size_t count; | 
| 12 | 111k |     unsigned char *encode = NULL; | 
| 13 | 111k |     size_t size; | 
| 14 | 111k |     char * assembler; | 
| 15 |  |  | 
| 16 | 111k |     if (outfile == NULL) { | 
| 17 |  |         // we compute the output | 
| 18 | 26 |         outfile = fopen("/dev/null", "w"); | 
| 19 | 26 |         if (outfile == NULL) { | 
| 20 | 0 |             printf("failed opening /dev/null\n"); | 
| 21 | 0 |             abort(); | 
| 22 | 0 |         } | 
| 23 | 26 |     } | 
| 24 |  |  | 
| 25 | 111k |     if (Size < 1) { | 
| 26 | 0 |         return 0; | 
| 27 | 0 |     } | 
| 28 |  |  | 
| 29 | 111k |     err = ks_open(KS_ARCH_MIPS, KS_MODE_MIPS64+KS_MODE_BIG_ENDIAN, &ks); | 
| 30 | 111k |     if (err != KS_ERR_OK) { | 
| 31 | 0 |         printf("ERROR: failed on ks_open(), quit error = %u\n", err); | 
| 32 | 0 |         abort(); | 
| 33 | 0 |     } | 
| 34 |  |  | 
| 35 | 111k |     ks_option(ks, KS_OPT_SYNTAX, Data[Size-1]); | 
| 36 |  |  | 
| 37 | 111k |     assembler = malloc(Size); | 
| 38 | 111k |     memcpy(assembler, Data, Size-1); | 
| 39 |  |     //null terminate string | 
| 40 | 111k |     assembler[Size-1] = 0; | 
| 41 |  |  | 
| 42 | 111k |     if (ks_asm(ks, assembler, 0, &encode, &size, &count) != KS_ERR_OK) { | 
| 43 | 68.4k |         fprintf(outfile, "ERROR: ks_asm() failed & count = %lu, error = %u\n", | 
| 44 | 68.4k |                 count, ks_errno(ks)); | 
| 45 | 68.4k |     } else { | 
| 46 | 42.8k |         size_t i; | 
| 47 |  |  | 
| 48 | 42.8k |         fprintf(outfile, "%s = ", assembler); | 
| 49 | 1.78G |         for (i = 0; i < size; i++) { | 
| 50 | 1.78G |             fprintf(outfile, "%02x ", encode[i]); | 
| 51 | 1.78G |         } | 
| 52 | 42.8k |         fprintf(outfile, "\n"); | 
| 53 | 42.8k |         fprintf(outfile, "Compiled: %lu bytes, statements: %lu\n", size, count); | 
| 54 | 42.8k |     } | 
| 55 |  |  | 
| 56 | 111k |     free(assembler); | 
| 57 |  |     // NOTE: free encode after usage to avoid leaking memory | 
| 58 | 111k |     if (encode != NULL) { | 
| 59 | 42.8k |         ks_free(encode); | 
| 60 | 42.8k |     } | 
| 61 |  |  | 
| 62 |  |     // close Keystone instance when done | 
| 63 | 111k |     ks_close(ks); | 
| 64 |  |  | 
| 65 | 111k |     return 0; | 
| 66 | 111k | } |