Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 1 | Kernel driver adt7475 |
| 2 | ===================== |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 3 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 4 | Supported chips: |
| 5 | * Analog Devices ADT7473 |
| 6 | Prefix: 'adt7473' |
| 7 | Addresses scanned: I2C 0x2C, 0x2D, 0x2E |
| 8 | Datasheet: Publicly available at the On Semiconductors website |
| 9 | * Analog Devices ADT7475 |
| 10 | Prefix: 'adt7475' |
| 11 | Addresses scanned: I2C 0x2E |
| 12 | Datasheet: Publicly available at the On Semiconductors website |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 13 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 14 | Authors: |
| 15 | Jordan Crouse |
| 16 | Hans de Goede |
| 17 | Darrick J. Wong (documentation) |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 18 | |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 19 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 20 | Description |
| 21 | ----------- |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 22 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 23 | This driver implements support for the Analog Devices ADT7473 and ADT7475 |
| 24 | chip family. Both chips differ only in minor details. They will be |
| 25 | collectively designed by the name "ADT747x" in the rest of this document. |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 26 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 27 | The ADT747x uses the 2-wire interface compatible with the SMBus 2.0 |
| 28 | specification. Using an analog to digital converter it measures three (3) |
| 29 | temperatures and two (2) voltages. It has four (4) 16-bit counters for |
| 30 | measuring fan speed. There are three (3) PWM outputs that can be used |
| 31 | to control fan speed. |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 32 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 33 | A sophisticated control system for the PWM outputs is designed into the |
| 34 | ADT747x that allows fan speed to be adjusted automatically based on any of the |
| 35 | three temperature sensors. Each PWM output is individually adjustable and |
| 36 | programmable. Once configured, the ADT747x will adjust the PWM outputs in |
| 37 | response to the measured temperatures without further host intervention. |
| 38 | This feature can also be disabled for manual control of the PWM's. |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 39 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 40 | Each of the measured inputs (voltage, temperature, fan speed) has |
| 41 | corresponding high/low limit values. The ADT747x will signal an ALARM if |
| 42 | any measured value exceeds either limit. |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 43 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 44 | The ADT747x samples all inputs continuously. The driver will not read |
| 45 | the registers more often than once every other second. Further, |
| 46 | configuration data is only read once per minute. |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 47 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 48 | Special Features |
| 49 | ---------------- |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 50 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 51 | The ADT747x has a 10-bit ADC and can therefore measure temperatures |
| 52 | with a resolution of 0.25 degree Celsius. Temperature readings can be |
| 53 | configured either for two's complement format or "Offset 64" format, |
| 54 | wherein 64 is subtracted from the raw value to get the temperature value. |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 55 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 56 | The datasheet is very detailed and describes a procedure for determining |
| 57 | an optimal configuration for the automatic PWM control. |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 58 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 59 | Fan Speed Control |
| 60 | ----------------- |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 61 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 62 | The driver exposes two trip points per PWM channel. |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 63 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 64 | point1: Set the PWM speed at the lower temperature bound |
| 65 | point2: Set the PWM speed at the higher temperature bound |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 66 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 67 | The ADT747x will scale the PWM linearly between the lower and higher PWM |
| 68 | speed when the temperature is between the two temperature boundaries. |
| 69 | Temperature boundaries are associated to temperature channels rather than |
| 70 | PWM outputs, and a given PWM output can be controlled by several temperature |
| 71 | channels. As a result, the ADT747x may compute more than one PWM value |
| 72 | for a channel at a given time, in which case the maximum value (fastest |
| 73 | fan speed) is applied. PWM values range from 0 (off) to 255 (full speed). |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 74 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 75 | Fan speed may be set to maximum when the temperature sensor associated with |
| 76 | the PWM control exceeds temp#_max. |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 77 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 78 | Notes |
| 79 | ----- |
Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 80 | |
Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame^] | 81 | The nVidia binary driver presents an ADT7473 chip via an on-card i2c bus. |
| 82 | Unfortunately, they fail to set the i2c adapter class, so this driver may |
| 83 | fail to find the chip until the nvidia driver is patched. |