treewide: remove redundant IS_ERR() before error code check
[linux/fpc-iii.git] / Documentation / hwmon / smsc47m1.rst
blobc54eabd5eb57a1db5382441b789c60645a1ea1e8
1 Kernel driver smsc47m1
2 ======================
4 Supported chips:
6   * SMSC LPC47B27x, LPC47M112, LPC47M10x, LPC47M13x, LPC47M14x,
8     LPC47M15x and LPC47M192
10     Addresses scanned: none, address read from Super I/O config space
12     Prefix: 'smsc47m1'
14     Datasheets:
16         http://www.smsc.com/media/Downloads_Public/Data_Sheets/47b272.pdf
18         http://www.smsc.com/media/Downloads_Public/Data_Sheets/47m10x.pdf
20         http://www.smsc.com/media/Downloads_Public/Data_Sheets/47m112.pdf
22         http://www.smsc.com/
24   * SMSC LPC47M292
26     Addresses scanned: none, address read from Super I/O config space
28     Prefix: 'smsc47m2'
30     Datasheet: Not public
32   * SMSC LPC47M997
34     Addresses scanned: none, address read from Super I/O config space
36     Prefix: 'smsc47m1'
38     Datasheet: none
42 Authors:
44      - Mark D. Studebaker <mdsxyz123@yahoo.com>,
45      - With assistance from Bruce Allen <ballen@uwm.edu>, and his
46        fan.c program:
48        - http://www.lsc-group.phys.uwm.edu/%7Eballen/driver/
50      - Gabriele Gorla <gorlik@yahoo.com>,
51      - Jean Delvare <jdelvare@suse.de>
53 Description
54 -----------
56 The Standard Microsystems Corporation (SMSC) 47M1xx Super I/O chips
57 contain monitoring and PWM control circuitry for two fans.
59 The LPC47M15x, LPC47M192 and LPC47M292 chips contain a full 'hardware
60 monitoring block' in addition to the fan monitoring and control. The
61 hardware monitoring block is not supported by this driver, use the
62 smsc47m192 driver for that.
64 No documentation is available for the 47M997, but it has the same device
65 ID as the 47M15x and 47M192 chips and seems to be compatible.
67 Fan rotation speeds are reported in RPM (rotations per minute). An alarm is
68 triggered if the rotation speed has dropped below a programmable limit. Fan
69 readings can be divided by a programmable divider (1, 2, 4 or 8) to give
70 the readings more range or accuracy. Not all RPM values can accurately be
71 represented, so some rounding is done. With a divider of 2, the lowest
72 representable value is around 2600 RPM.
74 PWM values are from 0 to 255.
76 If an alarm triggers, it will remain triggered until the hardware register
77 is read at least once. This means that the cause for the alarm may
78 already have disappeared! Note that in the current implementation, all
79 hardware registers are read whenever any data is read (unless it is less
80 than 1.5 seconds since the last update). This means that you can easily
81 miss once-only alarms.
83 ------------------------------------------------------------------
85 The lm_sensors project gratefully acknowledges the support of
86 Intel in the development of this driver.