From 9f9f6d19dd67926446fb89a7b2dc0bda6353645b Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Tue, 30 Mar 2010 04:58:26 +0000 Subject: [PATCH] if a timergroup is destroyed before its timers, print times. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@99873 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/Support/Timer.h | 6 +----- lib/Support/Statistic.cpp | 2 +- lib/Support/Timer.cpp | 18 +++++++++++++----- 3 files changed, 15 insertions(+), 11 deletions(-) diff --git a/include/llvm/Support/Timer.h b/include/llvm/Support/Timer.h index aba31506fcf..2997a8744cc 100644 --- a/include/llvm/Support/Timer.h +++ b/include/llvm/Support/Timer.h @@ -171,6 +171,7 @@ public: explicit TimerGroup(const TimerGroup &TG) : FirstTimer(0) { operator=(TG); } + ~TimerGroup(); void operator=(const TimerGroup &TG) { assert(TG.FirstTimer == 0 && FirstTimer == 0 && @@ -181,11 +182,6 @@ public: void setName(const std::string &name) { Name = name; } - ~TimerGroup() { - assert(FirstTimer == 0 && - "TimerGroup destroyed before all contained timers!"); - } - void PrintQueuedTimers(raw_ostream &OS); private: diff --git a/lib/Support/Statistic.cpp b/lib/Support/Statistic.cpp index e7876704599..f88094af74b 100644 --- a/lib/Support/Statistic.cpp +++ b/lib/Support/Statistic.cpp @@ -128,6 +128,6 @@ StatisticInfo::~StatisticInfo() { OutStream << '\n'; // Flush the output stream... OutStream.flush(); - if (&OutStream != &outs() && &OutStream != &errs() && &OutStream != &dbgs()) + if (&OutStream != &outs() && &OutStream != &errs()) delete &OutStream; // Close the file. } diff --git a/lib/Support/Timer.cpp b/lib/Support/Timer.cpp index cc903805e8f..daafd63dd2d 100644 --- a/lib/Support/Timer.cpp +++ b/lib/Support/Timer.cpp @@ -237,14 +237,22 @@ NamedRegionTimer::NamedRegionTimer(const std::string &Name, // TimerGroup Implementation //===----------------------------------------------------------------------===// +TimerGroup::~TimerGroup() { + // If the timer group is destroyed before the timers it owns, accumulate and + // print the timing data. + while (FirstTimer != 0) + removeTimer(*FirstTimer); +} + + void TimerGroup::removeTimer(Timer &T) { sys::SmartScopedLock L(*TimerLock); // If the timer was started, move its data to TimersToPrint. - if (T.Started) { - T.Started = false; + if (T.Started) TimersToPrint.push_back(std::make_pair(T.Time, T.Name)); - } + + T.TG = 0; // Unlink the timer from our list. *T.Prev = T.Next; @@ -257,9 +265,9 @@ void TimerGroup::removeTimer(Timer &T) { return; raw_ostream *OutStream = GetLibSupportInfoOutputFile(); - + PrintQueuedTimers(*OutStream); - + if (OutStream != &errs() && OutStream != &outs()) delete OutStream; // Close the file. }