mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-27 23:15:18 +00:00
util: Parse RSS into ullp
It is used to fill an unsigned long long anyway and if it is negative than there is really an issue somewhere. Signed-off-by: Martin Kletzander <mkletzan@redhat.com> Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
a7ee9eac83
commit
e940cac98e
@ -9937,7 +9937,7 @@ qemuDomainMemoryStatsInternal(virDomainObj *vm,
|
|||||||
|
|
||||||
{
|
{
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
long rss;
|
unsigned long long rss;
|
||||||
|
|
||||||
if (virDomainObjCheckActive(vm) < 0)
|
if (virDomainObjCheckActive(vm) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
#include <limits.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#ifndef WIN32
|
#ifndef WIN32
|
||||||
# include <sys/wait.h>
|
# include <sys/wait.h>
|
||||||
@ -1739,7 +1740,7 @@ virProcessGetStatInfo(unsigned long long *cpuTime,
|
|||||||
unsigned long long *userTime,
|
unsigned long long *userTime,
|
||||||
unsigned long long *sysTime,
|
unsigned long long *sysTime,
|
||||||
int *lastCpu,
|
int *lastCpu,
|
||||||
long *vm_rss,
|
unsigned long long *vm_rss,
|
||||||
pid_t pid,
|
pid_t pid,
|
||||||
pid_t tid)
|
pid_t tid)
|
||||||
{
|
{
|
||||||
@ -1748,14 +1749,16 @@ virProcessGetStatInfo(unsigned long long *cpuTime,
|
|||||||
unsigned long long stime = 0;
|
unsigned long long stime = 0;
|
||||||
const unsigned long long jiff2nsec = 1000ull * 1000ull * 1000ull /
|
const unsigned long long jiff2nsec = 1000ull * 1000ull * 1000ull /
|
||||||
(unsigned long long) sysconf(_SC_CLK_TCK);
|
(unsigned long long) sysconf(_SC_CLK_TCK);
|
||||||
long rss = 0;
|
const long pagesize = virGetSystemPageSizeKB();
|
||||||
|
unsigned long long rss = 0;
|
||||||
int cpu = 0;
|
int cpu = 0;
|
||||||
|
|
||||||
if (!proc_stat ||
|
if (!proc_stat ||
|
||||||
virStrToLong_ullp(proc_stat[VIR_PROCESS_STAT_UTIME], NULL, 10, &utime) < 0 ||
|
virStrToLong_ullp(proc_stat[VIR_PROCESS_STAT_UTIME], NULL, 10, &utime) < 0 ||
|
||||||
virStrToLong_ullp(proc_stat[VIR_PROCESS_STAT_STIME], NULL, 10, &stime) < 0 ||
|
virStrToLong_ullp(proc_stat[VIR_PROCESS_STAT_STIME], NULL, 10, &stime) < 0 ||
|
||||||
virStrToLong_l(proc_stat[VIR_PROCESS_STAT_RSS], NULL, 10, &rss) < 0 ||
|
virStrToLong_ullp(proc_stat[VIR_PROCESS_STAT_RSS], NULL, 10, &rss) < 0 ||
|
||||||
virStrToLong_i(proc_stat[VIR_PROCESS_STAT_PROCESSOR], NULL, 10, &cpu) < 0) {
|
virStrToLong_i(proc_stat[VIR_PROCESS_STAT_PROCESSOR], NULL, 10, &cpu) < 0 ||
|
||||||
|
rss > ULLONG_MAX / pagesize) {
|
||||||
VIR_WARN("cannot parse process status data");
|
VIR_WARN("cannot parse process status data");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1771,10 +1774,10 @@ virProcessGetStatInfo(unsigned long long *cpuTime,
|
|||||||
*lastCpu = cpu;
|
*lastCpu = cpu;
|
||||||
|
|
||||||
if (vm_rss)
|
if (vm_rss)
|
||||||
*vm_rss = rss * virGetSystemPageSizeKB();
|
*vm_rss = rss * pagesize;
|
||||||
|
|
||||||
|
|
||||||
VIR_DEBUG("Got status for %d/%d user=%llu sys=%llu cpu=%d rss=%ld",
|
VIR_DEBUG("Got status for %d/%d user=%llu sys=%llu cpu=%d rss=%lld",
|
||||||
(int) pid, tid, utime, stime, cpu, rss);
|
(int) pid, tid, utime, stime, cpu, rss);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -1851,7 +1854,7 @@ virProcessGetStatInfo(unsigned long long *cpuTime,
|
|||||||
unsigned long long *userTime,
|
unsigned long long *userTime,
|
||||||
unsigned long long *sysTime,
|
unsigned long long *sysTime,
|
||||||
int *lastCpu,
|
int *lastCpu,
|
||||||
long *vm_rss,
|
unsigned long long *vm_rss,
|
||||||
pid_t pid G_GNUC_UNUSED,
|
pid_t pid G_GNUC_UNUSED,
|
||||||
pid_t tid G_GNUC_UNUSED)
|
pid_t tid G_GNUC_UNUSED)
|
||||||
{
|
{
|
||||||
|
@ -198,7 +198,7 @@ int virProcessGetStatInfo(unsigned long long *cpuTime,
|
|||||||
unsigned long long *userTime,
|
unsigned long long *userTime,
|
||||||
unsigned long long *sysTime,
|
unsigned long long *sysTime,
|
||||||
int *lastCpu,
|
int *lastCpu,
|
||||||
long *vm_rss,
|
unsigned long long *vm_rss,
|
||||||
pid_t pid,
|
pid_t pid,
|
||||||
pid_t tid);
|
pid_t tid);
|
||||||
int virProcessGetSchedInfo(unsigned long long *cpuWait,
|
int virProcessGetSchedInfo(unsigned long long *cpuWait,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user