Index: compiler-rt/trunk/lib/esan/CMakeLists.txt =================================================================== --- compiler-rt/trunk/lib/esan/CMakeLists.txt +++ compiler-rt/trunk/lib/esan/CMakeLists.txt @@ -12,6 +12,7 @@ esan_flags.cpp esan_interface.cpp esan_interceptors.cpp + cache_frag.cpp working_set.cpp) foreach (arch ${ESAN_SUPPORTED_ARCH}) Index: compiler-rt/trunk/lib/esan/cache_frag.h =================================================================== --- compiler-rt/trunk/lib/esan/cache_frag.h +++ compiler-rt/trunk/lib/esan/cache_frag.h @@ -0,0 +1,28 @@ +//===-- cache_frag.h --------------------------------------------*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file is a part of EfficiencySanitizer, a family of performance tuners. +// +// Header for cache-fragmentation-specific code. +//===----------------------------------------------------------------------===// + +#ifndef CACHE_FRAG_H +#define CACHE_FRAG_H + +namespace __esan { + +void processCacheFragCompilationUnitInit(void *Ptr); +void processCacheFragCompilationUnitExit(void *Ptr); + +void initializeCacheFrag(); +int finalizeCacheFrag(); + +} // namespace __esan + +#endif // CACHE_FRAG_H Index: compiler-rt/trunk/lib/esan/cache_frag.cpp =================================================================== --- compiler-rt/trunk/lib/esan/cache_frag.cpp +++ compiler-rt/trunk/lib/esan/cache_frag.cpp @@ -0,0 +1,40 @@ +//===-- cache_frag.cpp ----------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file is a part of EfficiencySanitizer, a family of performance tuners. +// +// This file contains cache fragmentation-specific code. +//===----------------------------------------------------------------------===// + +#include "esan.h" + +namespace __esan { + +//===-- Init/exit functions -----------------------------------------------===// + +void processCacheFragCompilationUnitInit(void *Ptr) { + VPrintf(2, "in esan::%s\n", __FUNCTION__); +} + +void processCacheFragCompilationUnitExit(void *Ptr) { + VPrintf(2, "in esan::%s\n", __FUNCTION__); +} + +void initializeCacheFrag() { + VPrintf(2, "in esan::%s\n", __FUNCTION__); +} + +int finalizeCacheFrag() { + VPrintf(2, "in esan::%s\n", __FUNCTION__); + // FIXME: add the cache fragmentation final report. + Report("%s is not finished: nothing yet to report\n", SanitizerToolName); + return 0; +} + +} // namespace __esan Index: compiler-rt/trunk/lib/esan/esan.cpp =================================================================== --- compiler-rt/trunk/lib/esan/esan.cpp +++ compiler-rt/trunk/lib/esan/esan.cpp @@ -16,6 +16,7 @@ #include "esan_flags.h" #include "esan_interface_internal.h" #include "esan_shadow.h" +#include "cache_frag.h" #include "sanitizer_common/sanitizer_common.h" #include "sanitizer_common/sanitizer_flag_parser.h" #include "sanitizer_common/sanitizer_flags.h" @@ -175,7 +176,7 @@ initializeInterceptors(); if (WhichTool == ESAN_CacheFrag) { - // FIXME: add runtime code for this tool + initializeCacheFrag(); } else if (WhichTool == ESAN_WorkingSet) { initializeWorkingSet(); } @@ -186,10 +187,7 @@ int finalizeLibrary() { VPrintf(1, "in esan::%s\n", __FUNCTION__); if (WhichTool == ESAN_CacheFrag) { - // FIXME NYI: we need to add sampling + callstack gathering and have a - // strategy for how to generate a final report. - // We'll move this to cache_frag.cpp once we have something. - Report("%s is not finished: nothing yet to report\n", SanitizerToolName); + return finalizeCacheFrag(); } else if (WhichTool == ESAN_WorkingSet) { return finalizeWorkingSet(); } @@ -198,12 +196,18 @@ void processCompilationUnitInit(void *Ptr) { VPrintf(2, "in esan::%s\n", __FUNCTION__); + if (WhichTool == ESAN_CacheFrag) { + processCacheFragCompilationUnitInit(Ptr); + } } // This is called when the containing module is unloaded. // For the main executable module, this is called after finalizeLibrary. void processCompilationUnitExit(void *Ptr) { VPrintf(2, "in esan::%s\n", __FUNCTION__); + if (WhichTool == ESAN_CacheFrag) { + processCacheFragCompilationUnitExit(Ptr); + } } } // namespace __esan Index: compiler-rt/trunk/test/esan/TestCases/struct-simple.cpp =================================================================== --- compiler-rt/trunk/test/esan/TestCases/struct-simple.cpp +++ compiler-rt/trunk/test/esan/TestCases/struct-simple.cpp @@ -26,13 +26,19 @@ #ifdef MAIN int main(int argc, char **argv) { // CHECK: in esan::initializeLibrary - // CHECK: in esan::processCompilationUnitInit - // CHECK: in esan::processCompilationUnitInit + // CHECK: in esan::initializeCacheFrag + // CHECK-NEXT: in esan::processCompilationUnitInit + // CHECK-NEXT: in esan::processCacheFragCompilationUnitInit + // CHECK-NEXT: in esan::processCompilationUnitInit + // CHECK-NEXT: in esan::processCacheFragCompilationUnitInit part(); return 0; - // CHECK-NEXT: in esan::finalizeLibrary + // CHECK: in esan::finalizeLibrary + // CHECK-NEXT: in esan::finalizeCacheFrag // CHECK-NEXT: {{.*}}EfficiencySanitizer is not finished: nothing yet to report - // CHECK: in esan::processCompilationUnitExit - // CHECK: in esan::processCompilationUnitExit + // CHECK-NEXT: in esan::processCompilationUnitExit + // CHECK-NEXT: in esan::processCacheFragCompilationUnitExit + // CHECK-NEXT: in esan::processCompilationUnitExit + // CHECK-NEXT: in esan::processCacheFragCompilationUnitExit } #endif // MAIN