From 7d05563324e538a377ba12ca62b2b5b0fbbba547 Mon Sep 17 00:00:00 2001 From: Reid Spencer Date: Mon, 20 Dec 2004 21:44:27 +0000 Subject: Fix a bug where system time always equals user time git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@19075 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Support/Timer.cpp | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) (limited to 'lib/Support/Timer.cpp') 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; } -- cgit v1.2.3-18-g5258