Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 1 | Kernel driver w83627ehf |
| 2 | ======================= |
| 3 | |
| 4 | Supported chips: |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 5 | |
Gong Jun | 237c8d2f | 2009-03-30 21:46:42 +0200 | [diff] [blame] | 6 | * Winbond W83627EHF/EHG (ISA access ONLY) |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 7 | |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 8 | Prefix: 'w83627ehf' |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 9 | |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 10 | Addresses scanned: ISA address retrieved from Super I/O registers |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 11 | |
Guenter Roeck | 96d1eac | 2011-02-11 08:10:53 -0800 | [diff] [blame] | 12 | Datasheet: not available |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 13 | |
Gong Jun | 237c8d2f | 2009-03-30 21:46:42 +0200 | [diff] [blame] | 14 | * Winbond W83627DHG |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 15 | |
Gong Jun | 237c8d2f | 2009-03-30 21:46:42 +0200 | [diff] [blame] | 16 | Prefix: 'w83627dhg' |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 17 | |
Gong Jun | 237c8d2f | 2009-03-30 21:46:42 +0200 | [diff] [blame] | 18 | Addresses scanned: ISA address retrieved from Super I/O registers |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 19 | |
Guenter Roeck | 96d1eac | 2011-02-11 08:10:53 -0800 | [diff] [blame] | 20 | Datasheet: not available |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 21 | |
Jean Delvare | c1e48dc | 2009-06-15 18:39:50 +0200 | [diff] [blame] | 22 | * Winbond W83627DHG-P |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 23 | |
Jean Delvare | c1e48dc | 2009-06-15 18:39:50 +0200 | [diff] [blame] | 24 | Prefix: 'w83627dhg' |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 25 | |
Jean Delvare | c1e48dc | 2009-06-15 18:39:50 +0200 | [diff] [blame] | 26 | Addresses scanned: ISA address retrieved from Super I/O registers |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 27 | |
Jean Delvare | c1e48dc | 2009-06-15 18:39:50 +0200 | [diff] [blame] | 28 | Datasheet: not available |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 29 | |
Jean Delvare | eff7687 | 2011-11-04 12:00:48 +0100 | [diff] [blame] | 30 | * Winbond W83627UHG |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 31 | |
Jean Delvare | eff7687 | 2011-11-04 12:00:48 +0100 | [diff] [blame] | 32 | Prefix: 'w83627uhg' |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 33 | |
Jean Delvare | eff7687 | 2011-11-04 12:00:48 +0100 | [diff] [blame] | 34 | Addresses scanned: ISA address retrieved from Super I/O registers |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 35 | |
Jean Delvare | eff7687 | 2011-11-04 12:00:48 +0100 | [diff] [blame] | 36 | Datasheet: available from www.nuvoton.com |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 37 | |
Gong Jun | 237c8d2f | 2009-03-30 21:46:42 +0200 | [diff] [blame] | 38 | * Winbond W83667HG |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 39 | |
Gong Jun | 237c8d2f | 2009-03-30 21:46:42 +0200 | [diff] [blame] | 40 | Prefix: 'w83667hg' |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 41 | |
Gong Jun | 237c8d2f | 2009-03-30 21:46:42 +0200 | [diff] [blame] | 42 | Addresses scanned: ISA address retrieved from Super I/O registers |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 43 | |
Gong Jun | 237c8d2f | 2009-03-30 21:46:42 +0200 | [diff] [blame] | 44 | Datasheet: not available |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 45 | |
Guenter Roeck | c39aeda | 2010-08-14 21:08:55 +0200 | [diff] [blame] | 46 | * Winbond W83667HG-B |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 47 | |
Guenter Roeck | c39aeda | 2010-08-14 21:08:55 +0200 | [diff] [blame] | 48 | Prefix: 'w83667hg' |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 49 | |
Guenter Roeck | c39aeda | 2010-08-14 21:08:55 +0200 | [diff] [blame] | 50 | Addresses scanned: ISA address retrieved from Super I/O registers |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 51 | |
Guenter Roeck | ec3e5a16 | 2011-02-02 08:46:49 -0800 | [diff] [blame] | 52 | Datasheet: Available from Nuvoton upon request |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 53 | |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 54 | * Nuvoton NCT6775F/W83667HG-I |
| 55 | |
| 56 | Prefix: 'nct6775' |
| 57 | |
| 58 | Addresses scanned: ISA address retrieved from Super I/O registers |
| 59 | |
| 60 | Datasheet: Available from Nuvoton upon request |
| 61 | |
| 62 | * Nuvoton NCT6776F |
| 63 | |
| 64 | Prefix: 'nct6776' |
| 65 | |
| 66 | Addresses scanned: ISA address retrieved from Super I/O registers |
| 67 | |
| 68 | Datasheet: Available from Nuvoton upon request |
| 69 | |
| 70 | |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 71 | Authors: |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 72 | |
| 73 | - Jean Delvare <jdelvare@suse.de> |
| 74 | - Yuan Mu (Winbond) |
| 75 | - Rudolf Marek <r.marek@assembler.cz> |
| 76 | - David Hubbard <david.c.hubbard@gmail.com> |
| 77 | - Gong Jun <JGong@nuvoton.com> |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 78 | |
| 79 | Description |
| 80 | ----------- |
| 81 | |
Gong Jun | 237c8d2f | 2009-03-30 21:46:42 +0200 | [diff] [blame] | 82 | This driver implements support for the Winbond W83627EHF, W83627EHG, |
Jean Delvare | eff7687 | 2011-11-04 12:00:48 +0100 | [diff] [blame] | 83 | W83627DHG, W83627DHG-P, W83627UHG, W83667HG, W83667HG-B, W83667HG-I |
| 84 | (NCT6775F), and NCT6776F super I/O chips. We will refer to them collectively |
| 85 | as Winbond chips. |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 86 | |
Jean Delvare | aacb6b0 | 2012-03-13 04:03:27 -0400 | [diff] [blame] | 87 | The chips implement 3 to 4 temperature sensors (9 for NCT6775F and NCT6776F), |
Jean Delvare | eff7687 | 2011-11-04 12:00:48 +0100 | [diff] [blame] | 88 | 2 to 5 fan rotation speed sensors, 8 to 10 analog voltage sensors, one VID |
| 89 | (except for 627UHG), alarms with beep warnings (control unimplemented), |
Guenter Roeck | ec3e5a16 | 2011-02-02 08:46:49 -0800 | [diff] [blame] | 90 | and some automatic fan regulation strategies (plus manual fan control mode). |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 91 | |
Guenter Roeck | ec3e5a16 | 2011-02-02 08:46:49 -0800 | [diff] [blame] | 92 | The temperature sensor sources on W82677HG-B, NCT6775F, and NCT6776F are |
| 93 | configurable. temp4 and higher attributes are only reported if its temperature |
| 94 | source differs from the temperature sources of the already reported temperature |
| 95 | sensors. The configured source for each of the temperature sensors is provided |
| 96 | in tempX_label. |
Guenter Roeck | d36cf32 | 2011-02-07 15:08:54 -0800 | [diff] [blame] | 97 | |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 98 | Temperatures are measured in degrees Celsius and measurement resolution is 1 |
Guenter Roeck | ec3e5a16 | 2011-02-02 08:46:49 -0800 | [diff] [blame] | 99 | degC for temp1 and and 0.5 degC for temp2 and temp3. For temp4 and higher, |
| 100 | resolution is 1 degC for W83667HG-B and 0.0 degC for NCT6775F and NCT6776F. |
| 101 | An alarm is triggered when the temperature gets higher than high limit; |
| 102 | it stays on until the temperature falls below the hysteresis value. |
| 103 | Alarms are only supported for temp1, temp2, and temp3. |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 104 | |
| 105 | Fan rotation speeds are reported in RPM (rotations per minute). An alarm is |
| 106 | triggered if the rotation speed has dropped below a programmable limit. Fan |
| 107 | readings can be divided by a programmable divider (1, 2, 4, 8, 16, 32, 64 or |
| 108 | 128) to give the readings more range or accuracy. The driver sets the most |
| 109 | suitable fan divisor itself. Some fans might not be present because they |
| 110 | share pins with other functions. |
| 111 | |
| 112 | Voltage sensors (also known as IN sensors) report their values in millivolts. |
| 113 | An alarm is triggered if the voltage has crossed a programmable minimum |
| 114 | or maximum limit. |
| 115 | |
| 116 | The driver supports automatic fan control mode known as Thermal Cruise. |
| 117 | In this mode, the chip attempts to keep the measured temperature in a |
| 118 | predefined temperature range. If the temperature goes out of range, fan |
| 119 | is driven slower/faster to reach the predefined range again. |
| 120 | |
| 121 | The mode works for fan1-fan4. Mapping of temperatures to pwm outputs is as |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 122 | follows:: |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 123 | |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 124 | temp1 -> pwm1 |
| 125 | temp2 -> pwm2 |
| 126 | temp3 -> pwm3 (not on 627UHG) |
| 127 | prog -> pwm4 (not on 667HG and 667HG-B; the programmable setting is not |
| 128 | supported by the driver) |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 129 | |
| 130 | /sys files |
| 131 | ---------- |
| 132 | |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 133 | name |
| 134 | this is a standard hwmon device entry, it contains the name of |
| 135 | the device (see the prefix in the list of supported devices at |
| 136 | the top of this file) |
David Hubbard | 657c93b | 2007-02-14 21:15:04 +0100 | [diff] [blame] | 137 | |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 138 | pwm[1-4] |
| 139 | this file stores PWM duty cycle or DC value (fan speed) in range: |
| 140 | |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 141 | 0 (stop) to 255 (full) |
| 142 | |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 143 | pwm[1-4]_enable |
| 144 | this file controls mode of fan/temperature control: |
| 145 | |
Daniel J Blueman | 41e9a06 | 2009-12-14 18:01:37 -0800 | [diff] [blame] | 146 | * 1 Manual mode, write to pwm file any value 0-255 (full speed) |
| 147 | * 2 "Thermal Cruise" mode |
| 148 | * 3 "Fan Speed Cruise" mode |
| 149 | * 4 "Smart Fan III" mode |
Guenter Roeck | ec3e5a16 | 2011-02-02 08:46:49 -0800 | [diff] [blame] | 150 | * 5 "Smart Fan IV" mode |
| 151 | |
| 152 | SmartFan III mode is not supported on NCT6776F. |
| 153 | |
| 154 | SmartFan IV mode is configurable only if it was configured at system |
| 155 | startup, and is only supported for W83677HG-B, NCT6775F, and NCT6776F. |
| 156 | SmartFan IV operational parameters can not be configured at this time, |
| 157 | and the various pwm attributes are not used in SmartFan IV mode. |
| 158 | The attributes can be written to, which is useful if you plan to |
| 159 | configure the system for a different pwm mode. However, the information |
| 160 | returned when reading pwm attributes is unrelated to SmartFan IV |
| 161 | operation. |
Daniel J Blueman | 41e9a06 | 2009-12-14 18:01:37 -0800 | [diff] [blame] | 162 | |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 163 | pwm[1-4]_mode |
| 164 | controls if output is PWM or DC level |
| 165 | |
| 166 | * 0 DC output (0 - 12v) |
| 167 | * 1 PWM output |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 168 | |
| 169 | Thermal Cruise mode |
| 170 | ------------------- |
| 171 | |
| 172 | If the temperature is in the range defined by: |
| 173 | |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 174 | pwm[1-4]_target |
| 175 | set target temperature, unit millidegree Celsius |
| 176 | (range 0 - 127000) |
| 177 | pwm[1-4]_tolerance |
| 178 | tolerance, unit millidegree Celsius (range 0 - 15000) |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 179 | |
| 180 | there are no changes to fan speed. Once the temperature leaves the interval, |
| 181 | fan speed increases (temp is higher) or decreases if lower than desired. |
| 182 | There are defined steps and times, but not exported by the driver yet. |
| 183 | |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 184 | pwm[1-4]_min_output |
| 185 | minimum fan speed (range 1 - 255), when the temperature |
| 186 | is below defined range. |
| 187 | pwm[1-4]_stop_time |
| 188 | how many milliseconds [ms] must elapse to switch |
| 189 | corresponding fan off. (when the temperature was below |
| 190 | defined range). |
| 191 | pwm[1-4]_start_output |
| 192 | minimum fan speed (range 1 - 255) when spinning up |
| 193 | pwm[1-4]_step_output |
| 194 | rate of fan speed change (1 - 255) |
| 195 | pwm[1-4]_stop_output |
| 196 | minimum fan speed (range 1 - 255) when spinning down |
| 197 | pwm[1-4]_max_output |
| 198 | maximum fan speed (range 1 - 255), when the temperature |
| 199 | is above defined range. |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 200 | |
Guenter Roeck | c43524b | 2012-02-09 08:41:03 -0800 | [diff] [blame] | 201 | Note: last six functions are influenced by other control bits, not yet exported |
Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 202 | by the driver, so a change might not have any effect. |
David Hubbard | 657c93b | 2007-02-14 21:15:04 +0100 | [diff] [blame] | 203 | |
| 204 | Implementation Details |
| 205 | ---------------------- |
| 206 | |
| 207 | Future driver development should bear in mind that the following registers have |
| 208 | different functions on the 627EHF and the 627DHG. Some registers also have |
| 209 | different power-on default values, but BIOS should already be loading |
| 210 | appropriate defaults. Note that bank selection must be performed as is currently |
| 211 | done in the driver for all register addresses. |
| 212 | |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 213 | ========================= ===================================================== |
| 214 | Register(s) Meaning |
| 215 | ========================= ===================================================== |
| 216 | 0x49 only on DHG, selects temperature source for AUX fan, |
| 217 | CPU fan0 |
| 218 | 0x4a not completely documented for the EHF and the DHG |
| 219 | documentation assigns different behavior to bits 7 |
| 220 | and 6, including extending the temperature input |
| 221 | selection to SmartFan I, not just SmartFan III. |
| 222 | Testing on the EHF will reveal whether they are |
| 223 | compatible or not. |
| 224 | 0x58 Chip ID: 0xa1=EHF 0xc1=DHG |
| 225 | 0x5e only on DHG, has bits to enable "current mode" |
| 226 | temperature detection and critical temperature |
| 227 | protection |
| 228 | 0x45b only on EHF, bit 3, vin4 alarm (EHF supports 10 |
| 229 | inputs, only 9 on DHG) |
| 230 | 0x552 only on EHF, vin4 |
| 231 | 0x558 only on EHF, vin4 high limit |
| 232 | 0x559 only on EHF, vin4 low limit |
| 233 | 0x6b only on DHG, SYS fan critical temperature |
| 234 | 0x6c only on DHG, CPU fan0 critical temperature |
| 235 | 0x6d only on DHG, AUX fan critical temperature |
| 236 | 0x6e only on DHG, CPU fan1 critical temperature |
| 237 | 0x50-0x55 and 0x650-0x657 marked as: |
David Hubbard | 657c93b | 2007-02-14 21:15:04 +0100 | [diff] [blame] | 238 | |
Mauro Carvalho Chehab | b04f2f7 | 2019-04-17 06:46:28 -0300 | [diff] [blame] | 239 | - "Test Register" for the EHF |
| 240 | - "Reserved Register" for the DHG |
| 241 | ========================= ===================================================== |
David Hubbard | 657c93b | 2007-02-14 21:15:04 +0100 | [diff] [blame] | 242 | |
| 243 | The DHG also supports PECI, where the DHG queries Intel CPU temperatures, and |
| 244 | the ICH8 southbridge gets that data via PECI from the DHG, so that the |
| 245 | southbridge drives the fans. And the DHG supports SST, a one-wire serial bus. |
Jean Delvare | c1e48dc | 2009-06-15 18:39:50 +0200 | [diff] [blame] | 246 | |
| 247 | The DHG-P has an additional automatic fan speed control mode named Smart Fan |
| 248 | (TM) III+. This mode is not yet supported by the driver. |