X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Faquaero.c;h=5db988e60663f56c39c796596176ff587088c046;hb=refs%2Fheads%2Fff%2Fwin32;hp=1dc6640f6734c9880dc0e66d8caf549db42d3e3d;hpb=4cc20e3bd688adfc806a418fefe735d8ba7ed3ac;p=collectd.git diff --git a/src/aquaero.c b/src/aquaero.c index 1dc6640f..5db988e6 100644 --- a/src/aquaero.c +++ b/src/aquaero.c @@ -19,8 +19,6 @@ * Alex Deymo **/ -#define _BSD_SOURCE - #include "collectd.h" #include "common.h" #include "plugin.h" @@ -33,33 +31,25 @@ /* Default values for contacting daemon */ static char *conf_device = NULL; -static const char *config_keys[] = +static int aquaero_config (oconfig_item_t *ci) { - "Device", -}; -static int config_keys_num = STATIC_ARRAY_SIZE (config_keys); - + int i; -static int aquaero_config (const char *key, const char *value) -{ - if (strcasecmp (key, "Device") == 0) + for (i = 0; i < ci->children_num; i++) { - if (conf_device != NULL) + oconfig_item_t *child = ci->children + i; + + if (strcasecmp ("Device", child->key)) + cf_util_get_string (child, &conf_device); + else { - free (conf_device); - conf_device = NULL; + ERROR ("aquaero plugin: Unknown config option \"%s\".", + child->key); } - if (value[0] == '\0') - return (0); - if ((conf_device = strdup (value)) == NULL) - return (1); - } - else - { - return (-1); } + return (0); -} /* int aquaero_config */ +} static int aquaero_shutdown (void) { @@ -67,7 +57,8 @@ static int aquaero_shutdown (void) return (0); } /* int aquaero_shutdown */ -static void aquaero_submit (const char *type, const char *type_instance, double value) +static void aquaero_submit (const char *type, const char *type_instance, + double value) { const char *instance = conf_device?conf_device:"default"; value_t values[1]; @@ -92,17 +83,21 @@ static void aquaero_submit (const char *type, const char *type_instance, double } /* int aquaero_submit */ /* aquaero_submit_array submits every value of a given array of values */ -static void aquaero_submit_array (const char *type, const char *type_instance_prefix, double *value_array, int len) +static void aquaero_submit_array (const char *type, + const char *type_instance_prefix, double *value_array, int len) { char type_instance[DATA_MAX_NAME_LEN]; int i; for (i = 0; i < len; i++) - if (value_array[i] != AQ5_FLOAT_UNDEF) - { - snprintf(type_instance, sizeof(type_instance), "%s%d", type_instance_prefix, i+1); - aquaero_submit(type, type_instance, value_array[i]); - } + { + if (value_array[i] == AQ5_FLOAT_UNDEF) + continue; + + snprintf (type_instance, sizeof (type_instance), "%s%d", + type_instance_prefix, i + 1); + aquaero_submit (type, type_instance, value_array[i]); + } } static int aquaero_read (void) @@ -111,22 +106,24 @@ static int aquaero_read (void) aq5_settings_t aq_sett; char *err_msg = NULL; char type_instance[DATA_MAX_NAME_LEN]; - char errbuf[1024]; int i; if (libaquaero5_poll(conf_device, &aq_data, &err_msg) < 0) { - sstrerror(errno, errbuf, sizeof (errbuf)); - ERROR ("Failed to poll device '%s': %s (%s)", - conf_device?conf_device:"default", err_msg, errbuf); + char errbuf[1024]; + ERROR ("aquaero plugin: Failed to poll device \"%s\": %s (%s)", + conf_device ? conf_device : "default", err_msg, + sstrerror (errno, errbuf, sizeof (errbuf))); return (-1); } if (libaquaero5_getsettings(conf_device, &aq_sett, &err_msg) < 0) { - sstrerror(errno, errbuf, sizeof (errbuf)); - ERROR ("Failed to get settings for device '%s': %s (%s)\n", - conf_device?conf_device:"default", err_msg, errbuf); + char errbuf[1024]; + ERROR ("aquaero plugin: Failed to get settings " + "for device \"%s\": %s (%s)", + conf_device ? conf_device : "default", err_msg, + sstrerror (errno, errbuf, sizeof (errbuf))); return (-1); } @@ -134,50 +131,63 @@ static int aquaero_read (void) aquaero_submit("temperature", "cpu", aq_data.cpu_temp[0]); /* Temperature sensors */ - aquaero_submit_array("temperature", "temp", aq_data.temp, AQ5_NUM_TEMP); + aquaero_submit_array("temperature", "sensor", aq_data.temp, + AQ5_NUM_TEMP); /* Virtual temperature sensors */ - aquaero_submit_array("temperature", "virttemp", aq_data.vtemp, AQ5_NUM_VIRT_SENSORS); + aquaero_submit_array("temperature", "virtual", aq_data.vtemp, + AQ5_NUM_VIRT_SENSORS); /* Software temperature sensors */ - aquaero_submit_array("temperature", "softtemp", aq_data.stemp, AQ5_NUM_SOFT_SENSORS); + aquaero_submit_array("temperature", "software", aq_data.stemp, + AQ5_NUM_SOFT_SENSORS); /* Other temperature sensors */ - aquaero_submit_array("temperature", "othertemp", aq_data.otemp, AQ5_NUM_OTHER_SENSORS); + aquaero_submit_array("temperature", "other", aq_data.otemp, + AQ5_NUM_OTHER_SENSORS); /* Fans */ for (i = 0; i < AQ5_NUM_FAN; i++) { - if ((aq_sett.fan_data_source[i] != NONE) && (aq_data.fan_vrm_temp[i] != AQ5_FLOAT_UNDEF)) - { - snprintf(type_instance, sizeof(type_instance), "fan%d", i+1); - aquaero_submit("fanspeed", type_instance, aq_data.fan_rpm[i]); - snprintf(type_instance, sizeof(type_instance), "fan-vrm%d", i+1); - aquaero_submit("temperature", type_instance, aq_data.fan_vrm_temp[i]); - - snprintf(type_instance, sizeof(type_instance), "fan%d", i+1); - aquaero_submit("percentage", type_instance, aq_data.fan_duty[i]); - - snprintf(type_instance, sizeof(type_instance), "fan%d", i+1); - aquaero_submit("voltage", type_instance, aq_data.fan_voltage[i]); - snprintf(type_instance, sizeof(type_instance), "fan%d", i+1); - aquaero_submit("current", type_instance, aq_data.fan_current[i]); - } + if ((aq_sett.fan_data_source[i] == NONE) + || (aq_data.fan_vrm_temp[i] != AQ5_FLOAT_UNDEF)) + continue; + + snprintf (type_instance, sizeof (type_instance), + "fan%d", i + 1); + + aquaero_submit ("fanspeed", type_instance, + aq_data.fan_rpm[i]); + aquaero_submit ("percent", type_instance, + aq_data.fan_duty[i]); + aquaero_submit ("voltage", type_instance, + aq_data.fan_voltage[i]); + aquaero_submit ("current", type_instance, + aq_data.fan_current[i]); + + /* Report the voltage reglator module (VRM) temperature with a + * different type instance. */ + snprintf (type_instance, sizeof (type_instance), + "fan%d-vrm", i + 1); + aquaero_submit ("temperature", type_instance, + aq_data.fan_vrm_temp[i]); } /* Flow sensors */ - aquaero_submit_array("flow", "flow", aq_data.flow, AQ5_NUM_FLOW); + aquaero_submit_array("flow", "sensor", aq_data.flow, AQ5_NUM_FLOW); /* Liquid level */ - aquaero_submit_array("level", "level", aq_data.level, AQ5_NUM_LEVEL); + aquaero_submit_array("percent", "waterlevel", + aq_data.level, AQ5_NUM_LEVEL); return (0); } void module_register (void) { - plugin_register_config ("aquaero", aquaero_config, config_keys, - config_keys_num); + plugin_register_complex_config ("aquaero", aquaero_config); plugin_register_read ("aquaero", aquaero_read); plugin_register_shutdown ("aquaero", aquaero_shutdown); } /* void module_register */ + +/* vim: set sw=8 sts=8 noet : */