aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/i2c
diff options
context:
space:
mode:
authorJon Hunter <jon-hunter@ti.com>2012-06-28 11:11:31 -0400
committerWolfram Sang <w.sang@pengutronix.de>2012-07-12 08:18:27 -0400
commitf518b482c89b3ff51804f09c14b1cedbef811b84 (patch)
tree90ea68e9b4f0b832e222a969a621aa59c47f6339 /drivers/i2c
parent0e33bbb25436949cc100d40edfbe0f96dfa25882 (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>
Diffstat (limited to 'drivers/i2c')
-rw-r--r--drivers/i2c/busses/i2c-omap.c10
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 */