Coverage Report

Created: 2025-10-14 06:42

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/capstonev5/suite/fuzz/fuzz_disasm.c
Line
Count
Source
1
// the following must precede stdio (woo, thanks msft)
2
#if defined(_MSC_VER) && _MSC_VER < 1900
3
#define _CRT_SECURE_NO_WARNINGS
4
#endif
5
6
#include <stdio.h>
7
#include <stdlib.h>
8
#include <inttypes.h>
9
10
#include <capstone/capstone.h>
11
12
#include "platform.h"
13
14
int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size);
15
16
17
static FILE *outfile = NULL;
18
19
58.2k
int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
20
58.2k
    csh handle;
21
58.2k
    cs_insn *all_insn;
22
58.2k
    cs_detail *detail;
23
58.2k
    cs_err err;
24
58.2k
    unsigned int i;
25
26
58.2k
    if (Size < 1) {
27
        // 1 byte for arch choice
28
0
        return 0;
29
58.2k
    } else if (Size > 0x1000) {
30
        //limit input to 4kb
31
0
        Size = 0x1000;
32
0
    }
33
34
58.2k
    if (outfile == NULL) {
35
        // we compute the output
36
1
        outfile = fopen("/dev/null", "w");
37
1
        if (outfile == NULL) {
38
0
            return 0;
39
0
        }
40
1
    }
41
42
58.2k
    i = get_platform_entry((uint8_t)Data[0]);
43
44
58.2k
    err = cs_open(platforms[i].arch, platforms[i].mode, &handle);
45
58.2k
    if (err) {
46
2
        return 0;
47
2
    }
48
49
58.2k
    cs_option(handle, CS_OPT_DETAIL, CS_OPT_ON);
50
58.2k
    if (Data[0]&0x80) {
51
        //hack
52
16.8k
        cs_option(handle, CS_OPT_SYNTAX, CS_OPT_SYNTAX_ATT);
53
16.8k
    }
54
55
58.2k
    uint64_t address = 0x1000;
56
58.2k
    size_t count = cs_disasm(handle, Data+1, Size-1, address, 0, &all_insn);
57
58
58.2k
    if (count) {
59
56.9k
        size_t j;
60
56.9k
        unsigned int n;
61
62
3.13M
        for (j = 0; j < count; j++) {
63
3.08M
            cs_insn *i = &(all_insn[j]);
64
3.08M
            fprintf(outfile, "0x%"PRIx64":\t%s\t\t%s // insn-ID: %u, insn-mnem: %s\n",
65
3.08M
                   i->address, i->mnemonic, i->op_str,
66
3.08M
                   i->id, cs_insn_name(handle, i->id));
67
68
3.08M
            detail = i->detail;
69
70
3.08M
            if (detail->regs_read_count > 0) {
71
635k
                fprintf(outfile, "\tImplicit registers read: ");
72
1.64M
                for (n = 0; n < detail->regs_read_count; n++) {
73
1.00M
                    fprintf(outfile, "%s ", cs_reg_name(handle, detail->regs_read[n]));
74
1.00M
                }
75
635k
            }
76
77
3.08M
            if (detail->regs_write_count > 0) {
78
1.01M
                fprintf(outfile, "\tImplicit registers modified: ");
79
2.27M
                for (n = 0; n < detail->regs_write_count; n++) {
80
1.25M
                    fprintf(outfile, "%s ", cs_reg_name(handle, detail->regs_write[n]));
81
1.25M
                }
82
1.01M
            }
83
84
3.08M
            if (detail->groups_count > 0) {
85
1.60M
                fprintf(outfile, "\tThis instruction belongs to groups: ");
86
4.09M
                for (n = 0; n < detail->groups_count; n++) {
87
2.49M
                    fprintf(outfile, "%s ", cs_group_name(handle, detail->groups[n]));
88
2.49M
                }
89
1.60M
            }
90
3.08M
        }
91
92
56.9k
        fprintf(outfile, "0x%"PRIx64":\n", all_insn[j-1].address + all_insn[j-1].size);
93
56.9k
        cs_free(all_insn, count);
94
56.9k
    }
95
96
58.2k
    cs_close(&handle);
97
98
58.2k
    return 0;
99
58.2k
}