Fuzzing targets that allocate/deallocate a lot of memory tend to consume
a lot of RSS when ASan quarantine is enabled. Purging quarantine between
iterations and returning memory to OS keeps RSS down and should not
reduce the quarantine effectiveness provided the fuzz target does not
preserve state between iterations (in this case this feature can be turned off).
Based on D39153.
for could you put following together?
e.g.
void Fuzzer::PurgeAllocator() { if (some condition) return; if (some condition) return; if (some condition) return; if (some condition) return; EF->__sanitizer_purge_allocator(); LastAllocatorPurgeAttemptTime = system_clock::now(); } or void Fuzzer::PurgeAllocator() { if (some condition || some condition || some condition || some condition) { return; } EF->__sanitizer_purge_allocator(); LastAllocatorPurgeAttemptTime = system_clock::now(); }