diff --git a/llvm/include/llvm/IR/PassManager.h b/llvm/include/llvm/IR/PassManager.h --- a/llvm/include/llvm/IR/PassManager.h +++ b/llvm/include/llvm/IR/PassManager.h @@ -514,11 +514,7 @@ if (!PI.runBeforePass(*Pass, IR)) continue; - PreservedAnalyses PassPA; - { - TimeTraceScope TimeScope(Pass->name(), IR.getName()); - PassPA = Pass->run(IR, AM, ExtraArgs...); - } + PreservedAnalyses PassPA = Pass->run(IR, AM, ExtraArgs...); // Call onto PassInstrumentation's AfterPass callbacks immediately after // running the pass. diff --git a/llvm/include/llvm/Passes/StandardInstrumentations.h b/llvm/include/llvm/Passes/StandardInstrumentations.h --- a/llvm/include/llvm/Passes/StandardInstrumentations.h +++ b/llvm/include/llvm/Passes/StandardInstrumentations.h @@ -23,6 +23,7 @@ #include "llvm/IR/PassTimingInfo.h" #include "llvm/IR/ValueHandle.h" #include "llvm/Support/CommandLine.h" +#include "llvm/Support/TimeProfiler.h" #include "llvm/Transforms/IPO/SampleProfileProbe.h" #include @@ -405,6 +406,26 @@ void registerCallbacks(PassInstrumentationCallbacks &PIC); }; +// This class implements --time-trace functionality for new pass manager. +// It provides the pass-instrumentation callbacks that measure the pass +// execution time. They collect time tracing info by TimeProfiler. +class TimeProfilingPassesHandler { + +public: + TimeProfilingPassesHandler(); + // We intend this to be unique per-compilation, thus no copies. + TimeProfilingPassesHandler(const TimeProfilingPassesHandler &) = delete; + void operator=(const TimeProfilingPassesHandler &) = delete; + + void registerCallbacks(PassInstrumentationCallbacks &PIC); + +private: + PassInstrumentationCallbacks *PIC; + // Implementation of pass instrumentation callbacks. + void runBeforePass(StringRef PassID, Any IR); + void runAfterPass(); +}; + // Class that holds transitions between basic blocks. The transitions // are contained in a map of values to names of basic blocks. class DCData { @@ -505,6 +526,7 @@ PrintIRInstrumentation PrintIR; PrintPassInstrumentation PrintPass; TimePassesHandler TimePasses; + TimeProfilingPassesHandler TimeProfilingPasses; OptNoneInstrumentation OptNone; OptBisectInstrumentation OptBisect; PreservedCFGCheckerInstrumentation PreservedCFGChecker; diff --git a/llvm/include/llvm/Transforms/Scalar/LoopPassManager.h b/llvm/include/llvm/Transforms/Scalar/LoopPassManager.h --- a/llvm/include/llvm/Transforms/Scalar/LoopPassManager.h +++ b/llvm/include/llvm/Transforms/Scalar/LoopPassManager.h @@ -392,11 +392,7 @@ if (!PI.runBeforePass(*Pass, L)) return None; - PreservedAnalyses PA; - { - TimeTraceScope TimeScope(Pass->name(), IR.getName()); - PA = Pass->run(IR, AM, AR, U); - } + PreservedAnalyses PA = Pass->run(IR, AM, AR, U); // do not pass deleted Loop into the instrumentation if (U.skipCurrentLoop()) diff --git a/llvm/lib/Analysis/CGSCCPassManager.cpp b/llvm/lib/Analysis/CGSCCPassManager.cpp --- a/llvm/lib/Analysis/CGSCCPassManager.cpp +++ b/llvm/lib/Analysis/CGSCCPassManager.cpp @@ -84,11 +84,7 @@ if (!PI.runBeforePass(*Pass, *C)) continue; - PreservedAnalyses PassPA; - { - TimeTraceScope TimeScope(Pass->name()); - PassPA = Pass->run(*C, AM, G, UR); - } + PreservedAnalyses PassPA = Pass->run(*C, AM, G, UR); if (UR.InvalidatedSCCs.count(C)) PI.runAfterPassInvalidated(*Pass, PassPA); @@ -277,11 +273,7 @@ if (!PI.runBeforePass(*Pass, *C)) continue; - PreservedAnalyses PassPA; - { - TimeTraceScope TimeScope(Pass->name()); - PassPA = Pass->run(*C, CGAM, CG, UR); - } + PreservedAnalyses PassPA = Pass->run(*C, CGAM, CG, UR); if (UR.InvalidatedSCCs.count(C)) PI.runAfterPassInvalidated(*Pass, PassPA); @@ -548,12 +540,7 @@ if (!PI.runBeforePass(*Pass, F)) continue; - PreservedAnalyses PassPA; - { - TimeTraceScope TimeScope(Pass->name()); - PassPA = Pass->run(F, FAM); - } - + PreservedAnalyses PassPA = Pass->run(F, FAM); PI.runAfterPass(*Pass, F, PassPA); // We know that the function pass couldn't have invalidated any other diff --git a/llvm/lib/IR/PassManager.cpp b/llvm/lib/IR/PassManager.cpp --- a/llvm/lib/IR/PassManager.cpp +++ b/llvm/lib/IR/PassManager.cpp @@ -121,12 +121,7 @@ if (!PI.runBeforePass(*Pass, F)) continue; - PreservedAnalyses PassPA; - { - TimeTraceScope TimeScope(Pass->name(), F.getName()); - PassPA = Pass->run(F, FAM); - } - + PreservedAnalyses PassPA = Pass->run(F, FAM); PI.runAfterPass(*Pass, F, PassPA); // We know that the function pass couldn't have invalidated any other diff --git a/llvm/lib/Passes/StandardInstrumentations.cpp b/llvm/lib/Passes/StandardInstrumentations.cpp --- a/llvm/lib/Passes/StandardInstrumentations.cpp +++ b/llvm/lib/Passes/StandardInstrumentations.cpp @@ -1161,6 +1161,35 @@ TextChangeReporter>::registerRequiredCallbacks(PIC); } +TimeProfilingPassesHandler::TimeProfilingPassesHandler() {} + +void TimeProfilingPassesHandler::registerCallbacks( + PassInstrumentationCallbacks &PIC) { + this->PIC = &PIC; + PIC.registerBeforeNonSkippedPassCallback( + [this](StringRef P, Any IR) { this->runBeforePass(P, IR); }); + PIC.registerAfterPassCallback( + [this](StringRef P, Any IR, const PreservedAnalyses &) { + this->runAfterPass(); + }); + PIC.registerBeforeAnalysisCallback( + [this](StringRef P, Any IR) { this->runBeforePass(P, IR); }); + PIC.registerAfterAnalysisCallback( + [this](StringRef P, Any IR) { this->runAfterPass(); }); +} + +void TimeProfilingPassesHandler::runBeforePass(StringRef PassID, Any IR) { + if (getTimeTraceProfilerInstance() != nullptr) { + timeTraceProfilerBegin(PassID, getIRName(IR)); + } +} + +void TimeProfilingPassesHandler::runAfterPass() { + if (getTimeTraceProfilerInstance() != nullptr) { + timeTraceProfilerEnd(); + } +} + namespace { class DisplayNode; @@ -2066,6 +2095,7 @@ PrintIR.registerCallbacks(PIC); PrintPass.registerCallbacks(PIC); TimePasses.registerCallbacks(PIC); + TimeProfilingPasses.registerCallbacks(PIC); OptNone.registerCallbacks(PIC); OptBisect.registerCallbacks(PIC); if (FAM) diff --git a/llvm/lib/Transforms/Scalar/LoopPassManager.cpp b/llvm/lib/Transforms/Scalar/LoopPassManager.cpp --- a/llvm/lib/Transforms/Scalar/LoopPassManager.cpp +++ b/llvm/lib/Transforms/Scalar/LoopPassManager.cpp @@ -291,11 +291,7 @@ if (!PI.runBeforePass(*Pass, *L)) continue; - PreservedAnalyses PassPA; - { - TimeTraceScope TimeScope(Pass->name()); - PassPA = Pass->run(*L, LAM, LAR, Updater); - } + PreservedAnalyses PassPA = Pass->run(*L, LAM, LAR, Updater); // Do not pass deleted Loop into the instrumentation. if (Updater.skipCurrentLoop())