X-Git-Url: https://git.octo.it/?p=collectd.git;a=blobdiff_plain;f=src%2Firq.c;h=7e738291c58af7c851907f477e7386fc5e3fd561;hp=70d6b5abe41dfd353ff1574a3035194f9e45654d;hb=61fba41289decabc1a18c855fcd462fece9ab983;hpb=66bdee8d4c974e893826335977e1cc52410380eb diff --git a/src/irq.c b/src/irq.c index 70d6b5ab..7e738291 100644 --- a/src/irq.c +++ b/src/irq.c @@ -106,7 +106,7 @@ static int check_ignore_irq (const char *irq) return (1 - irq_list_action); } -static void irq_submit (const char *irq_name, counter_t value) +static void irq_submit (const char *irq_name, derive_t value) { value_t values[1]; value_list_t vl = VALUE_LIST_INIT; @@ -114,7 +114,7 @@ static void irq_submit (const char *irq_name, counter_t value) if (check_ignore_irq (irq_name)) return; - values[0].counter = value; + values[0].derive = value; vl.values = values; vl.values_len = 1; @@ -130,25 +130,25 @@ static int irq_read (void) { FILE *fh; char buffer[1024]; - unsigned long long irq_value; - unsigned long long value; - char *endptr; - int i; - char *fields[64]; - int fields_num; - - if ((fh = fopen ("/proc/interrupts", "r")) == NULL) + fh = fopen ("/proc/interrupts", "r"); + if (fh == NULL) { char errbuf[1024]; - WARNING ("irq plugin: fopen (/proc/interrupts): %s", + ERROR ("irq plugin: fopen (/proc/interrupts): %s", sstrerror (errno, errbuf, sizeof (errbuf))); return (-1); } + while (fgets (buffer, sizeof (buffer), fh) != NULL) { char *irq_name; size_t irq_name_len; + derive_t irq_value; + int i; + + char *fields[64]; + int fields_num; fields_num = strsplit (buffer, fields, 64); if (fields_num < 2) @@ -170,23 +170,22 @@ static int irq_read (void) irq_value = 0; for (i = 1; i < fields_num; i++) { - errno = 0; - endptr = NULL; - value = strtoull (fields[i], &endptr, 10); + /* Per-CPU value */ + value_t v; + int status; - /* Ignore all fields following a non-numeric field. */ - if ((errno != 0) || (endptr == NULL) || (*endptr != 0)) + status = parse_value (fields[i], &v, DS_TYPE_DERIVE); + if (status != 0) break; - irq_value += value; + irq_value += v.derive; } /* for (i) */ /* No valid fields -> do not submit anything. */ if (i <= 1) continue; - /* Force 32bit wrap-around */ - irq_submit (irq_name, irq_value % 4294967296ULL); + irq_submit (irq_name, irq_value); } fclose (fh);