| 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 | 
| Jean Delvare | d8d2ee0 | 2009-12-09 20:36:08 +0100 | [diff] [blame] | 13 |   * Analog Devices ADT7476 | 
 | 14 |     Prefix: 'adt7476' | 
 | 15 |     Addresses scanned: I2C 0x2C, 0x2D, 0x2E | 
 | 16 |     Datasheet: Publicly available at the On Semiconductors website | 
| Jean Delvare | 3d84998 | 2009-12-09 20:36:05 +0100 | [diff] [blame] | 17 |   * Analog Devices ADT7490 | 
 | 18 |     Prefix: 'adt7490' | 
 | 19 |     Addresses scanned: I2C 0x2C, 0x2D, 0x2E | 
 | 20 |     Datasheet: Publicly available at the On Semiconductors website | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 21 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 22 | Authors: | 
 | 23 | 	Jordan Crouse | 
 | 24 | 	Hans de Goede | 
 | 25 | 	Darrick J. Wong (documentation) | 
| Jean Delvare | 3d84998 | 2009-12-09 20:36:05 +0100 | [diff] [blame] | 26 | 	Jean Delvare | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 27 |  | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 28 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 29 | Description | 
 | 30 | ----------- | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 31 |  | 
| Jean Delvare | d8d2ee0 | 2009-12-09 20:36:08 +0100 | [diff] [blame] | 32 | This driver implements support for the Analog Devices ADT7473, ADT7475, | 
 | 33 | ADT7476 and ADT7490 chip family. The ADT7473 and ADT7475 differ only in | 
 | 34 | minor details. The ADT7476 has additional features, including extra voltage | 
 | 35 | measurement inputs and VID support. The ADT7490 also has additional | 
 | 36 | features, including extra voltage measurement inputs and PECI support. All | 
 | 37 | the supported chips will be collectively designed by the name "ADT747x" in | 
 | 38 | the rest of this document. | 
| 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 | The ADT747x uses the 2-wire interface compatible with the SMBus 2.0 | 
 | 41 | specification. Using an analog to digital converter it measures three (3) | 
| Jean Delvare | 3d84998 | 2009-12-09 20:36:05 +0100 | [diff] [blame] | 42 | temperatures and two (2) or more voltages. It has four (4) 16-bit counters | 
 | 43 | for measuring fan speed. There are three (3) PWM outputs that can be used | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 44 | to control fan speed. | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 45 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 46 | A sophisticated control system for the PWM outputs is designed into the | 
 | 47 | ADT747x that allows fan speed to be adjusted automatically based on any of the | 
 | 48 | three temperature sensors. Each PWM output is individually adjustable and | 
 | 49 | programmable. Once configured, the ADT747x will adjust the PWM outputs in | 
 | 50 | response to the measured temperatures without further host intervention. | 
 | 51 | 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] | 52 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 53 | Each of the measured inputs (voltage, temperature, fan speed) has | 
 | 54 | corresponding high/low limit values. The ADT747x will signal an ALARM if | 
 | 55 | any measured value exceeds either limit. | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 56 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 57 | The ADT747x samples all inputs continuously. The driver will not read | 
 | 58 | the registers more often than once every other second. Further, | 
 | 59 | configuration data is only read once per minute. | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 60 |  | 
| Jean Delvare | 3d84998 | 2009-12-09 20:36:05 +0100 | [diff] [blame] | 61 | Chip Differences Summary | 
 | 62 | ------------------------ | 
 | 63 |  | 
 | 64 | ADT7473: | 
 | 65 |   * 2 voltage inputs | 
 | 66 |   * system acoustics optimizations (not implemented) | 
 | 67 |  | 
 | 68 | ADT7475: | 
 | 69 |   * 2 voltage inputs | 
 | 70 |  | 
| Jean Delvare | d8d2ee0 | 2009-12-09 20:36:08 +0100 | [diff] [blame] | 71 | ADT7476: | 
 | 72 |   * 5 voltage inputs | 
| Jean Delvare | 54fe467 | 2009-12-09 20:36:08 +0100 | [diff] [blame] | 73 |   * VID support | 
| Jean Delvare | d8d2ee0 | 2009-12-09 20:36:08 +0100 | [diff] [blame] | 74 |  | 
| Jean Delvare | 3d84998 | 2009-12-09 20:36:05 +0100 | [diff] [blame] | 75 | ADT7490: | 
 | 76 |   * 6 voltage inputs | 
 | 77 |   * 1 Imon input (not implemented) | 
 | 78 |   * PECI support (not implemented) | 
 | 79 |   * 2 GPIO pins (not implemented) | 
 | 80 |   * system acoustics optimizations (not implemented) | 
 | 81 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 82 | Special Features | 
 | 83 | ---------------- | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 84 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 85 | The ADT747x has a 10-bit ADC and can therefore measure temperatures | 
 | 86 | with a resolution of 0.25 degree Celsius. Temperature readings can be | 
 | 87 | configured either for two's complement format or "Offset 64" format, | 
 | 88 | 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] | 89 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 90 | The datasheet is very detailed and describes a procedure for determining | 
 | 91 | an optimal configuration for the automatic PWM control. | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 92 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 93 | Fan Speed Control | 
 | 94 | ----------------- | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 95 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 96 | The driver exposes two trip points per PWM channel. | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 97 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 98 | point1: Set the PWM speed at the lower temperature bound | 
 | 99 | point2: Set the PWM speed at the higher temperature bound | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 100 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 101 | The ADT747x will scale the PWM linearly between the lower and higher PWM | 
 | 102 | speed when the temperature is between the two temperature boundaries. | 
 | 103 | Temperature boundaries are associated to temperature channels rather than | 
 | 104 | PWM outputs, and a given PWM output can be controlled by several temperature | 
 | 105 | channels. As a result, the ADT747x may compute more than one PWM value | 
 | 106 | for a channel at a given time, in which case the maximum value (fastest | 
 | 107 | 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] | 108 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 109 | Fan speed may be set to maximum when the temperature sensor associated with | 
 | 110 | the PWM control exceeds temp#_max. | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 111 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 112 | Notes | 
 | 113 | ----- | 
| Jordan Crouse | 1c301fc | 2009-01-15 22:27:47 +0100 | [diff] [blame] | 114 |  | 
| Jean Delvare | f890c6a | 2009-12-09 20:36:02 +0100 | [diff] [blame] | 115 | The nVidia binary driver presents an ADT7473 chip via an on-card i2c bus. | 
 | 116 | Unfortunately, they fail to set the i2c adapter class, so this driver may | 
 | 117 | fail to find the chip until the nvidia driver is patched. |