}
static struct psensor *
-create_sensor(char *id, char *name, int values_max_length)
+create_sensor(char *id, char *name, SkDisk *disk, int values_max_length)
{
- return psensor_create(id,
- strdup(name),
- SENSOR_TYPE_HDD_TEMP,
- values_max_length);
+ struct psensor *s;
+ s = psensor_create(id,
+ strdup(name),
+ SENSOR_TYPE_HDD_TEMP_ATASMART,
+ values_max_length);
+
+ s->disk = disk;
+
+ return s;
}
struct psensor **hdd_psensor_list_add(struct psensor **sensors,
int values_max_length)
{
- char **paths, **tmp;
+ char **paths, **tmp, *id;
SkDisk *disk;
struct psensor *sensor, **tmp_sensors, **result;
result = sensors;
tmp = paths;
while (*tmp) {
- log_debug("hdd_psensor_list_add open %s", tmp);
+ log_debug("hdd_psensor_list_add open %s", *tmp);
if (!sk_disk_open(*tmp, &disk)) {
- char *id = malloc(strlen("hdd at") + strlen(*tmp) + 1);
+ id = malloc(strlen("hdd at") + strlen(*tmp) + 1);
strcpy(id, "hdd at");
strcat(id, *tmp);
- sensor = create_sensor(id, *tmp, values_max_length);
+ sensor = create_sensor(id,
+ *tmp,
+ disk,
+ values_max_length);
tmp_sensors = psensor_list_add(result, sensor);
void hdd_psensor_list_update(struct psensor **sensors)
{
+ struct psensor **cur, *s;
+ uint64_t kelvin;
+ int ret;
+ double c;
+
+ cur = sensors;
+ while (*cur) {
+ s = *cur;
+ if (s->type == SENSOR_TYPE_HDD_TEMP_ATASMART) {
+ ret = sk_disk_smart_read_data(s->disk);
+
+ if (!ret) {
+ ret = sk_disk_smart_get_temperature(s->disk,
+ &kelvin);
+
+ if (!ret) {
+ c = (kelvin - 273150) / 1000;
+ psensor_set_current_value(s, c);
+ log_debug("hdd atasmart: %s %.2f",
+ s->id,
+ c);
+ }
+ }
+ }
+
+ cur++;
+ }
}
static struct psensor *
create_sensor(char *id, char *name, int values_max_length)
{
- return psensor_create(id, name, SENSOR_TYPE_HDD_TEMP,
+ return psensor_create(id, name, SENSOR_TYPE_HDD_TEMP_HDDTEMP,
values_max_length);
}
struct psensor **sensor_cur = sensors;
while (*sensor_cur) {
- if ((*sensor_cur)->type == SENSOR_TYPE_HDD_TEMP
+ if ((*sensor_cur)->type == SENSOR_TYPE_HDD_TEMP_HDDTEMP
&& !strcmp((*sensor_cur)->id + 4, info->name))
psensor_set_current_value(*sensor_cur,
(float)info->temp);
cpu_psensor_list_update(sensors);
#endif
- if (psensor_list_contains_type(sensors, SENSOR_TYPE_HDD_TEMP))
+ if (psensor_list_contains_type(sensors, SENSOR_TYPE_HDD_TEMP_HDDTEMP)
+ || psensor_list_contains_type(sensors,
+ SENSOR_TYPE_HDD_TEMP_ATASMART))
hdd_psensor_list_update(sensors);
}
SENSOR_TYPE_CPU_USAGE = 0x0800,
SENSOR_TYPE_AMD = 0x1000,
+ SENSOR_TYPE_HDD_TEMP_ATASMART = 0x2000 | SENSOR_TYPE_HDD_TEMP,
+ SENSOR_TYPE_HDD_TEMP_HDDTEMP = 0x4000 | SENSOR_TYPE_HDD_TEMP,
+
SENSOR_TYPE_AMD_TEMP = SENSOR_TYPE_AMD | SENSOR_TYPE_TEMP,
SENSOR_TYPE_AMD_FAN = SENSOR_TYPE_AMD | SENSOR_TYPE_FAN,