Commit ae7b0497 authored by Jean Delvare's avatar Jean Delvare Committed by Jean Delvare

i2c-i801: Document which chip support what feature

Provide a clearer documentation of which additional features each
ICH chip support, and which of these the driver supports.
Signed-off-by: default avatarJean Delvare <khali@linux-fr.org>
parent 6d16bfb5
...@@ -21,25 +21,34 @@ ...@@ -21,25 +21,34 @@
*/ */
/* /*
SUPPORTED DEVICES PCI ID Supports the following Intel I/O Controller Hubs (ICH):
82801AA 2413
82801AB 2423 I/O Block I2C
82801BA 2443 region SMBus Block proc. block
82801CA/CAM 2483 Chip name PCI ID size PEC buffer call read
82801DB 24C3 (HW PEC supported) ----------------------------------------------------------------------
82801EB 24D3 (HW PEC supported) 82801AA (ICH) 0x2413 16 no no no no
6300ESB 25A4 82801AB (ICH0) 0x2423 16 no no no no
ICH6 266A 82801BA (ICH2) 0x2443 16 no no no no
ICH7 27DA 82801CA (ICH3) 0x2483 32 soft no no no
ESB2 269B 82801DB (ICH4) 0x24c3 32 hard yes no no
ICH8 283E 82801E (ICH5) 0x24d3 32 hard yes yes yes
ICH9 2930 6300ESB 0x25a4 32 hard yes yes yes
Tolapai 5032 82801F (ICH6) 0x266a 32 hard yes yes yes
This driver supports several versions of Intel's I/O Controller Hubs (ICH). 6310ESB/6320ESB 0x269b 32 hard yes yes yes
For SMBus support, they are similar to the PIIX4 and are part 82801G (ICH7) 0x27da 32 hard yes yes yes
of Intel's '810' and other chipsets. 82801H (ICH8) 0x283e 32 hard yes yes yes
See the file Documentation/i2c/busses/i2c-i801 for details. 82801I (ICH9) 0x2930 32 hard yes yes yes
I2C Block Read and Process Call are not supported. Tolapai 0x5032 32 hard yes ? ?
Features supported by this driver:
Software PEC no
Hardware PEC yes
Block buffer yes
Block process call transaction no
I2C block read transaction no
See the file Documentation/i2c/busses/i2c-i801 for details.
*/ */
/* Note: we assume there can only be one I801, with one SMBus interface */ /* Note: we assume there can only be one I801, with one SMBus interface */
...@@ -62,9 +71,9 @@ ...@@ -62,9 +71,9 @@
#define SMBHSTDAT0 (5 + i801_smba) #define SMBHSTDAT0 (5 + i801_smba)
#define SMBHSTDAT1 (6 + i801_smba) #define SMBHSTDAT1 (6 + i801_smba)
#define SMBBLKDAT (7 + i801_smba) #define SMBBLKDAT (7 + i801_smba)
#define SMBPEC (8 + i801_smba) /* ICH4 only */ #define SMBPEC (8 + i801_smba) /* ICH3 and later */
#define SMBAUXSTS (12 + i801_smba) /* ICH4 only */ #define SMBAUXSTS (12 + i801_smba) /* ICH4 and later */
#define SMBAUXCTL (13 + i801_smba) /* ICH4 only */ #define SMBAUXCTL (13 + i801_smba) /* ICH4 and later */
/* PCI Address Constants */ /* PCI Address Constants */
#define SMBBAR 4 #define SMBBAR 4
...@@ -91,13 +100,13 @@ ...@@ -91,13 +100,13 @@
#define I801_BYTE 0x04 #define I801_BYTE 0x04
#define I801_BYTE_DATA 0x08 #define I801_BYTE_DATA 0x08
#define I801_WORD_DATA 0x0C #define I801_WORD_DATA 0x0C
#define I801_PROC_CALL 0x10 /* later chips only, unimplemented */ #define I801_PROC_CALL 0x10 /* unimplemented */
#define I801_BLOCK_DATA 0x14 #define I801_BLOCK_DATA 0x14
#define I801_I2C_BLOCK_DATA 0x18 /* unimplemented */ #define I801_I2C_BLOCK_DATA 0x18 /* unimplemented */
#define I801_BLOCK_LAST 0x34 #define I801_BLOCK_LAST 0x34
#define I801_I2C_BLOCK_LAST 0x38 /* unimplemented */ #define I801_I2C_BLOCK_LAST 0x38 /* unimplemented */
#define I801_START 0x40 #define I801_START 0x40
#define I801_PEC_EN 0x80 /* ICH4 only */ #define I801_PEC_EN 0x80 /* ICH3 and later */
/* I801 Hosts Status register bits */ /* I801 Hosts Status register bits */
#define SMBHSTSTS_BYTE_DONE 0x80 #define SMBHSTSTS_BYTE_DONE 0x80
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment