blob: d82ef72a4650c17a1b0a8d15530b41d67ad94d40 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
/*
* Copyright (C) 2005-2018 Team Kodi
* This file is part of Kodi - https://kodi.tv
*
* SPDX-License-Identifier: GPL-2.0-or-later
* See LICENSES/README.md for more information.
*/
#include "PosixResourceCounter.h"
#include "utils/log.h"
#include <errno.h>
#include "PlatformDefs.h"
CPosixResourceCounter::CPosixResourceCounter()
{
Reset();
}
CPosixResourceCounter::~CPosixResourceCounter() = default;
double CPosixResourceCounter::GetCPUUsage()
{
struct timeval tmNow;
if (gettimeofday(&tmNow, NULL) == -1)
CLog::Log(LOGERROR, "error {} in gettimeofday", errno);
else
{
double dElapsed = ( ((double)tmNow.tv_sec + (double)tmNow.tv_usec / 1000000.0) -
((double)m_tmLastCheck.tv_sec + (double)m_tmLastCheck.tv_usec / 1000000.0) );
if (dElapsed >= 3.0)
{
struct rusage usage;
if (getrusage(RUSAGE_SELF, &usage) == -1)
CLog::Log(LOGERROR, "error {} in getrusage", errno);
else
{
double dUser = ( ((double)usage.ru_utime.tv_sec + (double)usage.ru_utime.tv_usec / 1000000.0) -
((double)m_usage.ru_utime.tv_sec + (double)m_usage.ru_utime.tv_usec / 1000000.0) );
double dSys = ( ((double)usage.ru_stime.tv_sec + (double)usage.ru_stime.tv_usec / 1000000.0) -
((double)m_usage.ru_stime.tv_sec + (double)m_usage.ru_stime.tv_usec / 1000000.0) );
m_tmLastCheck = tmNow;
m_usage = usage;
m_dLastUsage = ((dUser+dSys) / dElapsed) * 100.0;
return m_dLastUsage;
}
}
}
return m_dLastUsage;
}
void CPosixResourceCounter::Reset()
{
if (gettimeofday(&m_tmLastCheck, NULL) == -1)
CLog::Log(LOGERROR, "error {} in gettimeofday", errno);
if (getrusage(RUSAGE_SELF, &m_usage) == -1)
CLog::Log(LOGERROR, "error {} in getrusage", errno);
m_dLastUsage = 0.0;
}
|