From: Paul Walmsley Date: Tue, 22 Jul 2008 23:51:29 +0000 (-0600) Subject: TWL4030: use correct register addresses for BCI IMR registers X-Git-Tag: v2.6.26-omap1~61 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=1cdf2aa5864a257f9ffaa3b476add8a08923a2d3;p=linux-2.6-omap-h63xx.git TWL4030: use correct register addresses for BCI IMR registers The existing code to mask and clear BCI interrupts in twl_init_irq() is wrong. It uses the wrong register offsets, it does not mask all of the BCI IMR registers, and it does not clear all of the BCI ISR registers. Signed-off-by: Paul Walmsley Signed-off-by: Tony Lindgren --- diff --git a/drivers/i2c/chips/twl4030-core.c b/drivers/i2c/chips/twl4030-core.c index dfc38057c22..bb0732c6521 100644 --- a/drivers/i2c/chips/twl4030-core.c +++ b/drivers/i2c/chips/twl4030-core.c @@ -750,29 +750,57 @@ static void twl_init_irq(void) /* POWER HACK (END) */ /* Slave address 0x4A */ - /* BCIIMR1_1 */ + /* BCIIMR1A */ + res = twl4030_i2c_write_u8(TWL4030_MODULE_INTERRUPTS, 0xFF, 0x2); + if (res < 0) { + pr_err("%s[%d][%d]\n", msg, res, __LINE__); + return; + } + + /* BCIIMR2A */ res = twl4030_i2c_write_u8(TWL4030_MODULE_INTERRUPTS, 0xFF, 0x3); if (res < 0) { pr_err("%s[%d][%d]\n", msg, res, __LINE__); return; } - /* BCIIMR1_2 */ - res = twl4030_i2c_write_u8(TWL4030_MODULE_INTERRUPTS, 0xFF, 0x4); + /* BCIIMR1B */ + res = twl4030_i2c_write_u8(TWL4030_MODULE_INTERRUPTS, 0xFF, 0x6); if (res < 0) { pr_err("%s[%d][%d]\n", msg, res, __LINE__); return; } - /* BCIIMR2_1 */ + /* BCIIMR2B */ res = twl4030_i2c_write_u8(TWL4030_MODULE_INTERRUPTS, 0xFF, 0x7); if (res < 0) { pr_err("%s[%d][%d]\n", msg, res, __LINE__); return; } - /* BCIIMR2_2 */ - res = twl4030_i2c_write_u8(TWL4030_MODULE_INTERRUPTS, 0xFF, 0x8); + /* BCIISR1A */ + res = twl4030_i2c_write_u8(TWL4030_MODULE_INTERRUPTS, 0xFF, 0x0); + if (res < 0) { + pr_err("%s[%d][%d]\n", msg, res, __LINE__); + return; + } + + /* BCIISR2A */ + res = twl4030_i2c_write_u8(TWL4030_MODULE_INTERRUPTS, 0xFF, 0x1); + if (res < 0) { + pr_err("%s[%d][%d]\n", msg, res, __LINE__); + return; + } + + /* BCIISR1B */ + res = twl4030_i2c_write_u8(TWL4030_MODULE_INTERRUPTS, 0xFF, 0x4); + if (res < 0) { + pr_err("%s[%d][%d]\n", msg, res, __LINE__); + return; + } + + /* BCIISR2B */ + res = twl4030_i2c_write_u8(TWL4030_MODULE_INTERRUPTS, 0xFF, 0x5); if (res < 0) { pr_err("%s[%d][%d]\n", msg, res, __LINE__); return;