mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-26 20:57:15 +00:00
For PR351:
* Implement GetMallocUsage to get usage of malloc heap * Implement GetMemoryUsage to get total memory usage of process * Implement GetTimeUsage to get elapsed/user/system time git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@19055 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a4775838e2
commit
721d9aa060
@ -11,7 +11,16 @@
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include <unistd.h>
|
||||
#include "Unix.h"
|
||||
#ifdef HAVE_SYS_TIME_H
|
||||
#include <sys/time.h>
|
||||
#endif
|
||||
#ifdef HAVE_SYS_RESOURCE_H
|
||||
#include <sys/resource.h>
|
||||
#endif
|
||||
#ifdef HAVE_MALLOC_H
|
||||
#include <malloc.h>
|
||||
#endif
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
//=== WARNING: Implementation here must contain only generic UNIX code that
|
||||
@ -22,13 +31,76 @@ namespace llvm {
|
||||
using namespace sys;
|
||||
|
||||
unsigned
|
||||
Process::GetPageSize() {
|
||||
// NOTE: The getpagesize function doesn't exist in POSIX 1003.1 and is
|
||||
// "deprecated" in SUSv2. Platforms including this implementation should
|
||||
// consider sysconf(_SC_PAGE_SIZE) if its available.
|
||||
static const int page_size = getpagesize();
|
||||
Process::GetPageSize()
|
||||
{
|
||||
#if defined(HAVE_GETPAGESIZE)
|
||||
static const int page_size = ::getpagesize();
|
||||
#elif defined(HAVE_SYSCONF)
|
||||
static long page_size = ::sysconf(_SC_PAGE_SIZE);
|
||||
#else
|
||||
#warning Cannot get the page size on this machine
|
||||
#endif
|
||||
return static_cast<unsigned>(page_size);
|
||||
}
|
||||
|
||||
#if defined(HAVE_SBRK)
|
||||
static char* som = reinterpret_cast<char*>(::sbrk(0));
|
||||
#endif
|
||||
|
||||
uint64_t
|
||||
Process::GetMallocUsage()
|
||||
{
|
||||
#ifdef HAVE_MALLINFO
|
||||
struct mallinfo mi;
|
||||
mi = ::mallinfo();
|
||||
return mi.uordblks;
|
||||
#elif HAVE_SBRK
|
||||
// Note this is only an approximation and more closely resembles
|
||||
// the value returned by mallinfo in the arena field.
|
||||
char * eom = sbrk(0);
|
||||
if (eom != ((char*)-1) && som != ((char*)-1))
|
||||
return eom - som;
|
||||
else
|
||||
return 0;
|
||||
#else
|
||||
#warning Cannot get malloc info on this platform
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
uint64_t
|
||||
Process::GetTotalMemoryUsage()
|
||||
{
|
||||
#ifdef HAVE_MALLINFO
|
||||
struct mallinfo mi = ::mallinfo();
|
||||
return mi.uordblks + mi.hblkhd;
|
||||
#else
|
||||
#warning Cannot get total memory size on this platform
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
void
|
||||
Process::GetTimeUsage(TimeValue& elapsed, TimeValue& user_time,
|
||||
TimeValue& sys_time)
|
||||
{
|
||||
elapsed = TimeValue::now();
|
||||
#ifdef 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 );
|
||||
#else
|
||||
#warning Cannot get usage times on this platform
|
||||
user_time.seconds(0);
|
||||
user_time.microseconds(0);
|
||||
sys_time.seconds(0);
|
||||
sys_time.microseconds(0);
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
// vim: sw=2 smartindent smarttab tw=80 autoindent expandtab
|
||||
|
@ -11,7 +11,16 @@
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include <unistd.h>
|
||||
#include "Unix.h"
|
||||
#ifdef HAVE_SYS_TIME_H
|
||||
#include <sys/time.h>
|
||||
#endif
|
||||
#ifdef HAVE_SYS_RESOURCE_H
|
||||
#include <sys/resource.h>
|
||||
#endif
|
||||
#ifdef HAVE_MALLOC_H
|
||||
#include <malloc.h>
|
||||
#endif
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
//=== WARNING: Implementation here must contain only generic UNIX code that
|
||||
@ -22,13 +31,76 @@ namespace llvm {
|
||||
using namespace sys;
|
||||
|
||||
unsigned
|
||||
Process::GetPageSize() {
|
||||
// NOTE: The getpagesize function doesn't exist in POSIX 1003.1 and is
|
||||
// "deprecated" in SUSv2. Platforms including this implementation should
|
||||
// consider sysconf(_SC_PAGE_SIZE) if its available.
|
||||
static const int page_size = getpagesize();
|
||||
Process::GetPageSize()
|
||||
{
|
||||
#if defined(HAVE_GETPAGESIZE)
|
||||
static const int page_size = ::getpagesize();
|
||||
#elif defined(HAVE_SYSCONF)
|
||||
static long page_size = ::sysconf(_SC_PAGE_SIZE);
|
||||
#else
|
||||
#warning Cannot get the page size on this machine
|
||||
#endif
|
||||
return static_cast<unsigned>(page_size);
|
||||
}
|
||||
|
||||
#if defined(HAVE_SBRK)
|
||||
static char* som = reinterpret_cast<char*>(::sbrk(0));
|
||||
#endif
|
||||
|
||||
uint64_t
|
||||
Process::GetMallocUsage()
|
||||
{
|
||||
#ifdef HAVE_MALLINFO
|
||||
struct mallinfo mi;
|
||||
mi = ::mallinfo();
|
||||
return mi.uordblks;
|
||||
#elif HAVE_SBRK
|
||||
// Note this is only an approximation and more closely resembles
|
||||
// the value returned by mallinfo in the arena field.
|
||||
char * eom = sbrk(0);
|
||||
if (eom != ((char*)-1) && som != ((char*)-1))
|
||||
return eom - som;
|
||||
else
|
||||
return 0;
|
||||
#else
|
||||
#warning Cannot get malloc info on this platform
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
uint64_t
|
||||
Process::GetTotalMemoryUsage()
|
||||
{
|
||||
#ifdef HAVE_MALLINFO
|
||||
struct mallinfo mi = ::mallinfo();
|
||||
return mi.uordblks + mi.hblkhd;
|
||||
#else
|
||||
#warning Cannot get total memory size on this platform
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
void
|
||||
Process::GetTimeUsage(TimeValue& elapsed, TimeValue& user_time,
|
||||
TimeValue& sys_time)
|
||||
{
|
||||
elapsed = TimeValue::now();
|
||||
#ifdef 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 );
|
||||
#else
|
||||
#warning Cannot get usage times on this platform
|
||||
user_time.seconds(0);
|
||||
user_time.microseconds(0);
|
||||
sys_time.seconds(0);
|
||||
sys_time.microseconds(0);
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
// vim: sw=2 smartindent smarttab tw=80 autoindent expandtab
|
||||
|
@ -41,5 +41,48 @@ Process::GetPageSize() {
|
||||
return PageSize;
|
||||
}
|
||||
|
||||
void*
|
||||
uint64_t
|
||||
Process::GetMallocUsage()
|
||||
{
|
||||
#ifdef HAVE_MALLINFO
|
||||
struct mallinfo mi = ::mallinfo();
|
||||
return mi.uordblks;
|
||||
#warning Cannot get malloc info on this platform
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
uint64_t
|
||||
Process::GetTotalMemoryUsage()
|
||||
{
|
||||
#ifdef HAVE_MALLINFO
|
||||
struct mallinfo mi = ::mallinfo();
|
||||
return mi.uordblks + mi.hblkhd
|
||||
#else
|
||||
#warning Cannot get total memory size on this platform
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
void
|
||||
Process::GetTimeUsage(
|
||||
TimeValue& elapsed, TimeValue& user_time, TimeValue& sys_time)
|
||||
{
|
||||
elapsed = TimeValue::now();
|
||||
|
||||
unsigned __int64 ProcCreate, ProcExit, KernelTime, UserTime;
|
||||
GetProcessTimes(GetCurrentProcess(), (FILETIME*)&ProcCreate,
|
||||
(FILETIME*)&ProcExit, (FILETIME*)&KernelTime,
|
||||
(FILETIME*)&UserTime
|
||||
);
|
||||
|
||||
// FILETIME's are # of 100 nanosecond ticks (1/10th of a microsecond)
|
||||
user_time.seconds( UserTime / 10000000 );
|
||||
user_time.nanoseconds( (UserTime % 10000000) * 100 );
|
||||
sys_time.seconds( KernelTime / 10000000 );
|
||||
user_time.nanoseconds( (UserTime % 10000000) * 100 );
|
||||
}
|
||||
|
||||
}
|
||||
// vim: sw=2 smartindent smarttab tw=80 autoindent expandtab
|
||||
|
@ -41,5 +41,48 @@ Process::GetPageSize() {
|
||||
return PageSize;
|
||||
}
|
||||
|
||||
void*
|
||||
uint64_t
|
||||
Process::GetMallocUsage()
|
||||
{
|
||||
#ifdef HAVE_MALLINFO
|
||||
struct mallinfo mi = ::mallinfo();
|
||||
return mi.uordblks;
|
||||
#warning Cannot get malloc info on this platform
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
uint64_t
|
||||
Process::GetTotalMemoryUsage()
|
||||
{
|
||||
#ifdef HAVE_MALLINFO
|
||||
struct mallinfo mi = ::mallinfo();
|
||||
return mi.uordblks + mi.hblkhd
|
||||
#else
|
||||
#warning Cannot get total memory size on this platform
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
void
|
||||
Process::GetTimeUsage(
|
||||
TimeValue& elapsed, TimeValue& user_time, TimeValue& sys_time)
|
||||
{
|
||||
elapsed = TimeValue::now();
|
||||
|
||||
unsigned __int64 ProcCreate, ProcExit, KernelTime, UserTime;
|
||||
GetProcessTimes(GetCurrentProcess(), (FILETIME*)&ProcCreate,
|
||||
(FILETIME*)&ProcExit, (FILETIME*)&KernelTime,
|
||||
(FILETIME*)&UserTime
|
||||
);
|
||||
|
||||
// FILETIME's are # of 100 nanosecond ticks (1/10th of a microsecond)
|
||||
user_time.seconds( UserTime / 10000000 );
|
||||
user_time.nanoseconds( (UserTime % 10000000) * 100 );
|
||||
sys_time.seconds( KernelTime / 10000000 );
|
||||
user_time.nanoseconds( (UserTime % 10000000) * 100 );
|
||||
}
|
||||
|
||||
}
|
||||
// vim: sw=2 smartindent smarttab tw=80 autoindent expandtab
|
||||
|
Loading…
x
Reference in New Issue
Block a user