/*
- * Copyright (C) 2010-2012 jeanfi@gmail.com
+ * Copyright (C) 2010-2014 jeanfi@gmail.com
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301 USA
*/
+#define _LARGEFILE_SOURCE 1
+#include "config.h"
+
#include <locale.h>
#include <libintl.h>
#define _(str) gettext(str)
#include <atasmart.h>
#include <linux/fs.h>
-#include "pio.h"
-#include "hdd.h"
-#include "log.h"
+#include <pio.h>
+#include <hdd.h>
+#include <plog.h>
+
+static const char *PROVIDER_NAME = "atasmart";
static int filter_sd(const char *p)
{
create_sensor(char *id, char *name, SkDisk *disk, int values_max_length)
{
struct psensor *s;
+ int t;
+
+ t = SENSOR_TYPE_ATASMART | SENSOR_TYPE_HDD | SENSOR_TYPE_TEMP;
+
s = psensor_create(id,
strdup(name),
- SENSOR_TYPE_HDD_TEMP_ATASMART,
+ strdup(_("Disk")),
+ t,
values_max_length);
s->disk = disk;
size = (uint64_t)-1;
/* So, it's a block device. Let's make sure the ioctls work */
if (ioctl(f, BLKGETSIZE64, &size) < 0) {
- log_debug("ioctl fails %s: %s", dname, strerror(errno));
+ log_debug("analyze_disk(hdd_atasmart): ioctl fails %s: %s",
+ dname,
+ strerror(errno));
goto fail;
}
if (size <= 0 || size == (uint64_t) -1) {
- log_debug("ioctl wrong size %s: %ld", dname, size);
+ log_debug("analyze_disk(hdd_atasmart): ioctl wrong size %s: %ld",
+ dname,
+ size);
goto fail;
}
log_debug("hdd_psensor_list_add(hdd_atasmart) open %s", *tmp);
if (!sk_disk_open(*tmp, &disk)) {
- id = malloc(strlen("hdd at") + strlen(*tmp) + 1);
- strcpy(id, "hdd at");
- strcat(id, *tmp);
+ id = malloc(strlen(PROVIDER_NAME)
+ + 1
+ + strlen(*tmp)
+ + 1);
+ sprintf(id, "%s %s", PROVIDER_NAME, *tmp);
sensor = create_sensor(id,
*tmp,
result = tmp_sensors;
} else {
- log_err("sk_disk_open(hdd_atasmart) %s failure", *tmp);
+ log_err(_("atasmart: sk_disk_open() failure: %s."),
+ *tmp);
analyze_disk(*tmp);
}
cur = sensors;
while (*cur) {
s = *cur;
- if (s->type == SENSOR_TYPE_HDD_TEMP_ATASMART) {
+ if (!(s->type & SENSOR_TYPE_REMOTE)
+ && s->type & SENSOR_TYPE_ATASMART) {
ret = sk_disk_smart_read_data(s->disk);
if (!ret) {