mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-26 18:43:33 -05:00
mfd: twl6030: Fix endianness problem in IRQ handler
The current TWL 6030 IRQ handler assumes little endianness. This change makes it endian-neutral. Signed-off-by: Danke Xie <d.xie@sta.samsung.com> Signed-off-by: Taras Kondratiuk <taras.kondratiuk@linaro.org> Signed-off-by: Lee Jones <lee.jones@linaro.org>
This commit is contained in:
parent
39fed00f0b
commit
754fa7bc98
1 changed files with 5 additions and 3 deletions
|
@ -176,8 +176,9 @@ static irqreturn_t twl6030_irq_thread(int irq, void *data)
|
|||
int i, ret;
|
||||
union {
|
||||
u8 bytes[4];
|
||||
u32 int_sts;
|
||||
__le32 int_sts;
|
||||
} sts;
|
||||
u32 int_sts; /* sts.int_sts converted to CPU endianness */
|
||||
struct twl6030_irq *pdata = data;
|
||||
|
||||
/* 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)
|
|||
if (sts.bytes[2] & 0x10)
|
||||
sts.bytes[2] |= 0x08;
|
||||
|
||||
for (i = 0; sts.int_sts; sts.int_sts >>= 1, i++)
|
||||
if (sts.int_sts & 0x1) {
|
||||
int_sts = le32_to_cpu(sts.int_sts);
|
||||
for (i = 0; int_sts; int_sts >>= 1, i++)
|
||||
if (int_sts & 0x1) {
|
||||
int module_irq =
|
||||
irq_find_mapping(pdata->irq_domain,
|
||||
pdata->irq_mapping_tbl[i]);
|
||||
|
|
Loading…
Add table
Reference in a new issue