aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/i2c/busses/i2c-i801.c20
1 files changed, 1 insertions, 19 deletions
diff --git a/drivers/i2c/busses/i2c-i801.c b/drivers/i2c/busses/i2c-i801.c
index 588583530c9f..413930cafc49 100644
--- a/drivers/i2c/busses/i2c-i801.c
+++ b/drivers/i2c/busses/i2c-i801.c
@@ -52,10 +52,6 @@
52#include <linux/i2c.h> 52#include <linux/i2c.h>
53#include <asm/io.h> 53#include <asm/io.h>
54 54
55#ifdef I2C_FUNC_SMBUS_BLOCK_DATA_PEC
56#define HAVE_PEC
57#endif
58
59/* I801 SMBus address offsets */ 55/* I801 SMBus address offsets */
60#define SMBHSTSTS (0 + i801_smba) 56#define SMBHSTSTS (0 + i801_smba)
61#define SMBHSTCNT (2 + i801_smba) 57#define SMBHSTCNT (2 + i801_smba)
@@ -392,7 +388,6 @@ static int i801_block_transaction(union i2c_smbus_data *data, char read_write,
392 goto END; 388 goto END;
393 } 389 }
394 390
395#ifdef HAVE_PEC
396 if(isich4 && command == I2C_SMBUS_BLOCK_DATA_PEC) { 391 if(isich4 && command == I2C_SMBUS_BLOCK_DATA_PEC) {
397 /* wait for INTR bit as advised by Intel */ 392 /* wait for INTR bit as advised by Intel */
398 timeout = 0; 393 timeout = 0;
@@ -407,7 +402,6 @@ static int i801_block_transaction(union i2c_smbus_data *data, char read_write,
407 } 402 }
408 outb_p(temp, SMBHSTSTS); 403 outb_p(temp, SMBHSTSTS);
409 } 404 }
410#endif
411 result = 0; 405 result = 0;
412END: 406END:
413 if (command == I2C_SMBUS_I2C_BLOCK_DATA) { 407 if (command == I2C_SMBUS_I2C_BLOCK_DATA) {
@@ -426,10 +420,8 @@ static s32 i801_access(struct i2c_adapter * adap, u16 addr,
426 int block = 0; 420 int block = 0;
427 int ret, xact = 0; 421 int ret, xact = 0;
428 422
429#ifdef HAVE_PEC
430 if(isich4) 423 if(isich4)
431 hwpec = (flags & I2C_CLIENT_PEC) != 0; 424 hwpec = (flags & I2C_CLIENT_PEC) != 0;
432#endif
433 425
434 switch (size) { 426 switch (size) {
435 case I2C_SMBUS_QUICK: 427 case I2C_SMBUS_QUICK:
@@ -464,11 +456,9 @@ static s32 i801_access(struct i2c_adapter * adap, u16 addr,
464 break; 456 break;
465 case I2C_SMBUS_BLOCK_DATA: 457 case I2C_SMBUS_BLOCK_DATA:
466 case I2C_SMBUS_I2C_BLOCK_DATA: 458 case I2C_SMBUS_I2C_BLOCK_DATA:
467#ifdef HAVE_PEC
468 case I2C_SMBUS_BLOCK_DATA_PEC: 459 case I2C_SMBUS_BLOCK_DATA_PEC:
469 if(hwpec && size == I2C_SMBUS_BLOCK_DATA) 460 if(hwpec && size == I2C_SMBUS_BLOCK_DATA)
470 size = I2C_SMBUS_BLOCK_DATA_PEC; 461 size = I2C_SMBUS_BLOCK_DATA_PEC;
471#endif
472 outb_p(((addr & 0x7f) << 1) | (read_write & 0x01), 462 outb_p(((addr & 0x7f) << 1) | (read_write & 0x01),
473 SMBHSTADD); 463 SMBHSTADD);
474 outb_p(command, SMBHSTCMD); 464 outb_p(command, SMBHSTCMD);
@@ -480,13 +470,11 @@ static s32 i801_access(struct i2c_adapter * adap, u16 addr,
480 return -1; 470 return -1;
481 } 471 }
482 472
483#ifdef HAVE_PEC
484 if(isich4 && hwpec) { 473 if(isich4 && hwpec) {
485 if(size != I2C_SMBUS_QUICK && 474 if(size != I2C_SMBUS_QUICK &&
486 size != I2C_SMBUS_I2C_BLOCK_DATA) 475 size != I2C_SMBUS_I2C_BLOCK_DATA)
487 outb_p(1, SMBAUXCTL); /* enable HW PEC */ 476 outb_p(1, SMBAUXCTL); /* enable HW PEC */
488 } 477 }
489#endif
490 if(block) 478 if(block)
491 ret = i801_block_transaction(data, read_write, size); 479 ret = i801_block_transaction(data, read_write, size);
492 else { 480 else {
@@ -494,13 +482,11 @@ static s32 i801_access(struct i2c_adapter * adap, u16 addr,
494 ret = i801_transaction(); 482 ret = i801_transaction();
495 } 483 }
496 484
497#ifdef HAVE_PEC
498 if(isich4 && hwpec) { 485 if(isich4 && hwpec) {
499 if(size != I2C_SMBUS_QUICK && 486 if(size != I2C_SMBUS_QUICK &&
500 size != I2C_SMBUS_I2C_BLOCK_DATA) 487 size != I2C_SMBUS_I2C_BLOCK_DATA)
501 outb_p(0, SMBAUXCTL); 488 outb_p(0, SMBAUXCTL);
502 } 489 }
503#endif
504 490
505 if(block) 491 if(block)
506 return ret; 492 return ret;
@@ -527,12 +513,8 @@ static u32 i801_func(struct i2c_adapter *adapter)
527 return I2C_FUNC_SMBUS_QUICK | I2C_FUNC_SMBUS_BYTE | 513 return I2C_FUNC_SMBUS_QUICK | I2C_FUNC_SMBUS_BYTE |
528 I2C_FUNC_SMBUS_BYTE_DATA | I2C_FUNC_SMBUS_WORD_DATA | 514 I2C_FUNC_SMBUS_BYTE_DATA | I2C_FUNC_SMBUS_WORD_DATA |
529 I2C_FUNC_SMBUS_BLOCK_DATA | I2C_FUNC_SMBUS_WRITE_I2C_BLOCK 515 I2C_FUNC_SMBUS_BLOCK_DATA | I2C_FUNC_SMBUS_WRITE_I2C_BLOCK
530#ifdef HAVE_PEC
531 | (isich4 ? I2C_FUNC_SMBUS_BLOCK_DATA_PEC | 516 | (isich4 ? I2C_FUNC_SMBUS_BLOCK_DATA_PEC |
532 I2C_FUNC_SMBUS_HWPEC_CALC 517 I2C_FUNC_SMBUS_HWPEC_CALC : 0);
533 : 0)
534#endif
535 ;
536} 518}
537 519
538static struct i2c_algorithm smbus_algorithm = { 520static struct i2c_algorithm smbus_algorithm = {