2023-01-22 21:36:46 +00:00
.. SPDX-License-Identifier: GPL-2.0
2023-01-22 18:48:34 +00:00
===================
Hardware Monitoring
===================
2019-04-17 06:46:29 -03:00
.. toctree ::
:maxdepth: 1
2019-04-22 08:14:55 -03:00
hwmon-kernel-api
pmbus-core
submitting-patches
sysfs-interface
userspace-tools
2019-04-17 06:46:29 -03:00
Hardware Monitoring Kernel Drivers
==================================
.. toctree ::
:maxdepth: 1
2019-04-22 08:14:55 -03:00
abituguru
abituguru3
2023-04-13 08:26:26 -05:00
acbel-fsg032
2019-04-22 08:14:55 -03:00
acpi_power_meter
ad7314
adc128d818
adm1021
adm1025
adm1026
adm1031
2020-01-14 13:21:57 +02:00
adm1177
2020-08-12 17:20:50 +03:00
adm1266
2019-04-22 08:14:55 -03:00
adm1275
adm9240
2024-03-21 16:21:43 +02:00
adp1050
2019-04-22 08:14:55 -03:00
ads7828
adt7410
adt7411
adt7462
adt7470
adt7475
2021-01-07 20:40:14 +01:00
aht10
2019-04-22 08:14:55 -03:00
amc6821
hwmon: add driver for Aquacomputer D5 Next
This driver exposes hardware sensors of the Aquacomputer D5 Next
watercooling pump, which communicates through a proprietary USB HID
protocol.
Available sensors are pump and fan speed, power, voltage and current, as
well as coolant temperature. Also available through debugfs are the serial
number, firmware version and power-on count.
Attaching a fan is optional and allows it to be controlled using
temperature curves directly from the pump. If it's not connected,
the fan-related sensors will report zeroes.
The pump can be configured either through software or via its physical
interface. Configuring the pump through this driver is not implemented,
as it seems to require sending it a complete configuration. That
includes addressable RGB LEDs, for which there is no standard sysfs
interface. Thus, that task is better suited for userspace tools.
This driver has been tested on x86_64, both in-kernel and as a module.
Signed-off-by: Aleksa Savic <savicaleksa83@gmail.com>
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
2021-08-28 07:26:28 +02:00
aquacomputer_d5next
2019-04-22 08:14:55 -03:00
asb100
asc7621
2024-02-21 18:40:25 +08:00
aspeed-g6-pwm-tach
2019-04-22 08:14:55 -03:00
aspeed-pwm-tacho
2022-01-24 02:56:44 +01:00
asus_ec_sensors
2024-01-08 10:44:50 +01:00
asus_rog_ryujin
hwmon: (asus_wmi_sensors) Support X370 Asus WMI.
Provides a Linux kernel module "asus_wmi_sensors" that provides sensor
readouts via ASUS' WMI interface present in the UEFI of
X370/X470/B450/X399 Ryzen motherboards.
Supported motherboards:
* ROG CROSSHAIR VI HERO,
* PRIME X399-A,
* PRIME X470-PRO,
* ROG CROSSHAIR VI EXTREME,
* ROG CROSSHAIR VI HERO (WI-FI AC),
* ROG CROSSHAIR VII HERO,
* ROG CROSSHAIR VII HERO (WI-FI),
* ROG STRIX B450-E GAMING,
* ROG STRIX B450-F GAMING,
* ROG STRIX B450-I GAMING,
* ROG STRIX X399-E GAMING,
* ROG STRIX X470-F GAMING,
* ROG STRIX X470-I GAMING,
* ROG ZENITH EXTREME,
* ROG ZENITH EXTREME ALPHA.
Co-developed-by: Ed Brindley <kernel@maidavale.org>
Signed-off-by: Ed Brindley <kernel@maidavale.org>
Signed-off-by: Denis Pauk <pauk.denis@gmail.com>
[groeck: Squashed:
"hwmon: Fix warnings in asus_wmi_sensors.rst documetation."]
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
2021-11-16 22:57:44 +02:00
asus_wmi_sensors
2020-04-20 20:21:13 +02:00
bcm54140
2019-10-29 11:20:54 -07:00
bel-pfe
2021-03-17 17:02:31 +13:00
bpa-rs600
hwmon: Add Baikal-T1 PVT sensor driver
Baikal-T1 SoC provides an embedded process, voltage and temperature
sensor to monitor an internal SoC environment (chip temperature, supply
voltage and process monitor) and on time detect critical situations,
which may cause the system instability and even damages. The IP-block
is based on the Analog Bits PVT sensor, but is equipped with a
dedicated control wrapper, which provides a MMIO registers-based access
to the sensor core functionality (APB3-bus based) and exposes an
additional functions like thresholds/data ready interrupts, its status
and masks, measurements timeout. All of these is used to create a hwmon
driver being added to the kernel by this commit.
The driver implements support for the hardware monitoring capabilities
of Baikal-T1 process, voltage and temperature sensors. PVT IP-core
consists of one temperature and four voltage sensors, each of which is
implemented as a dedicated hwmon channel config.
The driver can optionally provide the hwmon alarms for each sensor the
PVT controller supports. The alarms functionality is made compile-time
configurable due to the hardware interface implementation peculiarity,
which is connected with an ability to convert data from only one sensor
at a time. Additional limitation is that the controller performs the
thresholds checking synchronously with the data conversion procedure.
Due to these limitations in order to have the hwmon alarms
automatically detected the driver code must switch from one sensor to
another, read converted data and manually check the threshold status
bits. Depending on the measurements timeout settings this design may
cause additional burden on the system performance. By default if the
alarms kernel config is disabled the data conversion is performed by
the driver on demand when read operation is requested via corresponding
_input-file.
Co-developed-by: Maxim Kaurkin <maxim.kaurkin@baikalelectronics.ru>
Signed-off-by: Maxim Kaurkin <maxim.kaurkin@baikalelectronics.ru>
Signed-off-by: Serge Semin <Sergey.Semin@baikalelectronics.ru>
Cc: Alexey Malahov <Alexey.Malahov@baikalelectronics.ru>
Cc: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
Cc: Arnd Bergmann <arnd@arndb.de>
Cc: Rob Herring <robh+dt@kernel.org>
Cc: linux-mips@vger.kernel.org
Cc: devicetree@vger.kernel.org
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
2020-05-28 17:28:05 +03:00
bt1-pvt
hwmon: Add support for Amphenol ChipCap 2
The Amphenol ChipCap 2 is a capacitive polymer humidity and temperature
sensor with an integrated EEPROM and minimum/maximum humidity alarms.
All device variants offer an I2C interface and depending on the part
number, two different output modes:
- CC2D: digital output
- CC2A: analog (PDM) output
This driver adds support for the digital variant (CC2D part numbers),
which includes the following part numbers:
- non-sleep measurement mode (CC2D23, CC2D25, CC2D33, CC2D35)
- sleep measurement mode (CC2D23S, CC2D25S, CC2D33S, CC2D35S)
The Chipcap 2 EEPROM can be accessed to configure a series of parameters
like the minimum/maximum humidity alarm threshold and hysteresis. The
EEPROM is only accessible in the command window after a power-on reset.
The default window lasts 10 ms if no Start_CM command is sent. After the
command window is finished (either after the mentioned timeout of after
a Start_NOM command is sent), the device enters the normal operation
mode and makes a first measurement automatically.
Unfortunately, the device does not provide any hardware or software
reset and therefore the driver must trigger power cycles to enter the
command mode. A dedicated, external regulator is required for that.
This driver keeps the device off until a measurement or access to the
EEPROM is required, making use of the first automatic measurement to
avoid different code paths for sleep and non-sleep devices.
The minimum and maximum humidity alarms are configured with two
registers per alarm: one stores the alarm threshold and the other one
keeps the value that turns off the alarm. The alarm signals are only
updated when a measurement is carried out.
Signed-off-by: Javier Carrasco <javier.carrasco.cruz@gmail.com>
Link: https://lore.kernel.org/r/20240130-topic-chipcap2-v6-5-260bea05cf9b@gmail.com
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
2024-01-30 22:06:48 +01:00
chipcap2
2019-04-22 08:14:55 -03:00
coretemp
2020-06-26 07:59:36 +02:00
corsair-cpro
2020-10-27 14:17:10 +01:00
corsair-psu
2019-04-22 08:14:55 -03:00
da9052
da9055
2019-11-22 11:15:19 +01:00
dell-smm-hwmon
2019-04-22 08:14:55 -03:00
dme1737
2021-06-07 12:34:29 +02:00
dps920ab
hwmon: Driver for disk and solid state drives with temperature sensors
Reading the temperature of ATA drives has been supported for years
by userspace tools such as smarttools or hddtemp. The downside of
such tools is that they need to run with super-user privilege, that
the temperatures are not reported by standard tools such as 'sensors'
or 'libsensors', and that drive temperatures are not available for use
in the kernel's thermal subsystem.
This driver solves this problem by adding support for reading the
temperature of ATA drives from the kernel using the hwmon API and
by adding a temperature zone for each drive.
With this driver, the hard disk temperature can be read using the
unprivileged 'sensors' application:
$ sensors drivetemp-scsi-1-0
drivetemp-scsi-1-0
Adapter: SCSI adapter
temp1: +23.0°C
or directly from sysfs:
$ grep . /sys/class/hwmon/hwmon9/{name,temp1_input}
/sys/class/hwmon/hwmon9/name:drivetemp
/sys/class/hwmon/hwmon9/temp1_input:23000
If the drive supports SCT transport and reports temperature limits,
those are reported as well.
drivetemp-scsi-0-0
Adapter: SCSI adapter
temp1: +27.0°C (low = +0.0°C, high = +60.0°C)
(crit low = -41.0°C, crit = +85.0°C)
(lowest = +23.0°C, highest = +34.0°C)
The driver attempts to use SCT Command Transport to read the drive
temperature. If the SCT Command Transport feature set is not available,
or if it does not report the drive temperature, drive temperatures may
be readable through SMART attributes. Since SMART attributes are not well
defined, this method is only used as fallback mechanism.
Cc: Chris Healy <cphealy@gmail.com>
Cc: Linus Walleij <linus.walleij@linaro.org>
Cc: Martin K. Petersen <martin.petersen@oracle.com>
Cc: Bart Van Assche <bvanassche@acm.org>
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Tested-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
2019-11-28 21:34:40 -08:00
drivetemp
2019-04-22 08:14:55 -03:00
ds1621
ds620
emc1403
emc2103
2022-08-10 20:15:52 +03:00
emc2305
2019-04-22 08:14:55 -03:00
emc6w201
f71805f
f71882fg
fam15h_power
hwmon: Add driver for fsp-3y PSUs and PDUs
This patch adds support for these devices:
- YH-5151E - the PDU
- YM-2151E - the PSU
The device datasheet says that the devices support PMBus 1.2, but in my
testing, a lot of the commands aren't supported and if they are, they
sometimes behave strangely or inconsistently. For example, writes to the
PAGE command requires using PEC, otherwise the write won't work and the
page won't switch, even though, the standard says that PEC is optional.
On the other hand, writes to SMBALERT don't require PEC. Because of
this, the driver is mostly reverse engineered with the help of a tool
called pmbus_peek written by David Brownell (and later adopted by my
colleague Jan Kundrát).
The device also has some sort of a timing issue when switching pages,
which is explained further in the code.
Because of this, the driver support is limited. It exposes only the
values that have been tested to work correctly.
Signed-off-by: Václav Kubernát <kubernat@cesnet.cz>
Link: https://lore.kernel.org/r/20210414080019.3530794-1-kubernat@cesnet.cz
[groeck: Fixed up "missing braces around initializer" from 0-day]
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
2021-04-14 10:00:17 +02:00
fsp-3y
2019-04-22 08:14:55 -03:00
ftsteutates
g760a
g762
2023-12-07 13:23:59 +01:00
gigabyte_waterforce
2020-05-15 10:57:08 -07:00
gsc-hwmon
2019-04-22 08:14:55 -03:00
gl518sm
2023-01-03 14:36:50 -06:00
gxp-fan-ctrl
2019-04-22 08:14:55 -03:00
hih6130
2023-05-22 04:56:46 -07:00
hp-wmi-sensors
2023-07-25 06:22:07 +02:00
hs3001
2019-04-22 08:14:55 -03:00
ibmaem
ibm-cffps
ibmpowernv
ina209
ina2xx
2021-11-02 05:27:54 +00:00
ina238
2019-04-22 08:14:55 -03:00
ina3221
2023-05-04 00:57:42 -07:00
inspur-ipsps1
2020-09-21 14:17:51 +08:00
intel-m10-bmc-hwmon
2019-04-22 08:14:55 -03:00
ir35221
ir38064
2021-03-01 16:59:54 +13:00
ir36021
2019-04-22 08:14:55 -03:00
isl68137
it87
jc42
k10temp
k8temp
2022-04-01 23:40:32 +02:00
lan966x
2019-04-22 08:14:55 -03:00
lineage-pem
lm25066
lm63
lm70
lm73
lm75
lm77
lm78
lm80
lm83
lm85
lm87
lm90
lm92
lm93
lm95234
lm95245
lochnagar
2022-05-18 00:35:34 -07:00
lt7182s
2020-12-03 09:11:53 +02:00
ltc2992
2019-04-22 08:14:55 -03:00
ltc2945
2019-10-21 17:41:14 +02:00
ltc2947
2019-04-22 08:14:55 -03:00
ltc2978
ltc2990
2023-10-26 13:33:13 +03:00
ltc2991
2019-04-22 08:14:55 -03:00
ltc3815
ltc4151
ltc4215
ltc4245
ltc4260
ltc4261
2024-01-29 17:13:25 +01:00
ltc4282
2023-11-23 09:54:37 +08:00
ltc4286
2020-11-23 10:56:58 -08:00
max127
2021-04-19 12:12:51 +02:00
max15301
2019-04-22 08:14:55 -03:00
max16064
max16065
max1619
2019-12-14 06:37:31 -08:00
max16601
2019-04-22 08:14:55 -03:00
max1668
max197
2019-12-05 20:26:24 -08:00
max20730
2019-04-22 08:14:55 -03:00
max20751
max31722
2019-11-23 11:11:26 -08:00
max31730
2022-09-10 20:19:43 +03:00
max31760
2019-04-22 08:14:55 -03:00
max31785
max31790
2023-05-24 19:01:30 +03:00
max31827
2019-04-22 08:14:55 -03:00
max34440
2021-09-13 13:40:15 +00:00
max6620
2019-04-22 08:14:55 -03:00
max6639
max6642
max6650
max6697
max8688
mc13783-adc
2023-01-18 13:30:18 +01:00
mc34vr500
2019-04-22 08:14:55 -03:00
mcp3021
menf21bmc
mlxreg-fan
2023-12-12 00:05:19 +08:00
mp2856
2021-05-21 14:22:18 -03:00
mp2888
2020-10-27 10:51:11 +01:00
mp2975
2021-12-09 04:48:54 +00:00
mp5023
2023-11-13 23:50:08 +08:00
mp5990
2024-01-31 15:48:22 +08:00
mpq8785
2019-04-22 08:14:55 -03:00
nct6683
nct6775
nct7802
nct7904
npcm750-pwm-fan
nsa320
ntc_thermistor
hwmon: add driver for NZXT Kraken X42/X52/X62/X72
These are "all-in-one" CPU liquid coolers that can be monitored and
controlled through a proprietary USB HID protocol.
While the models have differently sized radiators and come with varying
numbers of fans, they are all indistinguishable at the software level.
The driver exposes fan/pump speeds and coolant temperature through the
standard hwmon sysfs interface.
Fan and pump control, while supported by the devices, are not currently
exposed. The firmware accepts up to 61 trip points per channel
(fan/pump), but the same set of trip temperatures has to be maintained
for both; with pwmX_auto_point_Y_temp attributes, users would need to
maintain this invariant themselves.
Instead, fan and pump control, as well as LED control (which the device
also supports for 9 addressable RGB LEDs on the CPU water block) are
left for existing and already mature user-space tools, which can still
be used alongside the driver, thanks to hidraw. A link to one, which I
also maintain, is provided in the documentation.
The implementation is based on USB traffic analysis. It has been
runtime tested on x86_64, both as a built-in driver and as a module.
Signed-off-by: Jonas Malaco <jonas@protocubo.io>
Link: https://lore.kernel.org/r/20210319045544.416138-1-jonas@protocubo.io
[groeck: Removed unnecessary spinlock.h include]
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
2021-03-19 01:55:44 -03:00
nzxt-kraken2
2024-01-29 12:19:28 +01:00
nzxt-kraken3
2021-10-31 09:30:58 +06:00
nzxt-smart2
2019-04-22 08:14:55 -03:00
occ
2022-11-04 11:07:00 -03:00
oxp-sensors
2019-04-22 08:14:55 -03:00
pc87360
pc87427
pcf8591
2021-06-09 11:32:09 +02:00
pim4328
2022-02-21 10:42:06 +01:00
pli1209bc
2020-12-02 14:11:04 +08:00
pm6764tr
2022-02-08 16:36:38 +01:00
peci-cputemp
peci-dimmtemp
2019-04-22 08:14:55 -03:00
pmbus
2023-09-02 09:47:01 +02:00
powerz
2019-04-22 08:14:55 -03:00
powr1220
2024-02-06 20:54:20 +08:00
pt5161l
2019-07-22 08:07:45 -03:00
pxe1610
2019-04-22 08:14:55 -03:00
pwm-fan
2020-12-01 16:59:00 -10:00
q54sj108a2
2019-04-22 08:14:55 -03:00
raspberrypi-hwmon
2021-07-26 19:06:14 +05:30
sbrmi
2020-12-11 13:54:26 -08:00
sbtsi_temp
2019-04-22 08:14:55 -03:00
sch5627
sch5636
scpi-hwmon
2023-03-21 10:26:44 +08:00
sfctemp
2019-04-22 08:14:55 -03:00
sht15
sht21
sht3x
2021-05-24 19:50:38 +05:30
sht4x
2019-04-22 08:14:55 -03:00
shtc1
sis5595
2020-09-14 23:43:36 +02:00
sl28cpld
2022-09-29 16:43:14 +07:00
smpro-hwmon
2019-04-22 08:14:55 -03:00
smsc47b397
smsc47m192
smsc47m1
2020-09-09 16:10:45 +02:00
sparx5-temp
2021-02-18 12:52:49 +01:00
stpddc60
2024-01-30 19:58:55 -05:00
surface_fan
2022-01-24 22:10:06 +10:00
sy7636a-hwmon
2019-04-22 08:14:55 -03:00
tc654
tc74
thmc50
tmp102
tmp103
tmp108
tmp401
tmp421
2022-02-22 14:36:10 -08:00
tmp464
2019-11-12 17:30:01 -05:00
tmp513
2021-01-21 14:44:33 +01:00
tps23861
2019-04-22 08:14:55 -03:00
tps40422
2020-02-01 08:24:47 -08:00
tps53679
2022-09-12 11:01:08 +08:00
tps546d24
2019-04-22 08:14:55 -03:00
twl4030-madc-hwmon
ucd9000
ucd9200
vexpress
via686a
vt1211
w83627ehf
w83627hf
w83773g
w83781d
w83791d
w83792d
w83793
w83795
w83l785ts
w83l786ng
wm831x
wm8350
xgene-hwmon
2024-04-25 23:36:01 +08:00
xdp710
2020-01-13 15:08:41 +00:00
xdpe12284
2022-04-27 18:40:12 +00:00
xdpe152c4
2019-04-22 08:14:55 -03:00
zl6100
2019-04-17 06:46:29 -03:00
.. only :: subproject and html
Indices
=======
* :ref: `genindex`