diff options
author | Grazvydas Ignotas <notasas@gmail.com> | 2010-09-28 09:22:19 -0400 |
---|---|---|
committer | Samuel Ortiz <sameo@linux.intel.com> | 2010-10-28 18:30:04 -0400 |
commit | 8e52e279b241d3a22d52c10a5f934db18b7d0a1b (patch) | |
tree | 7e90a6286246da448c67b8a016a638b23c485406 /drivers/mfd | |
parent | a28dbea0ad3bd8144f3348eb5c20fabc2f12b4b5 (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>
Diffstat (limited to 'drivers/mfd')
-rw-r--r-- | drivers/mfd/twl4030-irq.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/mfd/twl4030-irq.c b/drivers/mfd/twl4030-irq.c index b9fda7018ce..381ab26e92a 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) { |