mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-26 04:32:44 +01:00
Libfuzzer: do not pass null into user function
Differential Revision: http://reviews.llvm.org/D15098 llvm-svn: 254558
This commit is contained in:
parent
2dbef3216c
commit
2444b7e49b
@ -238,7 +238,11 @@ void Fuzzer::RunOneAndUpdateCorpus(Unit &U) {
|
||||
}
|
||||
|
||||
void Fuzzer::ExecuteCallback(const Unit &U) {
|
||||
int Res = USF.TargetFunction(U.data(), U.size());
|
||||
const uint8_t *Data = U.data();
|
||||
uint8_t EmptyData;
|
||||
if (!Data)
|
||||
Data = &EmptyData;
|
||||
int Res = USF.TargetFunction(Data, U.size());
|
||||
(void)Res;
|
||||
assert(Res == 0);
|
||||
}
|
||||
|
@ -1,4 +1,5 @@
|
||||
// Simple test for a fuzzer. The fuzzer must find the string "Hi!".
|
||||
#include <assert.h>
|
||||
#include <cstdint>
|
||||
#include <cstdlib>
|
||||
#include <cstddef>
|
||||
@ -7,6 +8,7 @@
|
||||
static volatile int Sink;
|
||||
|
||||
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
|
||||
assert(Data);
|
||||
if (Size > 0 && Data[0] == 'H') {
|
||||
Sink = 1;
|
||||
if (Size > 1 && Data[1] == 'i') {
|
||||
|
Loading…
Reference in New Issue
Block a user