X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fcpu.c;h=d48ab886332912a1c09e62c477d0048209dc9ab6;hb=8fd8f76dc11064e75e44448d16d35e09e46191a2;hp=b62679bcb69f8d50575b48ed39986bfe6ce8625b;hpb=6b9524922bf25e292fb4151031bc964d8041487c;p=collectd.git diff --git a/src/cpu.c b/src/cpu.c index b62679bc..d48ab886 100644 --- a/src/cpu.c +++ b/src/cpu.c @@ -676,40 +676,37 @@ static int cpu_read(void) { now); cpu_stage(cpu, COLLECTD_CPU_STATE_SOFTIRQ, (derive_t)atoll(fields[7]), now); + } - if (numfields >= 9) { - cpu_stage(cpu, COLLECTD_CPU_STATE_STEAL, (derive_t)atoll(fields[8]), - now); - - if (numfields >= 10) { /* Guest (since Linux 2.6.24) */ - if (report_guest) { - long long value = atoll(fields[9]); - cpu_stage(cpu, COLLECTD_CPU_STATE_GUEST, - (derive_t)value, now); - /* Guest is included in User; optionally subtract Guest from - User: */ - if (subtract_guest) { - user_value -= value; - if (user_value < 0) user_value = 0; - } - } - - if (numfields >= 11) { /* Guest_nice (since Linux 2.6.33) */ - if (report_guest) { - long long value = atoll(fields[10]); - cpu_stage(cpu, COLLECTD_CPU_STATE_GUEST_NICE, - (derive_t)value, now); - /* Guest_nice is included in Nice; optionally subtract - Guest_nice from Nice: */ - if (subtract_guest) { - nice_value -= value; - if (nice_value < 0) nice_value = 0; - } - } - } + if (numfields >= 9) { /* Steal (since Linux 2.6.11) */ + cpu_stage(cpu, COLLECTD_CPU_STATE_STEAL, (derive_t)atoll(fields[8]), now); + } + + if (numfields >= 10) { /* Guest (since Linux 2.6.24) */ + if (report_guest) { + long long value = atoll(fields[9]); + cpu_stage(cpu, COLLECTD_CPU_STATE_GUEST, (derive_t)value, now); + /* Guest is included in User; optionally subtract Guest from User: */ + if (subtract_guest) { + user_value -= value; + if (user_value < 0) user_value = 0; } } } + + if (numfields >= 11) { /* Guest_nice (since Linux 2.6.33) */ + if (report_guest) { + long long value = atoll(fields[10]); + cpu_stage(cpu, COLLECTD_CPU_STATE_GUEST_NICE, (derive_t)value, now); + /* Guest_nice is included in Nice; optionally subtract Guest_nice from + Nice: */ + if (subtract_guest) { + nice_value -= value; + if (nice_value < 0) nice_value = 0; + } + } + } + /* Eventually stage User and Nice: */ cpu_stage(cpu, COLLECTD_CPU_STATE_USER, (derive_t)user_value, now); cpu_stage(cpu, COLLECTD_CPU_STATE_NICE, (derive_t)nice_value, now);