Fuzzing: Configure flags to allow greater coverage

pull/2743/merge
Roger A. Light 3 years ago
parent 6f574f80ea
commit 94fbaa4fa1

@ -33,27 +33,40 @@ extern "C" {
} }
#endif #endif
#define kMinInputLength 1 #define kMinInputLength 3
#define kMaxInputLength 268435455U #define kMaxInputLength 268435455U
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
{ {
struct mosquitto *context = NULL; struct mosquitto *context = NULL;
uint8_t *data_heap; uint8_t *data_heap;
struct mosquitto__listener listener;
struct mosquitto__bridge bridge;
//if(size < kMinInputLength || size > kMaxInputLength){ if(size < kMinInputLength || size > kMaxInputLength){
//return 0; return 0;
//} }
db.config = (struct mosquitto__config *)calloc(1, sizeof(struct mosquitto__config)); db.config = (struct mosquitto__config *)calloc(1, sizeof(struct mosquitto__config));
log__init(db.config); log__init(db.config);
memset(&listener, 0, sizeof(listener));
memset(&bridge, 0, sizeof(bridge));
context = context__init();
if(!context) return 1;
context->listener = &listener;
context->bridge = &bridge;
context->state = (enum mosquitto_client_state )data[0];
context->protocol = (enum mosquitto__protocol )data[1];
size -= 2;
data_heap = (uint8_t *)malloc(size); data_heap = (uint8_t *)malloc(size);
memcpy(data_heap, data, size); if(!data_heap) return 1;
memcpy(data_heap, data, size);
context = context__init();
context->state = mosq_cs_active;
context->in_packet.command = data_heap[0]; context->in_packet.command = data_heap[0];
context->in_packet.payload = (uint8_t *)data_heap; context->in_packet.payload = (uint8_t *)data_heap;
context->in_packet.packet_length = size; context->in_packet.packet_length = size;
@ -62,6 +75,7 @@ extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
handle__packet(context); handle__packet(context);
context->bridge = NULL;
context__cleanup(context, true); context__cleanup(context, true);
free(db.config); free(db.config);

Loading…
Cancel
Save