| Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 1 | Kernel driver w83627ehf | 
 | 2 | ======================= | 
 | 3 |  | 
 | 4 | Supported chips: | 
 | 5 |   * Winbond W83627EHF/EHG (ISA access ONLY) | 
 | 6 |     Prefix: 'w83627ehf' | 
 | 7 |     Addresses scanned: ISA address retrieved from Super I/O registers | 
 | 8 |     Datasheet: http://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/W83627EHF_%20W83627EHGb.pdf | 
 | 9 |  | 
 | 10 | Authors: | 
 | 11 |         Jean Delvare <khali@linux-fr.org> | 
| Jean Delvare | 3379cee | 2006-09-24 21:25:52 +0200 | [diff] [blame] | 12 |         Yuan Mu (Winbond) | 
| Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 13 |         Rudolf Marek <r.marek@sh.cvut.cz> | 
 | 14 |  | 
 | 15 | Description | 
 | 16 | ----------- | 
 | 17 |  | 
 | 18 | This driver implements support for the Winbond W83627EHF and W83627EHG | 
 | 19 | super I/O chips. We will refer to them collectively as Winbond chips. | 
 | 20 |  | 
 | 21 | The chips implement three temperature sensors, five fan rotation | 
 | 22 | speed sensors, ten analog voltage sensors, alarms with beep warnings (control | 
 | 23 | unimplemented), and some automatic fan regulation strategies (plus manual | 
 | 24 | fan control mode). | 
 | 25 |  | 
 | 26 | Temperatures are measured in degrees Celsius and measurement resolution is 1 | 
 | 27 | degC for temp1 and 0.5 degC for temp2 and temp3. An alarm is triggered when | 
 | 28 | the temperature gets higher than high limit; it stays on until the temperature | 
| Jean Delvare | 15fe25c | 2006-10-08 21:59:54 +0200 | [diff] [blame^] | 29 | falls below the hysteresis value. | 
| Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 30 |  | 
 | 31 | Fan rotation speeds are reported in RPM (rotations per minute). An alarm is | 
 | 32 | triggered if the rotation speed has dropped below a programmable limit. Fan | 
 | 33 | readings can be divided by a programmable divider (1, 2, 4, 8, 16, 32, 64 or | 
 | 34 | 128) to give the readings more range or accuracy. The driver sets the most | 
 | 35 | suitable fan divisor itself. Some fans might not be present because they | 
 | 36 | share pins with other functions. | 
 | 37 |  | 
 | 38 | Voltage sensors (also known as IN sensors) report their values in millivolts. | 
 | 39 | An alarm is triggered if the voltage has crossed a programmable minimum | 
 | 40 | or maximum limit. | 
 | 41 |  | 
 | 42 | The driver supports automatic fan control mode known as Thermal Cruise. | 
 | 43 | In this mode, the chip attempts to keep the measured temperature in a | 
 | 44 | predefined temperature range. If the temperature goes out of range, fan | 
 | 45 | is driven slower/faster to reach the predefined range again. | 
 | 46 |  | 
 | 47 | The mode works for fan1-fan4. Mapping of temperatures to pwm outputs is as | 
 | 48 | follows: | 
 | 49 |  | 
 | 50 | temp1 -> pwm1 | 
 | 51 | temp2 -> pwm2 | 
 | 52 | temp3 -> pwm3 | 
 | 53 | prog  -> pwm4 (the programmable setting is not supported by the driver) | 
 | 54 |  | 
 | 55 | /sys files | 
 | 56 | ---------- | 
 | 57 |  | 
 | 58 | pwm[1-4] - this file stores PWM duty cycle or DC value (fan speed) in range: | 
 | 59 | 	   0 (stop) to 255 (full) | 
 | 60 |  | 
 | 61 | pwm[1-4]_enable - this file controls mode of fan/temperature control: | 
 | 62 | 	* 1 Manual Mode, write to pwm file any value 0-255 (full speed) | 
 | 63 | 	* 2 Thermal Cruise | 
 | 64 |  | 
 | 65 | Thermal Cruise mode | 
 | 66 | ------------------- | 
 | 67 |  | 
 | 68 | If the temperature is in the range defined by: | 
 | 69 |  | 
| Jean Delvare | 15fe25c | 2006-10-08 21:59:54 +0200 | [diff] [blame^] | 70 | pwm[1-4]_target    - set target temperature, unit millidegree Celsius | 
| Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 71 | 		     (range 0 - 127000) | 
| Jean Delvare | 15fe25c | 2006-10-08 21:59:54 +0200 | [diff] [blame^] | 72 | pwm[1-4]_tolerance - tolerance, unit millidegree Celsius (range 0 - 15000) | 
| Rudolf Marek | 563daaf | 2006-07-05 18:15:31 +0200 | [diff] [blame] | 73 |  | 
 | 74 | there are no changes to fan speed. Once the temperature leaves the interval, | 
 | 75 | fan speed increases (temp is higher) or decreases if lower than desired. | 
 | 76 | There are defined steps and times, but not exported by the driver yet. | 
 | 77 |  | 
 | 78 | pwm[1-4]_min_output - minimum fan speed (range 1 - 255), when the temperature | 
 | 79 |                       is below defined range. | 
 | 80 | pwm[1-4]_stop_time  - how many milliseconds [ms] must elapse to switch | 
 | 81 |                       corresponding fan off. (when the temperature was below | 
 | 82 |                       defined range). | 
 | 83 |  | 
 | 84 | Note: last two functions are influenced by other control bits, not yet exported | 
 | 85 |       by the driver, so a change might not have any effect. |