| Kernel driver adt7470 | 
 | ===================== | 
 |  | 
 | Supported chips: | 
 |  | 
 |   * Analog Devices ADT7470 | 
 |  | 
 |     Prefix: 'adt7470' | 
 |  | 
 |     Addresses scanned: I2C 0x2C, 0x2E, 0x2F | 
 |  | 
 |     Datasheet: Publicly available at the Analog Devices website | 
 |  | 
 | Author: Darrick J. Wong | 
 |  | 
 | Description | 
 | ----------- | 
 |  | 
 | This driver implements support for the Analog Devices ADT7470 chip.  There may | 
 | be other chips that implement this interface. | 
 |  | 
 | The ADT7470 uses the 2-wire interface compatible with the SMBus 2.0 | 
 | specification. Using an analog to digital converter it measures up to ten (10) | 
 | external temperatures. It has four (4) 16-bit counters for measuring fan speed. | 
 | There are four (4) PWM outputs that can be used to control fan speed. | 
 |  | 
 | A sophisticated control system for the PWM outputs is designed into the ADT7470 | 
 | that allows fan speed to be adjusted automatically based on any of the ten | 
 | temperature sensors. Each PWM output is individually adjustable and | 
 | programmable. Once configured, the ADT7470 will adjust the PWM outputs in | 
 | response to the measured temperatures with further host intervention.  This | 
 | feature can also be disabled for manual control of the PWM's. | 
 |  | 
 | Each of the measured inputs (temperature, fan speed) has corresponding high/low | 
 | limit values. The ADT7470 will signal an ALARM if any measured value exceeds | 
 | either limit. | 
 |  | 
 | The ADT7470 samples all inputs continuously.  A kernel thread is started up for | 
 | the purpose of periodically querying the temperature sensors, thus allowing the | 
 | automatic fan pwm control to set the fan speed.  The driver will not read the | 
 | registers more often than once every 5 seconds.  Further, configuration data is | 
 | only read once per minute. | 
 |  | 
 | Special Features | 
 | ---------------- | 
 |  | 
 | The ADT7470 has a 8-bit ADC and is capable of measuring temperatures with 1 | 
 | degC resolution. | 
 |  | 
 | The Analog Devices datasheet is very detailed and describes a procedure for | 
 | determining an optimal configuration for the automatic PWM control. | 
 |  | 
 | Configuration Notes | 
 | ------------------- | 
 |  | 
 | Besides standard interfaces driver adds the following: | 
 |  | 
 | * PWM Control | 
 |  | 
 | * pwm#_auto_point1_pwm and pwm#_auto_point1_temp and | 
 | * pwm#_auto_point2_pwm and pwm#_auto_point2_temp - | 
 |  | 
 |   - point1: Set the pwm speed at a lower temperature bound. | 
 |   - point2: Set the pwm speed at a higher temperature bound. | 
 |  | 
 | The ADT7470 will scale the pwm between the lower and higher pwm speed when | 
 | the temperature is between the two temperature boundaries.  PWM values range | 
 | from 0 (off) to 255 (full speed).  Fan speed will be set to maximum when the | 
 | temperature sensor associated with the PWM control exceeds | 
 | pwm#_auto_point2_temp. | 
 |  | 
 | The driver also allows control of the PWM frequency: | 
 |  | 
 | * pwm1_freq | 
 |  | 
 | The PWM frequency is rounded to the nearest one of: | 
 |  | 
 | * 11.0 Hz | 
 | * 14.7 Hz | 
 | * 22.1 Hz | 
 | * 29.4 Hz | 
 | * 35.3 Hz | 
 | * 44.1 Hz | 
 | * 58.8 Hz | 
 | * 88.2 Hz | 
 | * 1.4 kHz | 
 | * 22.5 kHz | 
 |  | 
 | Notes | 
 | ----- | 
 |  | 
 | The temperature inputs no longer need to be read periodically from userspace in | 
 | order for the automatic pwm algorithm to run.  This was the case for earlier | 
 | versions of the driver. |