1 // SPDX-License-Identifier: GPL-2.0
3 * Hwmon client for disk and solid state drives with temperature sensors
4 * Copyright (C) 2019 Zodiac Inflight Innovations
7 * Hwmon client for S.M.A.R.T. hard disk drives with temperature sensors.
8 * (C) 2018 Linus Walleij
10 * hwmon: Driver for SCSI/ATA temperature sensors
11 * by Constantin Baranov <const@mimas.ru>, submitted September 2009
13 * This drive supports reporting the temperature of SATA drives. It can be
14 * easily extended to report the temperature of SCSI drives.
16 * The primary means to read drive temperatures and temperature limits
17 * for ATA drives is the SCT Command Transport feature set as specified in
19 * It can be used to read the current drive temperature, temperature limits,
20 * and historic minimum and maximum temperatures. The SCT Command Transport
21 * feature set is documented in "AT Attachment 8 - ATA/ATAPI Command Set
24 * If the SCT Command Transport feature set is not available, drive temperatures
25 * may be readable through SMART attributes. Since SMART attributes are not well
26 * defined, this method is only used as fallback mechanism.
28 * There are three SMART attributes which may report drive temperatures.
29 * Those are defined as follows (from
30 * http://www.cropel.com/library/smart-attribute-list.aspx).
32 * 190 Temperature Temperature, monitored by a sensor somewhere inside
33 * the drive. Raw value typicaly holds the actual
34 * temperature (hexadecimal) in its rightmost two digits.
36 * 194 Temperature Temperature, monitored by a sensor somewhere inside
37 * the drive. Raw value typicaly holds the actual
38 * temperature (hexadecimal) in its rightmost two digits.
40 * 231 Temperature Temperature, monitored by a sensor somewhere inside
41 * the drive. Raw value typicaly holds the actual
42 * temperature (hexadecimal) in its rightmost two digits.
44 * Wikipedia defines attributes a bit differently.
46 * 190 Temperature Value is equal to (100-temp. °C), allowing manufacturer
47 * Difference or to set a minimum threshold which corresponds to a
48 * Airflow maximum temperature. This also follows the convention of
49 * Temperature 100 being a best-case value and lower values being
50 * undesirable. However, some older drives may instead
51 * report raw Temperature (identical to 0xC2) or
52 * Temperature minus 50 here.
53 * 194 Temperature or Indicates the device temperature, if the appropriate
54 * Temperature sensor is fitted. Lowest byte of the raw value contains
55 * Celsius the exact temperature value (Celsius degrees).
56 * 231 Life Left Indicates the approximate SSD life left, in terms of
57 * (SSDs) or program/erase cycles or available reserved blocks.
58 * Temperature A normalized value of 100 represents a new drive, with
59 * a threshold value at 10 indicating a need for
60 * replacement. A value of 0 may mean that the drive is
61 * operating in read-only mode to allow data recovery.
62 * Previously (pre-2010) occasionally used for Drive
63 * Temperature (more typically reported at 0xC2).
65 * Common denominator is that the first raw byte reports the temperature
66 * in degrees C on almost all drives. Some drives may report a fractional
67 * temperature in the second raw byte.
69 * Known exceptions (from libatasmart):
70 * - SAMSUNG SV0412H and SAMSUNG SV1204H) report the temperature in 10th
71 * degrees C in the first two raw bytes.
72 * - A few Maxtor drives report an unknown or bad value in attribute 194.
73 * - Certain Apple SSD drives report an unknown value in attribute 190.
74 * Only certain firmware versions are affected.
76 * Those exceptions affect older ATA drives and are currently ignored.
77 * Also, the second raw byte (possibly reporting the fractional temperature)
78 * is currently ignored.
80 * Many drives also report temperature limits in additional SMART data raw
81 * bytes. The format of those is not well defined and varies widely.
82 * The driver does not currently attempt to report those limits.
84 * According to data in smartmontools, attribute 231 is rarely used to report
85 * drive temperatures. At the same time, several drives report SSD life left
86 * in attribute 231, but do not support temperature sensors. For this reason,
87 * attribute 231 is currently ignored.
89 * Following above definitions, temperatures are reported as follows.
90 * If SCT Command Transport is supported, it is used to read the
91 * temperature and, if available, temperature limits.
92 * - Otherwise, if SMART attribute 194 is supported, it is used to read
94 * - Otherwise, if SMART attribute 190 is supported, it is used to read
98 #include <linux/ata.h>
99 #include <linux/bits.h>
100 #include <linux/device.h>
101 #include <linux/hwmon.h>
102 #include <linux/kernel.h>
103 #include <linux/list.h>
104 #include <linux/module.h>
105 #include <linux/mutex.h>
106 #include <scsi/scsi_cmnd.h>
107 #include <scsi/scsi_device.h>
108 #include <scsi/scsi_driver.h>
109 #include <scsi/scsi_proto.h>
111 struct drivetemp_data
{
112 struct list_head list
; /* list of instantiated devices */
113 struct mutex lock
; /* protect data buffer accesses */
114 struct scsi_device
*sdev
; /* SCSI device */
115 struct device
*dev
; /* instantiating device */
116 struct device
*hwdev
; /* hardware monitoring device */
117 u8 smartdata
[ATA_SECT_SIZE
]; /* local buffer */
118 int (*get_temp
)(struct drivetemp_data
*st
, u32 attr
, long *val
);
119 bool have_temp_lowest
; /* lowest temp in SCT status */
120 bool have_temp_highest
; /* highest temp in SCT status */
121 bool have_temp_min
; /* have min temp */
122 bool have_temp_max
; /* have max temp */
123 bool have_temp_lcrit
; /* have lower critical limit */
124 bool have_temp_crit
; /* have critical limit */
125 int temp_min
; /* min temp */
126 int temp_max
; /* max temp */
127 int temp_lcrit
; /* lower critical limit */
128 int temp_crit
; /* critical limit */
131 static LIST_HEAD(drivetemp_devlist
);
133 #define ATA_MAX_SMART_ATTRS 30
134 #define SMART_TEMP_PROP_190 190
135 #define SMART_TEMP_PROP_194 194
137 #define SCT_STATUS_REQ_ADDR 0xe0
138 #define SCT_STATUS_VERSION_LOW 0 /* log byte offsets */
139 #define SCT_STATUS_VERSION_HIGH 1
140 #define SCT_STATUS_TEMP 200
141 #define SCT_STATUS_TEMP_LOWEST 201
142 #define SCT_STATUS_TEMP_HIGHEST 202
143 #define SCT_READ_LOG_ADDR 0xe1
144 #define SMART_READ_LOG 0xd5
145 #define SMART_WRITE_LOG 0xd6
147 #define INVALID_TEMP 0x80
149 #define temp_is_valid(temp) ((temp) != INVALID_TEMP)
150 #define temp_from_sct(temp) (((s8)(temp)) * 1000)
152 static inline bool ata_id_smart_supported(u16
*id
)
154 return id
[ATA_ID_COMMAND_SET_1
] & BIT(0);
157 static inline bool ata_id_smart_enabled(u16
*id
)
159 return id
[ATA_ID_CFS_ENABLE_1
] & BIT(0);
162 static int drivetemp_scsi_command(struct drivetemp_data
*st
,
163 u8 ata_command
, u8 feature
,
164 u8 lba_low
, u8 lba_mid
, u8 lba_high
)
166 u8 scsi_cmd
[MAX_COMMAND_SIZE
];
169 memset(scsi_cmd
, 0, sizeof(scsi_cmd
));
170 scsi_cmd
[0] = ATA_16
;
171 if (ata_command
== ATA_CMD_SMART
&& feature
== SMART_WRITE_LOG
) {
172 scsi_cmd
[1] = (5 << 1); /* PIO Data-out */
174 * No off.line or cc, write to dev, block count in sector count
178 data_dir
= DMA_TO_DEVICE
;
180 scsi_cmd
[1] = (4 << 1); /* PIO Data-in */
182 * No off.line or cc, read from dev, block count in sector count
186 data_dir
= DMA_FROM_DEVICE
;
188 scsi_cmd
[4] = feature
;
189 scsi_cmd
[6] = 1; /* 1 sector */
190 scsi_cmd
[8] = lba_low
;
191 scsi_cmd
[10] = lba_mid
;
192 scsi_cmd
[12] = lba_high
;
193 scsi_cmd
[14] = ata_command
;
195 return scsi_execute_req(st
->sdev
, scsi_cmd
, data_dir
,
196 st
->smartdata
, ATA_SECT_SIZE
, NULL
, HZ
, 5,
200 static int drivetemp_ata_command(struct drivetemp_data
*st
, u8 feature
,
203 return drivetemp_scsi_command(st
, ATA_CMD_SMART
, feature
, select
,
204 ATA_SMART_LBAM_PASS
, ATA_SMART_LBAH_PASS
);
207 static int drivetemp_get_smarttemp(struct drivetemp_data
*st
, u32 attr
,
210 u8
*buf
= st
->smartdata
;
211 bool have_temp
= false;
217 err
= drivetemp_ata_command(st
, ATA_SMART_READ_VALUES
, 0);
221 /* Checksum the read value table */
223 for (i
= 0; i
< ATA_SECT_SIZE
; i
++)
226 dev_dbg(&st
->sdev
->sdev_gendev
,
227 "checksum error reading SMART values\n");
231 for (i
= 0; i
< ATA_MAX_SMART_ATTRS
; i
++) {
232 u8
*attr
= buf
+ i
* 12;
238 if (id
== SMART_TEMP_PROP_190
) {
242 if (id
== SMART_TEMP_PROP_194
) {
250 *temp
= temp_raw
* 1000;
257 static int drivetemp_get_scttemp(struct drivetemp_data
*st
, u32 attr
, long *val
)
259 u8
*buf
= st
->smartdata
;
262 err
= drivetemp_ata_command(st
, SMART_READ_LOG
, SCT_STATUS_REQ_ADDR
);
266 case hwmon_temp_input
:
267 if (!temp_is_valid(buf
[SCT_STATUS_TEMP
]))
269 *val
= temp_from_sct(buf
[SCT_STATUS_TEMP
]);
271 case hwmon_temp_lowest
:
272 if (!temp_is_valid(buf
[SCT_STATUS_TEMP_LOWEST
]))
274 *val
= temp_from_sct(buf
[SCT_STATUS_TEMP_LOWEST
]);
276 case hwmon_temp_highest
:
277 if (!temp_is_valid(buf
[SCT_STATUS_TEMP_HIGHEST
]))
279 *val
= temp_from_sct(buf
[SCT_STATUS_TEMP_HIGHEST
]);
288 static const char * const sct_avoid_models
[] = {
290 * These drives will have WRITE FPDMA QUEUED command timeouts and sometimes just
291 * freeze until power-cycled under heavy write loads when their temperature is
292 * getting polled in SCT mode. The SMART mode seems to be fine, though.
294 * While only the 3 TB model (DT01ACA3) was actually caught exhibiting the
295 * problem let's play safe here to avoid data corruption and ban the whole
298 * The models from this array are prefix-matched.
303 static bool drivetemp_sct_avoid(struct drivetemp_data
*st
)
305 struct scsi_device
*sdev
= st
->sdev
;
312 * The "model" field contains just the raw SCSI INQUIRY response
313 * "product identification" field, which has a width of 16 bytes.
314 * This field is space-filled, but is NOT NULL-terminated.
316 for (ctr
= 0; ctr
< ARRAY_SIZE(sct_avoid_models
); ctr
++)
317 if (!strncmp(sdev
->model
, sct_avoid_models
[ctr
],
318 strlen(sct_avoid_models
[ctr
])))
324 static int drivetemp_identify_sata(struct drivetemp_data
*st
)
326 struct scsi_device
*sdev
= st
->sdev
;
327 u8
*buf
= st
->smartdata
;
328 struct scsi_vpd
*vpd
;
329 bool is_ata
, is_sata
;
330 bool have_sct_data_table
;
339 /* SCSI-ATA Translation present? */
341 vpd
= rcu_dereference(sdev
->vpd_pg89
);
344 * Verify that ATA IDENTIFY DEVICE data is included in ATA Information
345 * VPD and that the drive implements the SATA protocol.
347 if (!vpd
|| vpd
->len
< 572 || vpd
->data
[56] != ATA_CMD_ID_ATA
||
348 vpd
->data
[36] != 0x34) {
352 ata_id
= (u16
*)&vpd
->data
[60];
353 is_ata
= ata_id_is_ata(ata_id
);
354 is_sata
= ata_id_is_sata(ata_id
);
355 have_sct
= ata_id_sct_supported(ata_id
);
356 have_sct_data_table
= ata_id_sct_data_tables(ata_id
);
357 have_smart
= ata_id_smart_supported(ata_id
) &&
358 ata_id_smart_enabled(ata_id
);
362 /* bail out if this is not a SATA device */
363 if (!is_ata
|| !is_sata
)
366 if (have_sct
&& drivetemp_sct_avoid(st
)) {
367 dev_notice(&sdev
->sdev_gendev
,
368 "will avoid using SCT for temperature monitoring\n");
375 err
= drivetemp_ata_command(st
, SMART_READ_LOG
, SCT_STATUS_REQ_ADDR
);
379 version
= (buf
[SCT_STATUS_VERSION_HIGH
] << 8) |
380 buf
[SCT_STATUS_VERSION_LOW
];
381 if (version
!= 2 && version
!= 3)
384 have_sct_temp
= temp_is_valid(buf
[SCT_STATUS_TEMP
]);
388 st
->have_temp_lowest
= temp_is_valid(buf
[SCT_STATUS_TEMP_LOWEST
]);
389 st
->have_temp_highest
= temp_is_valid(buf
[SCT_STATUS_TEMP_HIGHEST
]);
391 if (!have_sct_data_table
)
394 /* Request and read temperature history table */
395 memset(buf
, '\0', sizeof(st
->smartdata
));
396 buf
[0] = 5; /* data table command */
397 buf
[2] = 1; /* read table */
398 buf
[4] = 2; /* temperature history table */
400 err
= drivetemp_ata_command(st
, SMART_WRITE_LOG
, SCT_STATUS_REQ_ADDR
);
404 err
= drivetemp_ata_command(st
, SMART_READ_LOG
, SCT_READ_LOG_ADDR
);
409 * Temperature limits per AT Attachment 8 -
410 * ATA/ATAPI Command Set (ATA8-ACS)
412 st
->have_temp_max
= temp_is_valid(buf
[6]);
413 st
->have_temp_crit
= temp_is_valid(buf
[7]);
414 st
->have_temp_min
= temp_is_valid(buf
[8]);
415 st
->have_temp_lcrit
= temp_is_valid(buf
[9]);
417 st
->temp_max
= temp_from_sct(buf
[6]);
418 st
->temp_crit
= temp_from_sct(buf
[7]);
419 st
->temp_min
= temp_from_sct(buf
[8]);
420 st
->temp_lcrit
= temp_from_sct(buf
[9]);
424 st
->get_temp
= drivetemp_get_scttemp
;
430 st
->get_temp
= drivetemp_get_smarttemp
;
431 return drivetemp_get_smarttemp(st
, hwmon_temp_input
, &temp
);
434 static int drivetemp_identify(struct drivetemp_data
*st
)
436 struct scsi_device
*sdev
= st
->sdev
;
438 /* Bail out immediately if there is no inquiry data */
439 if (!sdev
->inquiry
|| sdev
->inquiry_len
< 16)
443 if (sdev
->type
!= TYPE_DISK
&& sdev
->type
!= TYPE_ZBC
)
446 return drivetemp_identify_sata(st
);
449 static int drivetemp_read(struct device
*dev
, enum hwmon_sensor_types type
,
450 u32 attr
, int channel
, long *val
)
452 struct drivetemp_data
*st
= dev_get_drvdata(dev
);
455 if (type
!= hwmon_temp
)
459 case hwmon_temp_input
:
460 case hwmon_temp_lowest
:
461 case hwmon_temp_highest
:
462 mutex_lock(&st
->lock
);
463 err
= st
->get_temp(st
, attr
, val
);
464 mutex_unlock(&st
->lock
);
466 case hwmon_temp_lcrit
:
467 *val
= st
->temp_lcrit
;
475 case hwmon_temp_crit
:
476 *val
= st
->temp_crit
;
485 static umode_t
drivetemp_is_visible(const void *data
,
486 enum hwmon_sensor_types type
,
487 u32 attr
, int channel
)
489 const struct drivetemp_data
*st
= data
;
494 case hwmon_temp_input
:
496 case hwmon_temp_lowest
:
497 if (st
->have_temp_lowest
)
500 case hwmon_temp_highest
:
501 if (st
->have_temp_highest
)
505 if (st
->have_temp_min
)
509 if (st
->have_temp_max
)
512 case hwmon_temp_lcrit
:
513 if (st
->have_temp_lcrit
)
516 case hwmon_temp_crit
:
517 if (st
->have_temp_crit
)
530 static const struct hwmon_channel_info
*drivetemp_info
[] = {
531 HWMON_CHANNEL_INFO(chip
,
532 HWMON_C_REGISTER_TZ
),
533 HWMON_CHANNEL_INFO(temp
, HWMON_T_INPUT
|
534 HWMON_T_LOWEST
| HWMON_T_HIGHEST
|
535 HWMON_T_MIN
| HWMON_T_MAX
|
536 HWMON_T_LCRIT
| HWMON_T_CRIT
),
540 static const struct hwmon_ops drivetemp_ops
= {
541 .is_visible
= drivetemp_is_visible
,
542 .read
= drivetemp_read
,
545 static const struct hwmon_chip_info drivetemp_chip_info
= {
546 .ops
= &drivetemp_ops
,
547 .info
= drivetemp_info
,
551 * The device argument points to sdev->sdev_dev. Its parent is
552 * sdev->sdev_gendev, which we can use to get the scsi_device pointer.
554 static int drivetemp_add(struct device
*dev
, struct class_interface
*intf
)
556 struct scsi_device
*sdev
= to_scsi_device(dev
->parent
);
557 struct drivetemp_data
*st
;
560 st
= kzalloc(sizeof(*st
), GFP_KERNEL
);
566 mutex_init(&st
->lock
);
568 if (drivetemp_identify(st
)) {
573 st
->hwdev
= hwmon_device_register_with_info(dev
->parent
, "drivetemp",
574 st
, &drivetemp_chip_info
,
576 if (IS_ERR(st
->hwdev
)) {
577 err
= PTR_ERR(st
->hwdev
);
581 list_add(&st
->list
, &drivetemp_devlist
);
589 static void drivetemp_remove(struct device
*dev
, struct class_interface
*intf
)
591 struct drivetemp_data
*st
, *tmp
;
593 list_for_each_entry_safe(st
, tmp
, &drivetemp_devlist
, list
) {
594 if (st
->dev
== dev
) {
596 hwmon_device_unregister(st
->hwdev
);
603 static struct class_interface drivetemp_interface
= {
604 .add_dev
= drivetemp_add
,
605 .remove_dev
= drivetemp_remove
,
608 static int __init
drivetemp_init(void)
610 return scsi_register_interface(&drivetemp_interface
);
613 static void __exit
drivetemp_exit(void)
615 scsi_unregister_interface(&drivetemp_interface
);
618 module_init(drivetemp_init
);
619 module_exit(drivetemp_exit
);
621 MODULE_AUTHOR("Guenter Roeck <linus@roeck-us.net>");
622 MODULE_DESCRIPTION("Hard drive temperature monitor");
623 MODULE_LICENSE("GPL");