X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Firq.c;h=9b7e61877d8c62bafc009e91e1f792c43024e63e;hb=b4d9bd23f3e04f9b42204d9954842524e2a7eb61;hp=6c30e95a752bb4583ca6ce466279062cdfb7e094;hpb=d246967f9483c508549f1723ec977cc8a19dbd4c;p=collectd.git diff --git a/src/irq.c b/src/irq.c index 6c30e95a..9b7e6187 100644 --- a/src/irq.c +++ b/src/irq.c @@ -25,12 +25,8 @@ #include "plugin.h" #include "configfile.h" -#define MODULE_NAME "irq" - -#if KERNEL_LINUX -# define IRQ_HAVE_READ 1 -#else -# define IRQ_HAVE_READ 0 +#if !KERNEL_LINUX +# error "No applicable input method." #endif #define BUFSIZE 128 @@ -38,17 +34,6 @@ /* * (Module-)Global variables */ -static data_source_t dsrc_irq[1] = -{ - {"value", DS_TYPE_COUNTER, 0, 65535.0} -}; - -static data_set_t ds_irq = -{ - "irq", 1, dsrc_irq -}; - -#if IRQ_HAVE_READ static const char *config_keys[] = { "Irq", @@ -78,7 +63,7 @@ static int irq_config (const char *key, const char *value) if (temp == NULL) { fprintf (stderr, "irq plugin: Cannot allocate more memory.\n"); - syslog (LOG_ERR, "irq plugin: Cannot allocate more memory."); + ERROR ("irq plugin: Cannot allocate more memory."); return (1); } irq_list = temp; @@ -91,7 +76,7 @@ static int irq_config (const char *key, const char *value) { fprintf (stderr, "irq plugin: Irq value is not a " "number: `%s'\n", value); - syslog (LOG_ERR, "irq plugin: Irq value is not a " + ERROR ("irq plugin: Irq value is not a " "number: `%s'", value); return (1); } @@ -126,7 +111,7 @@ static int check_ignore_irq (const unsigned int irq) if (irq_list_num < 1) return (0); - for (i = 0; i < irq_list_num; i++) + for (i = 0; (unsigned int)i < irq_list_num; i++) if (irq == irq_list[i]) return (irq_list_action); @@ -147,21 +132,20 @@ static void irq_submit (unsigned int irq, counter_t value) vl.values = values; vl.values_len = 1; vl.time = time (NULL); - strcpy (vl.host, hostname_g); - strcpy (vl.plugin, "irq"); + sstrncpy (vl.host, hostname_g, sizeof (vl.host)); + sstrncpy (vl.plugin, "irq", sizeof (vl.plugin)); + sstrncpy (vl.type, "irq", sizeof (vl.type)); - status = snprintf (vl.type_instance, sizeof (vl.type_instance), + status = ssnprintf (vl.type_instance, sizeof (vl.type_instance), "%u", irq); - if ((status < 1) || (status >= sizeof (vl.type_instance))) + if ((status < 1) || ((unsigned int)status >= sizeof (vl.type_instance))) return; - plugin_dispatch_values ("irq", &vl); + plugin_dispatch_values (&vl); } /* void irq_submit */ static int irq_read (void) { -#if KERNEL_LINUX - #undef BUFSIZE #define BUFSIZE 256 @@ -178,8 +162,9 @@ static int irq_read (void) if ((fh = fopen ("/proc/interrupts", "r")) == NULL) { - syslog (LOG_WARNING, "irq plugin: fopen (/proc/interrupts): %s", - strerror (errno)); + char errbuf[1024]; + WARNING ("irq plugin: fopen (/proc/interrupts): %s", + sstrerror (errno, errbuf, sizeof (errbuf))); return (-1); } while (fgets (buffer, BUFSIZE, fh) != NULL) @@ -209,22 +194,15 @@ static int irq_read (void) irq_submit (irq, irq_value); } fclose (fh); -#endif /* KERNEL_LINUX */ return (0); } /* int irq_read */ -#endif /* IRQ_HAVE_READ */ void module_register (void) { - plugin_register_data_set (&ds_irq); - -#if IRQ_HAVE_READ plugin_register_config ("irq", irq_config, config_keys, config_keys_num); plugin_register_read ("irq", irq_read); -#endif /* IRQ_HAVE_READ */ -} +} /* void module_register */ #undef BUFSIZE -#undef MODULE_NAME