Optimize fuzzer

This commit is contained in:
cpq 2022-09-25 11:58:28 +01:00
parent 6a500b8d40
commit 41960b4212

View File

@ -71,10 +71,11 @@ int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
struct eth *eth = (struct eth *) pkt; struct eth *eth = (struct eth *) pkt;
memcpy(pkt, data, size); memcpy(pkt, data, size);
if (size > sizeof(*eth)) { if (size > sizeof(*eth)) {
static uint8_t i; static size_t i;
uint16_t types[] = {0x800, 0x800, 0x806, 0x86dd}; uint16_t eth_types[] = {0x800, 0x800, 0x806, 0x86dd};
memcpy(eth->dst, ifp->mac, 6); // Set valid destination MAC memcpy(eth->dst, ifp->mac, 6); // Set valid destination MAC
eth->type = mg_htons(types[i++ & 3]); eth->type = mg_htons(eth_types[i++]);
if (i >= sizeof(eth_types) / sizeof(eth_types[0])) i = 0;
} }
mip_rx(ifp, (void *) pkt, size); mip_rx(ifp, (void *) pkt, size);