MT#55283 refactor load monitor thread

Use the looper thread helper functions.

Change-Id: Ib272ce706484f393bd42f291231c82ff6ea5212f
pull/1676/head
Richard Fuchs 2 years ago
parent b90edf0ecf
commit a6ecfb8a80

@ -14,46 +14,42 @@ int cpu_usage; // percent times 100 (0 - 9999)
static long used_last, idle_last;
void load_thread(void *dummy) {
enum thread_looper_action load_thread() {
// anything to do?
if (!rtpe_config.load_limit && !rtpe_config.cpu_limit)
return;
return TLA_BREAK;
while (!rtpe_shutdown) {
if (rtpe_config.load_limit) {
double loadavg;
if (getloadavg(&loadavg, 1) >= 1)
g_atomic_int_set(&load_average, (int) (loadavg * 100.0));
else
ilog(LOG_WARN, "Failed to obtain load average: %s", strerror(errno));
}
if (rtpe_config.load_limit) {
double loadavg;
if (getloadavg(&loadavg, 1) >= 1)
g_atomic_int_set(&load_average, (int) (loadavg * 100.0));
else
ilog(LOG_WARN, "Failed to obtain load average: %s", strerror(errno));
}
if (rtpe_config.cpu_limit) {
FILE *f;
f = fopen("/proc/stat", "r");
if (f) {
long user_now, nice_now, system_now, idle_now;
if (fscanf(f, "cpu %li %li %li %li",
&user_now, &nice_now, &system_now, &idle_now) == 4)
{
long used_now = user_now + nice_now + system_now;
long used_secs = used_now - used_last;
long idle_secs = idle_now - idle_last;
long total_secs = used_secs + idle_secs;
if (total_secs > 0 && used_last && idle_last)
g_atomic_int_set(&cpu_usage, (int) (used_secs
* 10000 / total_secs));
used_last = used_now;
idle_last = idle_now;
}
else
ilog(LOG_WARN, "Failed to obtain CPU usage");
fclose(f);
if (rtpe_config.cpu_limit) {
FILE *f;
f = fopen("/proc/stat", "r");
if (f) {
long user_now, nice_now, system_now, idle_now;
if (fscanf(f, "cpu %li %li %li %li",
&user_now, &nice_now, &system_now, &idle_now) == 4)
{
long used_now = user_now + nice_now + system_now;
long used_secs = used_now - used_last;
long idle_secs = idle_now - idle_last;
long total_secs = used_secs + idle_secs;
if (total_secs > 0 && used_last && idle_last)
g_atomic_int_set(&cpu_usage, (int) (used_secs
* 10000 / total_secs));
used_last = used_now;
idle_last = idle_now;
}
else
ilog(LOG_WARN, "Failed to obtain CPU usage");
fclose(f);
}
thread_cancel_enable();
usleep(500000);
thread_cancel_disable();
}
return TLA_CONTINUE;
}

@ -1343,8 +1343,8 @@ int main(int argc, char **argv) {
rtpe_config.idle_priority, "poller timer");
/* load monitoring thread */
thread_create_detach_prio(load_thread, NULL, rtpe_config.idle_scheduling,
rtpe_config.idle_priority, "load monitor");
thread_create_looper(load_thread, rtpe_config.idle_scheduling,
rtpe_config.idle_priority, "load monitor", 500000);
/* separate thread for releasing ports (sockets), which are scheduled for clearing */
thread_create_looper(release_closed_sockets, rtpe_config.idle_scheduling,

@ -4,6 +4,6 @@
extern int load_average; // times 100
extern int cpu_usage; // times 100
void load_thread(void *);
enum thread_looper_action load_thread(void);
#endif

Loading…
Cancel
Save