gpio: rcar: Fix runtime PM imbalance on error
[linux/fpc-iii.git] / Documentation / hwmon / emc1403.rst
blob3a4913b63ef365caf3d9b322d8b4ef764a664f94
1 Kernel driver emc1403
2 =====================
4 Supported chips:
6   * SMSC / Microchip EMC1402, EMC1412
8     Addresses scanned: I2C 0x18, 0x1c, 0x29, 0x4c, 0x4d, 0x5c
10     Prefix: 'emc1402'
12     Datasheets:
14         - http://ww1.microchip.com/downloads/en/DeviceDoc/1412.pdf
15         - http://ww1.microchip.com/downloads/en/DeviceDoc/1402.pdf
17   * SMSC / Microchip EMC1403, EMC1404, EMC1413, EMC1414
19     Addresses scanned: I2C 0x18, 0x29, 0x4c, 0x4d
21     Prefix: 'emc1403', 'emc1404'
23     Datasheets:
25         - http://ww1.microchip.com/downloads/en/DeviceDoc/1403_1404.pdf
26         - http://ww1.microchip.com/downloads/en/DeviceDoc/1413_1414.pdf
28   * SMSC / Microchip EMC1422
30     Addresses scanned: I2C 0x4c
32     Prefix: 'emc1422'
34     Datasheet:
36         - http://ww1.microchip.com/downloads/en/DeviceDoc/1422.pdf
38   * SMSC / Microchip EMC1423, EMC1424
40     Addresses scanned: I2C 0x4c
42     Prefix: 'emc1423', 'emc1424'
44     Datasheet:
46         - http://ww1.microchip.com/downloads/en/DeviceDoc/1423_1424.pdf
48 Author:
49     Kalhan Trisal <kalhan.trisal@intel.com
52 Description
53 -----------
55 The Standard Microsystems Corporation (SMSC) / Microchip EMC14xx chips
56 contain up to four temperature sensors. EMC14x2 support two sensors
57 (one internal, one external). EMC14x3 support three sensors (one internal,
58 two external), and EMC14x4 support four sensors (one internal, three
59 external).
61 The chips implement three limits for each sensor: low (tempX_min), high
62 (tempX_max) and critical (tempX_crit.) The chips also implement an
63 hysteresis mechanism which applies to all limits. The relative difference
64 is stored in a single register on the chip, which means that the relative
65 difference between the limit and its hysteresis is always the same for
66 all three limits.
68 This implementation detail implies the following:
70 * When setting a limit, its hysteresis will automatically follow, the
71   difference staying unchanged. For example, if the old critical limit
72   was 80 degrees C, and the hysteresis was 75 degrees C, and you change
73   the critical limit to 90 degrees C, then the hysteresis will
74   automatically change to 85 degrees C.
75 * The hysteresis values can't be set independently. We decided to make
76   only temp1_crit_hyst writable, while all other hysteresis attributes
77   are read-only. Setting temp1_crit_hyst writes the difference between
78   temp1_crit_hyst and temp1_crit into the chip, and the same relative
79   hysteresis applies automatically to all other limits.
80 * The limits should be set before the hysteresis.