diff options
author | Reid Spencer <rspencer@reidspencer.com> | 2004-12-20 21:43:33 +0000 |
---|---|---|
committer | Reid Spencer <rspencer@reidspencer.com> | 2004-12-20 21:43:33 +0000 |
commit | d4c698880936ab98317c5d8565ec6f394a01cc35 (patch) | |
tree | a3c3cb58829454f0711d2d7407ec17054bdf845a | |
parent | 08b4bd74961c890b3b06627044f953ce6cc7ce3f (diff) | |
download | bcm5719-llvm-d4c698880936ab98317c5d8565ec6f394a01cc35.tar.gz bcm5719-llvm-d4c698880936ab98317c5d8565ec6f394a01cc35.zip |
Implement GetTimeUsage correctly.
llvm-svn: 19074
-rw-r--r-- | llvm/lib/System/Unix/Process.cpp | 12 |
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); |