X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fentropy.c;h=94a291ece1a7edde7783ec3a353da38976a43bc3;hb=48efd3deb4c9139fd060ff3d289896e9031bcc7c;hp=03de9efb48175dccecf7bdd6ab3a53ddf730e33d;hpb=f7b05ebf3311b4c6cb5289f1f7cd8ee02918ef92;p=collectd.git diff --git a/src/entropy.c b/src/entropy.c index 03de9efb..94a291ec 100644 --- a/src/entropy.c +++ b/src/entropy.c @@ -25,57 +25,38 @@ **/ #include "collectd.h" -#include "common.h" + #include "plugin.h" +#include "utils/common/common.h" #if !KERNEL_LINUX -# error "No applicable input method." +#error "No applicable input method." #endif #define ENTROPY_FILE "/proc/sys/kernel/random/entropy_avail" -static void entropy_submit (double entropy) -{ - value_t values[1]; - value_list_t vl = VALUE_LIST_INIT; - - values[0].gauge = entropy; +static void entropy_submit(value_t value) { + value_list_t vl = VALUE_LIST_INIT; - vl.values = values; - vl.values_len = 1; - sstrncpy (vl.host, hostname_g, sizeof (vl.host)); - sstrncpy (vl.plugin, "entropy", sizeof (vl.plugin)); - sstrncpy (vl.type, "entropy", sizeof (vl.type)); + vl.values = &value; + vl.values_len = 1; + sstrncpy(vl.plugin, "entropy", sizeof(vl.plugin)); + sstrncpy(vl.type, "entropy", sizeof(vl.type)); - plugin_dispatch_values (&vl); + plugin_dispatch_values(&vl); } -static int entropy_read (void) -{ - double entropy; - FILE *fh; - char buffer[64]; - - fh = fopen (ENTROPY_FILE, "r"); - if (fh == NULL) - return (-1); - - if (fgets (buffer, sizeof (buffer), fh) == NULL) - { - fclose (fh); - return (-1); - } - fclose (fh); - - entropy = atof (buffer); - - if (entropy > 0.0) - entropy_submit (entropy); +static int entropy_read(void) { + value_t v; + if (parse_value_file(ENTROPY_FILE, &v, DS_TYPE_GAUGE) != 0) { + ERROR("entropy plugin: Reading \"" ENTROPY_FILE "\" failed."); + return -1; + } - return (0); + entropy_submit(v); + return 0; } -void module_register (void) -{ - plugin_register_read ("entropy", entropy_read); +void module_register(void) { + plugin_register_read("entropy", entropy_read); } /* void module_register */