summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2004-12-20 21:43:33 +0000
committerReid Spencer <rspencer@reidspencer.com>2004-12-20 21:43:33 +0000
commitd4c698880936ab98317c5d8565ec6f394a01cc35 (patch)
treea3c3cb58829454f0711d2d7407ec17054bdf845a
parent08b4bd74961c890b3b06627044f953ce6cc7ce3f (diff)
downloadbcm5719-llvm-d4c698880936ab98317c5d8565ec6f394a01cc35.tar.gz
bcm5719-llvm-d4c698880936ab98317c5d8565ec6f394a01cc35.zip
Implement GetTimeUsage correctly.
llvm-svn: 19074
-rw-r--r--llvm/lib/System/Unix/Process.cpp12
1 files changed, 8 insertions, 4 deletions
diff --git a/llvm/lib/System/Unix/Process.cpp b/llvm/lib/System/Unix/Process.cpp
index eef6535ee90..1c203ab50c5 100644
--- a/llvm/lib/System/Unix/Process.cpp
+++ b/llvm/lib/System/Unix/Process.cpp
@@ -92,10 +92,14 @@ Process::GetTimeUsage(TimeValue& elapsed, TimeValue& user_time,
#if defined(HAVE_GETRUSAGE)
struct rusage usage;
::getrusage(RUSAGE_SELF, &usage);
- user_time.seconds( usage.ru_utime.tv_sec );
- user_time.microseconds( usage.ru_utime.tv_usec );
- sys_time.seconds( usage.ru_stime.tv_sec );
- sys_time.microseconds( usage.ru_stime.tv_usec );
+ user_time = TimeValue(
+ static_cast<TimeValue::SecondsType>( usage.ru_utime.tv_sec ),
+ static_cast<TimeValue::NanoSecondsType>( usage.ru_utime.tv_usec *
+ TimeValue::NANOSECONDS_PER_MICROSECOND ) );
+ sys_time = TimeValue(
+ static_cast<TimeValue::SecondsType>( usage.ru_stime.tv_sec ),
+ static_cast<TimeValue::NanoSecondsType>( usage.ru_stime.tv_usec *
+ TimeValue::NANOSECONDS_PER_MICROSECOND ) );
#else
#warning Cannot get usage times on this platform
user_time.seconds(0);
OpenPOWER on IntegriCloud