forked from OSchip/llvm-project
[libFuzzer] properly reset the guards when reseting the coverage. Also try to fix check-fuzzer on the bot
llvm-svn: 281814
This commit is contained in:
parent
a53d49e1b5
commit
bc3789a919
|
@ -380,6 +380,7 @@ class TracePC {
|
|||
NumNewPCs = 0;
|
||||
CounterMap.Reset();
|
||||
TotalCoverageMap.Reset();
|
||||
ResetGuards();
|
||||
}
|
||||
|
||||
void PrintModuleInfo();
|
||||
|
@ -394,6 +395,8 @@ private:
|
|||
size_t NumNewPCs = 0;
|
||||
void AddNewPC(uintptr_t PC) { NewPCs[(NumNewPCs++) % kMaxNewPCs] = PC; }
|
||||
|
||||
void ResetGuards();
|
||||
|
||||
struct Module {
|
||||
uint64_t *Start, *Stop;
|
||||
};
|
||||
|
|
|
@ -34,6 +34,8 @@ void TracePC::HandleTrace(uint64_t *Guard, uintptr_t PC) {
|
|||
}
|
||||
if (Counter < 255)
|
||||
Value++;
|
||||
else
|
||||
Value |= kBit63;
|
||||
} else {
|
||||
Value |= kBit63;
|
||||
TotalCoverage++;
|
||||
|
@ -60,6 +62,12 @@ void TracePC::PrintModuleInfo() {
|
|||
Printf("\n");
|
||||
}
|
||||
|
||||
void TracePC::ResetGuards() {
|
||||
for (size_t M = 0; M < NumModules; M++)
|
||||
for (uint64_t *X = Modules[M].Start; X < Modules[M].Stop; X++)
|
||||
*X = (*X >> 32) << 32;
|
||||
}
|
||||
|
||||
void TracePC::FinalizeTrace() {
|
||||
if (UseCounters && TotalCoverage) {
|
||||
for (size_t M = 0; M < NumModules; M++) {
|
||||
|
|
|
@ -36,4 +36,4 @@ set_target_properties(LLVMFuzzer-DSO1 PROPERTIES LIBRARY_OUTPUT_DIRECTORY
|
|||
set_target_properties(LLVMFuzzer-DSO2 PROPERTIES LIBRARY_OUTPUT_DIRECTORY
|
||||
"${CMAKE_BINARY_DIR}/lib/Fuzzer/lib")
|
||||
|
||||
set(TestBinaries ${TestBinaries} LLVMFuzzer-DSOTest)
|
||||
set(TestBinaries ${TestBinaries} LLVMFuzzer-DSOTest PARENT_SCOPE)
|
||||
|
|
Loading…
Reference in New Issue