summaryrefslogtreecommitdiff
path: root/lib/Support/Timer.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'lib/Support/Timer.cpp')
-rw-r--r--lib/Support/Timer.cpp17
1 files changed, 12 insertions, 5 deletions
diff --git a/lib/Support/Timer.cpp b/lib/Support/Timer.cpp
index 1b2f91d03b..47d696804a 100644
--- a/lib/Support/Timer.cpp
+++ b/lib/Support/Timer.cpp
@@ -105,12 +105,19 @@ static TimeRecord getTimeRecord(bool Start) {
sys::TimeValue user(0,0);
sys::TimeValue sys(0,0);
- sys::Process::GetTimeUsage(now,user,sys);
+ long MemUsed = 0;
+ if (Start) {
+ sys::Process::GetTimeUsage(now,user,sys);
+ MemUsed = sys::Process::GetMallocUsage();
+ } else {
+ MemUsed = sys::Process::GetMallocUsage();
+ sys::Process::GetTimeUsage(now,user,sys);
+ }
- Result.Elapsed = now.seconds() + now.microseconds() / 1000000.0;
- Result.UserTime = user.seconds() + user.microseconds() / 1000000.0;
- Result.UserTime = sys.seconds() + sys.microseconds() / 1000000.0;
- Result.MemUsed = sys::Process::GetMallocUsage();
+ Result.Elapsed = now.seconds() + now.microseconds() / 1000000.0;
+ Result.UserTime = user.seconds() + user.microseconds() / 1000000.0;
+ Result.SystemTime = sys.seconds() + sys.microseconds() / 1000000.0;
+ Result.MemUsed = MemUsed;
return Result;
}