ide-pci-generic: kill the unused ifdef/endif/MODULE code
[linux-2.6/openmoko-kernel/knife-kernel.git] / drivers / i2c / busses / i2c-i801.c
blobaa9157913b9addd98182a0b5f16cd92cd0b80ea3
1 /*
2 i2c-i801.c - Part of lm_sensors, Linux kernel modules for hardware
3 monitoring
4 Copyright (c) 1998 - 2002 Frodo Looijaard <frodol@dds.nl>,
5 Philip Edelbrock <phil@netroedge.com>, and Mark D. Studebaker
6 <mdsxyz123@yahoo.com>
7 Copyright (C) 2007 Jean Delvare <khali@linux-fr.org>
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
25 Supports the following Intel I/O Controller Hubs (ICH):
27 I/O Block I2C
28 region SMBus Block proc. block
29 Chip name PCI ID size PEC buffer call read
30 ----------------------------------------------------------------------
31 82801AA (ICH) 0x2413 16 no no no no
32 82801AB (ICH0) 0x2423 16 no no no no
33 82801BA (ICH2) 0x2443 16 no no no no
34 82801CA (ICH3) 0x2483 32 soft no no no
35 82801DB (ICH4) 0x24c3 32 hard yes no no
36 82801E (ICH5) 0x24d3 32 hard yes yes yes
37 6300ESB 0x25a4 32 hard yes yes yes
38 82801F (ICH6) 0x266a 32 hard yes yes yes
39 6310ESB/6320ESB 0x269b 32 hard yes yes yes
40 82801G (ICH7) 0x27da 32 hard yes yes yes
41 82801H (ICH8) 0x283e 32 hard yes yes yes
42 82801I (ICH9) 0x2930 32 hard yes yes yes
43 Tolapai 0x5032 32 hard yes ? ?
45 Features supported by this driver:
46 Software PEC no
47 Hardware PEC yes
48 Block buffer yes
49 Block process call transaction no
50 I2C block read transaction yes (doesn't use the block buffer)
52 See the file Documentation/i2c/busses/i2c-i801 for details.
55 /* Note: we assume there can only be one I801, with one SMBus interface */
57 #include <linux/module.h>
58 #include <linux/pci.h>
59 #include <linux/kernel.h>
60 #include <linux/stddef.h>
61 #include <linux/delay.h>
62 #include <linux/ioport.h>
63 #include <linux/init.h>
64 #include <linux/i2c.h>
65 #include <asm/io.h>
67 /* I801 SMBus address offsets */
68 #define SMBHSTSTS (0 + i801_smba)
69 #define SMBHSTCNT (2 + i801_smba)
70 #define SMBHSTCMD (3 + i801_smba)
71 #define SMBHSTADD (4 + i801_smba)
72 #define SMBHSTDAT0 (5 + i801_smba)
73 #define SMBHSTDAT1 (6 + i801_smba)
74 #define SMBBLKDAT (7 + i801_smba)
75 #define SMBPEC (8 + i801_smba) /* ICH3 and later */
76 #define SMBAUXSTS (12 + i801_smba) /* ICH4 and later */
77 #define SMBAUXCTL (13 + i801_smba) /* ICH4 and later */
79 /* PCI Address Constants */
80 #define SMBBAR 4
81 #define SMBHSTCFG 0x040
83 /* Host configuration bits for SMBHSTCFG */
84 #define SMBHSTCFG_HST_EN 1
85 #define SMBHSTCFG_SMB_SMI_EN 2
86 #define SMBHSTCFG_I2C_EN 4
88 /* Auxillary control register bits, ICH4+ only */
89 #define SMBAUXCTL_CRC 1
90 #define SMBAUXCTL_E32B 2
92 /* kill bit for SMBHSTCNT */
93 #define SMBHSTCNT_KILL 2
95 /* Other settings */
96 #define MAX_TIMEOUT 100
97 #define ENABLE_INT9 0 /* set to 0x01 to enable - untested */
99 /* I801 command constants */
100 #define I801_QUICK 0x00
101 #define I801_BYTE 0x04
102 #define I801_BYTE_DATA 0x08
103 #define I801_WORD_DATA 0x0C
104 #define I801_PROC_CALL 0x10 /* unimplemented */
105 #define I801_BLOCK_DATA 0x14
106 #define I801_I2C_BLOCK_DATA 0x18 /* ICH5 and later */
107 #define I801_BLOCK_LAST 0x34
108 #define I801_I2C_BLOCK_LAST 0x38 /* ICH5 and later */
109 #define I801_START 0x40
110 #define I801_PEC_EN 0x80 /* ICH3 and later */
112 /* I801 Hosts Status register bits */
113 #define SMBHSTSTS_BYTE_DONE 0x80
114 #define SMBHSTSTS_INUSE_STS 0x40
115 #define SMBHSTSTS_SMBALERT_STS 0x20
116 #define SMBHSTSTS_FAILED 0x10
117 #define SMBHSTSTS_BUS_ERR 0x08
118 #define SMBHSTSTS_DEV_ERR 0x04
119 #define SMBHSTSTS_INTR 0x02
120 #define SMBHSTSTS_HOST_BUSY 0x01
122 static unsigned long i801_smba;
123 static unsigned char i801_original_hstcfg;
124 static struct pci_driver i801_driver;
125 static struct pci_dev *I801_dev;
127 #define FEATURE_SMBUS_PEC (1 << 0)
128 #define FEATURE_BLOCK_BUFFER (1 << 1)
129 #define FEATURE_BLOCK_PROC (1 << 2)
130 #define FEATURE_I2C_BLOCK_READ (1 << 3)
131 static unsigned int i801_features;
133 static int i801_transaction(int xact)
135 int temp;
136 int result = 0;
137 int timeout = 0;
139 dev_dbg(&I801_dev->dev, "Transaction (pre): CNT=%02x, CMD=%02x, "
140 "ADD=%02x, DAT0=%02x, DAT1=%02x\n", inb_p(SMBHSTCNT),
141 inb_p(SMBHSTCMD), inb_p(SMBHSTADD), inb_p(SMBHSTDAT0),
142 inb_p(SMBHSTDAT1));
144 /* Make sure the SMBus host is ready to start transmitting */
145 /* 0x1f = Failed, Bus_Err, Dev_Err, Intr, Host_Busy */
146 if ((temp = (0x1f & inb_p(SMBHSTSTS))) != 0x00) {
147 dev_dbg(&I801_dev->dev, "SMBus busy (%02x). Resetting...\n",
148 temp);
149 outb_p(temp, SMBHSTSTS);
150 if ((temp = (0x1f & inb_p(SMBHSTSTS))) != 0x00) {
151 dev_dbg(&I801_dev->dev, "Failed! (%02x)\n", temp);
152 return -1;
153 } else {
154 dev_dbg(&I801_dev->dev, "Successful!\n");
158 /* the current contents of SMBHSTCNT can be overwritten, since PEC,
159 * INTREN, SMBSCMD are passed in xact */
160 outb_p(xact | I801_START, SMBHSTCNT);
162 /* We will always wait for a fraction of a second! */
163 do {
164 msleep(1);
165 temp = inb_p(SMBHSTSTS);
166 } while ((temp & SMBHSTSTS_HOST_BUSY) && (timeout++ < MAX_TIMEOUT));
168 /* If the SMBus is still busy, we give up */
169 if (timeout >= MAX_TIMEOUT) {
170 dev_dbg(&I801_dev->dev, "SMBus Timeout!\n");
171 result = -1;
172 /* try to stop the current command */
173 dev_dbg(&I801_dev->dev, "Terminating the current operation\n");
174 outb_p(inb_p(SMBHSTCNT) | SMBHSTCNT_KILL, SMBHSTCNT);
175 msleep(1);
176 outb_p(inb_p(SMBHSTCNT) & (~SMBHSTCNT_KILL), SMBHSTCNT);
179 if (temp & SMBHSTSTS_FAILED) {
180 result = -1;
181 dev_dbg(&I801_dev->dev, "Error: Failed bus transaction\n");
184 if (temp & SMBHSTSTS_BUS_ERR) {
185 result = -1;
186 dev_err(&I801_dev->dev, "Bus collision! SMBus may be locked "
187 "until next hard reset. (sorry!)\n");
188 /* Clock stops and slave is stuck in mid-transmission */
191 if (temp & SMBHSTSTS_DEV_ERR) {
192 result = -1;
193 dev_dbg(&I801_dev->dev, "Error: no response!\n");
196 if ((inb_p(SMBHSTSTS) & 0x1f) != 0x00)
197 outb_p(inb(SMBHSTSTS), SMBHSTSTS);
199 if ((temp = (0x1f & inb_p(SMBHSTSTS))) != 0x00) {
200 dev_dbg(&I801_dev->dev, "Failed reset at end of transaction "
201 "(%02x)\n", temp);
203 dev_dbg(&I801_dev->dev, "Transaction (post): CNT=%02x, CMD=%02x, "
204 "ADD=%02x, DAT0=%02x, DAT1=%02x\n", inb_p(SMBHSTCNT),
205 inb_p(SMBHSTCMD), inb_p(SMBHSTADD), inb_p(SMBHSTDAT0),
206 inb_p(SMBHSTDAT1));
207 return result;
210 /* wait for INTR bit as advised by Intel */
211 static void i801_wait_hwpec(void)
213 int timeout = 0;
214 int temp;
216 do {
217 msleep(1);
218 temp = inb_p(SMBHSTSTS);
219 } while ((!(temp & SMBHSTSTS_INTR))
220 && (timeout++ < MAX_TIMEOUT));
222 if (timeout >= MAX_TIMEOUT) {
223 dev_dbg(&I801_dev->dev, "PEC Timeout!\n");
225 outb_p(temp, SMBHSTSTS);
228 static int i801_block_transaction_by_block(union i2c_smbus_data *data,
229 char read_write, int hwpec)
231 int i, len;
233 inb_p(SMBHSTCNT); /* reset the data buffer index */
235 /* Use 32-byte buffer to process this transaction */
236 if (read_write == I2C_SMBUS_WRITE) {
237 len = data->block[0];
238 outb_p(len, SMBHSTDAT0);
239 for (i = 0; i < len; i++)
240 outb_p(data->block[i+1], SMBBLKDAT);
243 if (i801_transaction(I801_BLOCK_DATA | ENABLE_INT9 |
244 I801_PEC_EN * hwpec))
245 return -1;
247 if (read_write == I2C_SMBUS_READ) {
248 len = inb_p(SMBHSTDAT0);
249 if (len < 1 || len > I2C_SMBUS_BLOCK_MAX)
250 return -1;
252 data->block[0] = len;
253 for (i = 0; i < len; i++)
254 data->block[i + 1] = inb_p(SMBBLKDAT);
256 return 0;
259 static int i801_block_transaction_byte_by_byte(union i2c_smbus_data *data,
260 char read_write, int command,
261 int hwpec)
263 int i, len;
264 int smbcmd;
265 int temp;
266 int result = 0;
267 int timeout;
268 unsigned char errmask;
270 len = data->block[0];
272 if (read_write == I2C_SMBUS_WRITE) {
273 outb_p(len, SMBHSTDAT0);
274 outb_p(data->block[1], SMBBLKDAT);
277 for (i = 1; i <= len; i++) {
278 if (i == len && read_write == I2C_SMBUS_READ) {
279 if (command == I2C_SMBUS_I2C_BLOCK_DATA)
280 smbcmd = I801_I2C_BLOCK_LAST;
281 else
282 smbcmd = I801_BLOCK_LAST;
283 } else {
284 if (command == I2C_SMBUS_I2C_BLOCK_DATA
285 && read_write == I2C_SMBUS_READ)
286 smbcmd = I801_I2C_BLOCK_DATA;
287 else
288 smbcmd = I801_BLOCK_DATA;
290 outb_p(smbcmd | ENABLE_INT9, SMBHSTCNT);
292 dev_dbg(&I801_dev->dev, "Block (pre %d): CNT=%02x, CMD=%02x, "
293 "ADD=%02x, DAT0=%02x, DAT1=%02x, BLKDAT=%02x\n", i,
294 inb_p(SMBHSTCNT), inb_p(SMBHSTCMD), inb_p(SMBHSTADD),
295 inb_p(SMBHSTDAT0), inb_p(SMBHSTDAT1), inb_p(SMBBLKDAT));
297 /* Make sure the SMBus host is ready to start transmitting */
298 temp = inb_p(SMBHSTSTS);
299 if (i == 1) {
300 /* Erroneous conditions before transaction:
301 * Byte_Done, Failed, Bus_Err, Dev_Err, Intr, Host_Busy */
302 errmask = 0x9f;
303 } else {
304 /* Erroneous conditions during transaction:
305 * Failed, Bus_Err, Dev_Err, Intr */
306 errmask = 0x1e;
308 if (temp & errmask) {
309 dev_dbg(&I801_dev->dev, "SMBus busy (%02x). "
310 "Resetting...\n", temp);
311 outb_p(temp, SMBHSTSTS);
312 if (((temp = inb_p(SMBHSTSTS)) & errmask) != 0x00) {
313 dev_err(&I801_dev->dev,
314 "Reset failed! (%02x)\n", temp);
315 return -1;
317 if (i != 1)
318 /* if die in middle of block transaction, fail */
319 return -1;
322 if (i == 1)
323 outb_p(inb(SMBHSTCNT) | I801_START, SMBHSTCNT);
325 /* We will always wait for a fraction of a second! */
326 timeout = 0;
327 do {
328 msleep(1);
329 temp = inb_p(SMBHSTSTS);
331 while ((!(temp & SMBHSTSTS_BYTE_DONE))
332 && (timeout++ < MAX_TIMEOUT));
334 /* If the SMBus is still busy, we give up */
335 if (timeout >= MAX_TIMEOUT) {
336 /* try to stop the current command */
337 dev_dbg(&I801_dev->dev, "Terminating the current "
338 "operation\n");
339 outb_p(inb_p(SMBHSTCNT) | SMBHSTCNT_KILL, SMBHSTCNT);
340 msleep(1);
341 outb_p(inb_p(SMBHSTCNT) & (~SMBHSTCNT_KILL),
342 SMBHSTCNT);
343 result = -1;
344 dev_dbg(&I801_dev->dev, "SMBus Timeout!\n");
347 if (temp & SMBHSTSTS_FAILED) {
348 result = -1;
349 dev_dbg(&I801_dev->dev,
350 "Error: Failed bus transaction\n");
351 } else if (temp & SMBHSTSTS_BUS_ERR) {
352 result = -1;
353 dev_err(&I801_dev->dev, "Bus collision!\n");
354 } else if (temp & SMBHSTSTS_DEV_ERR) {
355 result = -1;
356 dev_dbg(&I801_dev->dev, "Error: no response!\n");
359 if (i == 1 && read_write == I2C_SMBUS_READ
360 && command != I2C_SMBUS_I2C_BLOCK_DATA) {
361 len = inb_p(SMBHSTDAT0);
362 if (len < 1 || len > I2C_SMBUS_BLOCK_MAX)
363 return -1;
364 data->block[0] = len;
367 /* Retrieve/store value in SMBBLKDAT */
368 if (read_write == I2C_SMBUS_READ)
369 data->block[i] = inb_p(SMBBLKDAT);
370 if (read_write == I2C_SMBUS_WRITE && i+1 <= len)
371 outb_p(data->block[i+1], SMBBLKDAT);
372 if ((temp & 0x9e) != 0x00)
373 outb_p(temp, SMBHSTSTS); /* signals SMBBLKDAT ready */
375 if ((temp = (0x1e & inb_p(SMBHSTSTS))) != 0x00) {
376 dev_dbg(&I801_dev->dev,
377 "Bad status (%02x) at end of transaction\n",
378 temp);
380 dev_dbg(&I801_dev->dev, "Block (post %d): CNT=%02x, CMD=%02x, "
381 "ADD=%02x, DAT0=%02x, DAT1=%02x, BLKDAT=%02x\n", i,
382 inb_p(SMBHSTCNT), inb_p(SMBHSTCMD), inb_p(SMBHSTADD),
383 inb_p(SMBHSTDAT0), inb_p(SMBHSTDAT1), inb_p(SMBBLKDAT));
385 if (result < 0)
386 return result;
388 return result;
391 static int i801_set_block_buffer_mode(void)
393 outb_p(inb_p(SMBAUXCTL) | SMBAUXCTL_E32B, SMBAUXCTL);
394 if ((inb_p(SMBAUXCTL) & SMBAUXCTL_E32B) == 0)
395 return -1;
396 return 0;
399 /* Block transaction function */
400 static int i801_block_transaction(union i2c_smbus_data *data, char read_write,
401 int command, int hwpec)
403 int result = 0;
404 unsigned char hostc;
406 if (command == I2C_SMBUS_I2C_BLOCK_DATA) {
407 if (read_write == I2C_SMBUS_WRITE) {
408 /* set I2C_EN bit in configuration register */
409 pci_read_config_byte(I801_dev, SMBHSTCFG, &hostc);
410 pci_write_config_byte(I801_dev, SMBHSTCFG,
411 hostc | SMBHSTCFG_I2C_EN);
412 } else if (!(i801_features & FEATURE_I2C_BLOCK_READ)) {
413 dev_err(&I801_dev->dev,
414 "I2C block read is unsupported!\n");
415 return -1;
419 if (read_write == I2C_SMBUS_WRITE
420 || command == I2C_SMBUS_I2C_BLOCK_DATA) {
421 if (data->block[0] < 1)
422 data->block[0] = 1;
423 if (data->block[0] > I2C_SMBUS_BLOCK_MAX)
424 data->block[0] = I2C_SMBUS_BLOCK_MAX;
425 } else {
426 data->block[0] = 32; /* max for SMBus block reads */
429 if ((i801_features & FEATURE_BLOCK_BUFFER)
430 && !(command == I2C_SMBUS_I2C_BLOCK_DATA
431 && read_write == I2C_SMBUS_READ)
432 && i801_set_block_buffer_mode() == 0)
433 result = i801_block_transaction_by_block(data, read_write,
434 hwpec);
435 else
436 result = i801_block_transaction_byte_by_byte(data, read_write,
437 command, hwpec);
439 if (result == 0 && hwpec)
440 i801_wait_hwpec();
442 if (command == I2C_SMBUS_I2C_BLOCK_DATA
443 && read_write == I2C_SMBUS_WRITE) {
444 /* restore saved configuration register value */
445 pci_write_config_byte(I801_dev, SMBHSTCFG, hostc);
447 return result;
450 /* Return -1 on error. */
451 static s32 i801_access(struct i2c_adapter * adap, u16 addr,
452 unsigned short flags, char read_write, u8 command,
453 int size, union i2c_smbus_data * data)
455 int hwpec;
456 int block = 0;
457 int ret, xact = 0;
459 hwpec = (i801_features & FEATURE_SMBUS_PEC) && (flags & I2C_CLIENT_PEC)
460 && size != I2C_SMBUS_QUICK
461 && size != I2C_SMBUS_I2C_BLOCK_DATA;
463 switch (size) {
464 case I2C_SMBUS_QUICK:
465 outb_p(((addr & 0x7f) << 1) | (read_write & 0x01),
466 SMBHSTADD);
467 xact = I801_QUICK;
468 break;
469 case I2C_SMBUS_BYTE:
470 outb_p(((addr & 0x7f) << 1) | (read_write & 0x01),
471 SMBHSTADD);
472 if (read_write == I2C_SMBUS_WRITE)
473 outb_p(command, SMBHSTCMD);
474 xact = I801_BYTE;
475 break;
476 case I2C_SMBUS_BYTE_DATA:
477 outb_p(((addr & 0x7f) << 1) | (read_write & 0x01),
478 SMBHSTADD);
479 outb_p(command, SMBHSTCMD);
480 if (read_write == I2C_SMBUS_WRITE)
481 outb_p(data->byte, SMBHSTDAT0);
482 xact = I801_BYTE_DATA;
483 break;
484 case I2C_SMBUS_WORD_DATA:
485 outb_p(((addr & 0x7f) << 1) | (read_write & 0x01),
486 SMBHSTADD);
487 outb_p(command, SMBHSTCMD);
488 if (read_write == I2C_SMBUS_WRITE) {
489 outb_p(data->word & 0xff, SMBHSTDAT0);
490 outb_p((data->word & 0xff00) >> 8, SMBHSTDAT1);
492 xact = I801_WORD_DATA;
493 break;
494 case I2C_SMBUS_BLOCK_DATA:
495 outb_p(((addr & 0x7f) << 1) | (read_write & 0x01),
496 SMBHSTADD);
497 outb_p(command, SMBHSTCMD);
498 block = 1;
499 break;
500 case I2C_SMBUS_I2C_BLOCK_DATA:
501 /* NB: page 240 of ICH5 datasheet shows that the R/#W
502 * bit should be cleared here, even when reading */
503 outb_p((addr & 0x7f) << 1, SMBHSTADD);
504 if (read_write == I2C_SMBUS_READ) {
505 /* NB: page 240 of ICH5 datasheet also shows
506 * that DATA1 is the cmd field when reading */
507 outb_p(command, SMBHSTDAT1);
508 } else
509 outb_p(command, SMBHSTCMD);
510 block = 1;
511 break;
512 case I2C_SMBUS_PROC_CALL:
513 default:
514 dev_err(&I801_dev->dev, "Unsupported transaction %d\n", size);
515 return -1;
518 if (hwpec) /* enable/disable hardware PEC */
519 outb_p(inb_p(SMBAUXCTL) | SMBAUXCTL_CRC, SMBAUXCTL);
520 else
521 outb_p(inb_p(SMBAUXCTL) & (~SMBAUXCTL_CRC), SMBAUXCTL);
523 if(block)
524 ret = i801_block_transaction(data, read_write, size, hwpec);
525 else
526 ret = i801_transaction(xact | ENABLE_INT9);
528 /* Some BIOSes don't like it when PEC is enabled at reboot or resume
529 time, so we forcibly disable it after every transaction. Turn off
530 E32B for the same reason. */
531 if (hwpec || block)
532 outb_p(inb_p(SMBAUXCTL) & ~(SMBAUXCTL_CRC | SMBAUXCTL_E32B),
533 SMBAUXCTL);
535 if(block)
536 return ret;
537 if(ret)
538 return -1;
539 if ((read_write == I2C_SMBUS_WRITE) || (xact == I801_QUICK))
540 return 0;
542 switch (xact & 0x7f) {
543 case I801_BYTE: /* Result put in SMBHSTDAT0 */
544 case I801_BYTE_DATA:
545 data->byte = inb_p(SMBHSTDAT0);
546 break;
547 case I801_WORD_DATA:
548 data->word = inb_p(SMBHSTDAT0) + (inb_p(SMBHSTDAT1) << 8);
549 break;
551 return 0;
555 static u32 i801_func(struct i2c_adapter *adapter)
557 return I2C_FUNC_SMBUS_QUICK | I2C_FUNC_SMBUS_BYTE |
558 I2C_FUNC_SMBUS_BYTE_DATA | I2C_FUNC_SMBUS_WORD_DATA |
559 I2C_FUNC_SMBUS_BLOCK_DATA | I2C_FUNC_SMBUS_WRITE_I2C_BLOCK |
560 ((i801_features & FEATURE_SMBUS_PEC) ? I2C_FUNC_SMBUS_PEC : 0) |
561 ((i801_features & FEATURE_I2C_BLOCK_READ) ?
562 I2C_FUNC_SMBUS_READ_I2C_BLOCK : 0);
565 static const struct i2c_algorithm smbus_algorithm = {
566 .smbus_xfer = i801_access,
567 .functionality = i801_func,
570 static struct i2c_adapter i801_adapter = {
571 .owner = THIS_MODULE,
572 .id = I2C_HW_SMBUS_I801,
573 .class = I2C_CLASS_HWMON,
574 .algo = &smbus_algorithm,
577 static struct pci_device_id i801_ids[] = {
578 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801AA_3) },
579 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801AB_3) },
580 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801BA_2) },
581 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801CA_3) },
582 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801DB_3) },
583 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801EB_3) },
584 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ESB_4) },
585 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH6_16) },
586 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH7_17) },
587 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ESB2_17) },
588 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH8_5) },
589 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH9_6) },
590 { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_TOLAPAI_1) },
591 { 0, }
594 MODULE_DEVICE_TABLE (pci, i801_ids);
596 static int __devinit i801_probe(struct pci_dev *dev, const struct pci_device_id *id)
598 unsigned char temp;
599 int err;
601 I801_dev = dev;
602 i801_features = 0;
603 switch (dev->device) {
604 case PCI_DEVICE_ID_INTEL_82801EB_3:
605 case PCI_DEVICE_ID_INTEL_ESB_4:
606 case PCI_DEVICE_ID_INTEL_ICH6_16:
607 case PCI_DEVICE_ID_INTEL_ICH7_17:
608 case PCI_DEVICE_ID_INTEL_ESB2_17:
609 case PCI_DEVICE_ID_INTEL_ICH8_5:
610 case PCI_DEVICE_ID_INTEL_ICH9_6:
611 i801_features |= FEATURE_I2C_BLOCK_READ;
612 /* fall through */
613 case PCI_DEVICE_ID_INTEL_82801DB_3:
614 case PCI_DEVICE_ID_INTEL_TOLAPAI_1:
615 i801_features |= FEATURE_SMBUS_PEC;
616 i801_features |= FEATURE_BLOCK_BUFFER;
617 break;
620 err = pci_enable_device(dev);
621 if (err) {
622 dev_err(&dev->dev, "Failed to enable SMBus PCI device (%d)\n",
623 err);
624 goto exit;
627 /* Determine the address of the SMBus area */
628 i801_smba = pci_resource_start(dev, SMBBAR);
629 if (!i801_smba) {
630 dev_err(&dev->dev, "SMBus base address uninitialized, "
631 "upgrade BIOS\n");
632 err = -ENODEV;
633 goto exit;
636 err = pci_request_region(dev, SMBBAR, i801_driver.name);
637 if (err) {
638 dev_err(&dev->dev, "Failed to request SMBus region "
639 "0x%lx-0x%Lx\n", i801_smba,
640 (unsigned long long)pci_resource_end(dev, SMBBAR));
641 goto exit;
644 pci_read_config_byte(I801_dev, SMBHSTCFG, &temp);
645 i801_original_hstcfg = temp;
646 temp &= ~SMBHSTCFG_I2C_EN; /* SMBus timing */
647 if (!(temp & SMBHSTCFG_HST_EN)) {
648 dev_info(&dev->dev, "Enabling SMBus device\n");
649 temp |= SMBHSTCFG_HST_EN;
651 pci_write_config_byte(I801_dev, SMBHSTCFG, temp);
653 if (temp & SMBHSTCFG_SMB_SMI_EN)
654 dev_dbg(&dev->dev, "SMBus using interrupt SMI#\n");
655 else
656 dev_dbg(&dev->dev, "SMBus using PCI Interrupt\n");
658 /* Clear special mode bits */
659 if (i801_features & (FEATURE_SMBUS_PEC | FEATURE_BLOCK_BUFFER))
660 outb_p(inb_p(SMBAUXCTL) & ~(SMBAUXCTL_CRC | SMBAUXCTL_E32B),
661 SMBAUXCTL);
663 /* set up the sysfs linkage to our parent device */
664 i801_adapter.dev.parent = &dev->dev;
666 snprintf(i801_adapter.name, sizeof(i801_adapter.name),
667 "SMBus I801 adapter at %04lx", i801_smba);
668 err = i2c_add_adapter(&i801_adapter);
669 if (err) {
670 dev_err(&dev->dev, "Failed to add SMBus adapter\n");
671 goto exit_release;
673 return 0;
675 exit_release:
676 pci_release_region(dev, SMBBAR);
677 exit:
678 return err;
681 static void __devexit i801_remove(struct pci_dev *dev)
683 i2c_del_adapter(&i801_adapter);
684 pci_write_config_byte(I801_dev, SMBHSTCFG, i801_original_hstcfg);
685 pci_release_region(dev, SMBBAR);
687 * do not call pci_disable_device(dev) since it can cause hard hangs on
688 * some systems during power-off (eg. Fujitsu-Siemens Lifebook E8010)
692 #ifdef CONFIG_PM
693 static int i801_suspend(struct pci_dev *dev, pm_message_t mesg)
695 pci_save_state(dev);
696 pci_write_config_byte(dev, SMBHSTCFG, i801_original_hstcfg);
697 pci_set_power_state(dev, pci_choose_state(dev, mesg));
698 return 0;
701 static int i801_resume(struct pci_dev *dev)
703 pci_set_power_state(dev, PCI_D0);
704 pci_restore_state(dev);
705 return pci_enable_device(dev);
707 #else
708 #define i801_suspend NULL
709 #define i801_resume NULL
710 #endif
712 static struct pci_driver i801_driver = {
713 .name = "i801_smbus",
714 .id_table = i801_ids,
715 .probe = i801_probe,
716 .remove = __devexit_p(i801_remove),
717 .suspend = i801_suspend,
718 .resume = i801_resume,
721 static int __init i2c_i801_init(void)
723 return pci_register_driver(&i801_driver);
726 static void __exit i2c_i801_exit(void)
728 pci_unregister_driver(&i801_driver);
731 MODULE_AUTHOR("Mark D. Studebaker <mdsxyz123@yahoo.com>, "
732 "Jean Delvare <khali@linux-fr.org>");
733 MODULE_DESCRIPTION("I801 SMBus driver");
734 MODULE_LICENSE("GPL");
736 module_init(i2c_i801_init);
737 module_exit(i2c_i801_exit);