X-Git-Url: http://wpitchoune.net/gitweb/?p=psensor-pkg-debian.git;a=blobdiff_plain;f=src%2Flib%2Fhdd_atasmart.c;h=402c92ee949ce9c6ea24a93ed32e37b81bb88191;hp=0fd7d5d7f4e1f12bcad8f073ae88a33cac13280d;hb=bd7036af56a4b61b2b473dccbeac5e26f78b57da;hpb=48da1ac5531838d157762882ee455cec4da05728;ds=sidebyside diff --git a/src/lib/hdd_atasmart.c b/src/lib/hdd_atasmart.c index 0fd7d5d..402c92e 100644 --- a/src/lib/hdd_atasmart.c +++ b/src/lib/hdd_atasmart.c @@ -25,6 +25,7 @@ #include #include +#include #include #include #include @@ -46,6 +47,16 @@ static int filter_sd(const char *p) return strlen(p) == 8 && !strncmp(p, "/dev/sd", 7); } +static void provider_data_free(void *data) +{ + sk_disk_free((SkDisk *)data); +} + +static SkDisk *get_disk(struct psensor *s) +{ + return (SkDisk *)s->provider_data; +} + static struct psensor * create_sensor(char *id, char *name, SkDisk *disk, int values_max_length) { @@ -60,7 +71,8 @@ create_sensor(char *id, char *name, SkDisk *disk, int values_max_length) t, values_max_length); - s->disk = disk; + s->provider_data = disk; + s->provider_data_free_fct = &provider_data_free; return s; } @@ -158,16 +170,22 @@ void atasmart_psensor_list_update(struct psensor **sensors) uint64_t kelvin; int ret; double c; + SkDisk *disk; + + if (!sensors) + return; cur = sensors; while (*cur) { s = *cur; if (!(s->type & SENSOR_TYPE_REMOTE) && s->type & SENSOR_TYPE_ATASMART) { - ret = sk_disk_smart_read_data(s->disk); + disk = get_disk(s); + + ret = sk_disk_smart_read_data(disk); if (!ret) { - ret = sk_disk_smart_get_temperature(s->disk, + ret = sk_disk_smart_get_temperature(disk, &kelvin); if (!ret) {