aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGrazvydas Ignotas <notasas@gmail.com>2010-09-28 09:22:19 -0400
committerSamuel Ortiz <sameo@linux.intel.com>2010-10-28 18:30:04 -0400
commit8e52e279b241d3a22d52c10a5f934db18b7d0a1b (patch)
tree7e90a6286246da448c67b8a016a638b23c485406
parenta28dbea0ad3bd8144f3348eb5c20fabc2f12b4b5 (diff)
mfd: Fix TWL4030 COR bit polarity for BCI SIH block
The chip TRM documentation contradicts itself about this bit, page 174 of swcu050e says bit should be 0 for clear-on-read behavior, while page 487 says it should be 1. Testing shows it should be 1, so set the .set_cor flag accordingly. This is needed for upcoming BCI charging driver to function. Signed-off-by: Grazvydas Ignotas <notasas@gmail.com> Acked-by: Tony Lindgren <tony@atomide.com> Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
-rw-r--r--drivers/mfd/twl4030-irq.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/mfd/twl4030-irq.c b/drivers/mfd/twl4030-irq.c
index b9fda7018cef..381ab26e92a3 100644
--- a/drivers/mfd/twl4030-irq.c
+++ b/drivers/mfd/twl4030-irq.c
@@ -144,6 +144,7 @@ static const struct sih sih_modules_twl4030[6] = {
144 .name = "bci", 144 .name = "bci",
145 .module = TWL4030_MODULE_INTERRUPTS, 145 .module = TWL4030_MODULE_INTERRUPTS,
146 .control_offset = TWL4030_INTERRUPTS_BCISIHCTRL, 146 .control_offset = TWL4030_INTERRUPTS_BCISIHCTRL,
147 .set_cor = true,
147 .bits = 12, 148 .bits = 12,
148 .bytes_ixr = 2, 149 .bytes_ixr = 2,
149 .edr_offset = TWL4030_INTERRUPTS_BCIEDR1, 150 .edr_offset = TWL4030_INTERRUPTS_BCIEDR1,
@@ -408,7 +409,7 @@ static int twl4030_init_sih_modules(unsigned line)
408 * set Clear-On-Read (COR) bit. 409 * set Clear-On-Read (COR) bit.
409 * 410 *
410 * NOTE that sometimes COR polarity is documented as being 411 * NOTE that sometimes COR polarity is documented as being
411 * inverted: for MADC and BCI, COR=1 means "clear on write". 412 * inverted: for MADC, COR=1 means "clear on write".
412 * And for PWR_INT it's not documented... 413 * And for PWR_INT it's not documented...
413 */ 414 */
414 if (sih->set_cor) { 415 if (sih->set_cor) {