diff options
author | Jon Hunter <jon-hunter@ti.com> | 2012-06-28 11:11:31 -0400 |
---|---|---|
committer | Wolfram Sang <w.sang@pengutronix.de> | 2012-07-12 08:18:27 -0400 |
commit | f518b482c89b3ff51804f09c14b1cedbef811b84 (patch) | |
tree | 90ea68e9b4f0b832e222a969a621aa59c47f6339 | |
parent | 0e33bbb25436949cc100d40edfbe0f96dfa25882 (diff) |
i2c: omap: Correct I2C revision for OMAP3
The OMAP3530 is based upon the same silicon as the OMAP3430 and so the I2C
revision is the same for 3430 and 3530. However, the OMAP3630 device has the
same I2C revision as OMAP4. Correct the revision definition to reflect this.
This patch is based on work done by Jon Hunter <jon-hunter@ti.com>
Changes from his patch
- Update OMAP_I2C_REV_ON_3430 also to reflect that it is same as 3530
Reviewed-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Jon Hunter <jon-hunter@ti.com>
Signed-off-by: Shubhrajyoti D <shubhrajyoti@ti.com>
Signed-off-by: Wolfram Sang <w.sang@pengutronix.de>
-rw-r--r-- | drivers/i2c/busses/i2c-omap.c | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/drivers/i2c/busses/i2c-omap.c b/drivers/i2c/busses/i2c-omap.c index 6d05f1878ca0..8c2d7cfb82da 100644 --- a/drivers/i2c/busses/i2c-omap.c +++ b/drivers/i2c/busses/i2c-omap.c | |||
@@ -49,8 +49,8 @@ | |||
49 | 49 | ||
50 | /* I2C controller revisions present on specific hardware */ | 50 | /* I2C controller revisions present on specific hardware */ |
51 | #define OMAP_I2C_REV_ON_2430 0x36 | 51 | #define OMAP_I2C_REV_ON_2430 0x36 |
52 | #define OMAP_I2C_REV_ON_3430 0x3C | 52 | #define OMAP_I2C_REV_ON_3430_3530 0x3C |
53 | #define OMAP_I2C_REV_ON_3530_4430 0x40 | 53 | #define OMAP_I2C_REV_ON_3630_4430 0x40 |
54 | 54 | ||
55 | /* timeout waiting for the controller to respond */ | 55 | /* timeout waiting for the controller to respond */ |
56 | #define OMAP_I2C_TIMEOUT (msecs_to_jiffies(1000)) | 56 | #define OMAP_I2C_TIMEOUT (msecs_to_jiffies(1000)) |
@@ -305,7 +305,7 @@ static int omap_i2c_init(struct omap_i2c_dev *dev) | |||
305 | omap_i2c_write_reg(dev, OMAP_I2C_SYSC_REG, | 305 | omap_i2c_write_reg(dev, OMAP_I2C_SYSC_REG, |
306 | SYSC_AUTOIDLE_MASK); | 306 | SYSC_AUTOIDLE_MASK); |
307 | 307 | ||
308 | } else if (dev->rev >= OMAP_I2C_REV_ON_3430) { | 308 | } else if (dev->rev >= OMAP_I2C_REV_ON_3430_3530) { |
309 | dev->syscstate = SYSC_AUTOIDLE_MASK; | 309 | dev->syscstate = SYSC_AUTOIDLE_MASK; |
310 | dev->syscstate |= SYSC_ENAWAKEUP_MASK; | 310 | dev->syscstate |= SYSC_ENAWAKEUP_MASK; |
311 | dev->syscstate |= (SYSC_IDLEMODE_SMART << | 311 | dev->syscstate |= (SYSC_IDLEMODE_SMART << |
@@ -1020,7 +1020,7 @@ omap_i2c_probe(struct platform_device *pdev) | |||
1020 | if (dev->flags & OMAP_I2C_FLAG_APPLY_ERRATA_I207) | 1020 | if (dev->flags & OMAP_I2C_FLAG_APPLY_ERRATA_I207) |
1021 | dev->errata |= I2C_OMAP_ERRATA_I207; | 1021 | dev->errata |= I2C_OMAP_ERRATA_I207; |
1022 | 1022 | ||
1023 | if (dev->rev <= OMAP_I2C_REV_ON_3430) | 1023 | if (dev->rev <= OMAP_I2C_REV_ON_3430_3530) |
1024 | dev->errata |= I2C_OMAP_ERRATA_I462; | 1024 | dev->errata |= I2C_OMAP_ERRATA_I462; |
1025 | 1025 | ||
1026 | if (!(dev->flags & OMAP_I2C_FLAG_NO_FIFO)) { | 1026 | if (!(dev->flags & OMAP_I2C_FLAG_NO_FIFO)) { |
@@ -1038,7 +1038,7 @@ omap_i2c_probe(struct platform_device *pdev) | |||
1038 | 1038 | ||
1039 | dev->fifo_size = (dev->fifo_size / 2); | 1039 | dev->fifo_size = (dev->fifo_size / 2); |
1040 | 1040 | ||
1041 | if (dev->rev >= OMAP_I2C_REV_ON_3530_4430) | 1041 | if (dev->rev >= OMAP_I2C_REV_ON_3630_4430) |
1042 | dev->b_hw = 0; /* Disable hardware fixes */ | 1042 | dev->b_hw = 0; /* Disable hardware fixes */ |
1043 | else | 1043 | else |
1044 | dev->b_hw = 1; /* Enable hardware fixes */ | 1044 | dev->b_hw = 1; /* Enable hardware fixes */ |