From 8da773bf74f29c10f81b382f39a06f2486e4216c Mon Sep 17 00:00:00 2001 From: Xinliang David Li Date: Tue, 17 May 2016 20:19:03 +0000 Subject: Simple refactoring /NFC llvm-svn: 269829 --- .../Transforms/Instrumentation/InstrProfiling.cpp | 23 ++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) (limited to 'llvm/lib/Transforms/Instrumentation/InstrProfiling.cpp') diff --git a/llvm/lib/Transforms/Instrumentation/InstrProfiling.cpp b/llvm/lib/Transforms/Instrumentation/InstrProfiling.cpp index 930001f..60f77d47 100644 --- a/llvm/lib/Transforms/Instrumentation/InstrProfiling.cpp +++ b/llvm/lib/Transforms/Instrumentation/InstrProfiling.cpp @@ -367,6 +367,20 @@ InstrProfiling::getOrCreateRegionCounters(InstrProfIncrementInst *Inc) { return CounterPtr; } +static bool needsRuntimeRegistrationOfSectionRange(const Module &M) { + // Don't do this for Darwin. compiler-rt uses linker magic. + if (Triple(M.getTargetTriple()).isOSDarwin()) + return false; + + // Use linker script magic to get data/cnts/name start/end. + if (Triple(M.getTargetTriple()).isOSLinux() || + Triple(M.getTargetTriple()).isOSFreeBSD() || + Triple(M.getTargetTriple()).isPS4CPU()) + return false; + + return true; +} + void InstrProfiling::emitNameData() { std::string UncompressedData; @@ -391,14 +405,7 @@ void InstrProfiling::emitNameData() { } void InstrProfiling::emitRegistration() { - // Don't do this for Darwin. compiler-rt uses linker magic. - if (Triple(M->getTargetTriple()).isOSDarwin()) - return; - - // Use linker script magic to get data/cnts/name start/end. - if (Triple(M->getTargetTriple()).isOSLinux() || - Triple(M->getTargetTriple()).isOSFreeBSD() || - Triple(M->getTargetTriple()).isPS4CPU()) + if (!needsRuntimeRegistrationOfSectionRange(*M)) return; // Construct the function. -- cgit v1.1