diff options
Diffstat (limited to 'drivers/mfd/twl6030-irq.c')
-rw-r--r-- | drivers/mfd/twl6030-irq.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/drivers/mfd/twl6030-irq.c b/drivers/mfd/twl6030-irq.c index 517eda832f79..18a607e2ca06 100644 --- a/drivers/mfd/twl6030-irq.c +++ b/drivers/mfd/twl6030-irq.c | |||
@@ -176,8 +176,9 @@ static irqreturn_t twl6030_irq_thread(int irq, void *data) | |||
176 | int i, ret; | 176 | int i, ret; |
177 | union { | 177 | union { |
178 | u8 bytes[4]; | 178 | u8 bytes[4]; |
179 | u32 int_sts; | 179 | __le32 int_sts; |
180 | } sts; | 180 | } sts; |
181 | u32 int_sts; /* sts.int_sts converted to CPU endianness */ | ||
181 | struct twl6030_irq *pdata = data; | 182 | struct twl6030_irq *pdata = data; |
182 | 183 | ||
183 | /* read INT_STS_A, B and C in one shot using a burst read */ | 184 | /* read INT_STS_A, B and C in one shot using a burst read */ |
@@ -196,8 +197,9 @@ static irqreturn_t twl6030_irq_thread(int irq, void *data) | |||
196 | if (sts.bytes[2] & 0x10) | 197 | if (sts.bytes[2] & 0x10) |
197 | sts.bytes[2] |= 0x08; | 198 | sts.bytes[2] |= 0x08; |
198 | 199 | ||
199 | for (i = 0; sts.int_sts; sts.int_sts >>= 1, i++) | 200 | int_sts = le32_to_cpu(sts.int_sts); |
200 | if (sts.int_sts & 0x1) { | 201 | for (i = 0; int_sts; int_sts >>= 1, i++) |
202 | if (int_sts & 0x1) { | ||
201 | int module_irq = | 203 | int module_irq = |
202 | irq_find_mapping(pdata->irq_domain, | 204 | irq_find_mapping(pdata->irq_domain, |
203 | pdata->irq_mapping_tbl[i]); | 205 | pdata->irq_mapping_tbl[i]); |