diff options
author | Axel Lin <axel.lin@ingics.com> | 2012-11-19 21:34:56 -0500 |
---|---|---|
committer | Samuel Ortiz <sameo@linux.intel.com> | 2012-11-26 06:10:51 -0500 |
commit | 3f9be35bd9090eaa2f68ed9b24efdbf3abcf4b28 (patch) | |
tree | b2a5647e0f05fb5415f315a24700d12ccfa9b2ff /include/linux/mfd | |
parent | 302b95621dc96651187c21fd66e5a44860e4c3b1 (diff) |
mfd: rc5t583: Fix array subscript is above array bounds
I got below build warning while compiling this driver.
It's obviously RC5T583_MAX_INTERRUPT_MASK_REGS is 9 but irq_en_add
array only has 8 elements.
CC drivers/mfd/rc5t583-irq.o
drivers/mfd/rc5t583-irq.c: In function 'rc5t583_irq_sync_unlock':
drivers/mfd/rc5t583-irq.c:227: warning: array subscript is above array bounds
drivers/mfd/rc5t583-irq.c: In function 'rc5t583_irq_init':
drivers/mfd/rc5t583-irq.c:349: warning: array subscript is above array bounds
Since the number of interrupt enable registers is 8, this patch adds
define for RC5T583_MAX_INTERRUPT_EN_REGS to fix this bug.
Signed-off-by: Axel Lin <axel.lin@ingics.com>
Acked-by: Laxman Dewangan <ldewangan@nvidia.com>
Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
Diffstat (limited to 'include/linux/mfd')
-rw-r--r-- | include/linux/mfd/rc5t583.h | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/include/linux/mfd/rc5t583.h b/include/linux/mfd/rc5t583.h index 36c242e52ef1..fd413ccab915 100644 --- a/include/linux/mfd/rc5t583.h +++ b/include/linux/mfd/rc5t583.h | |||
@@ -33,6 +33,7 @@ | |||
33 | /* Maximum number of main interrupts */ | 33 | /* Maximum number of main interrupts */ |
34 | #define MAX_MAIN_INTERRUPT 5 | 34 | #define MAX_MAIN_INTERRUPT 5 |
35 | #define RC5T583_MAX_GPEDGE_REG 2 | 35 | #define RC5T583_MAX_GPEDGE_REG 2 |
36 | #define RC5T583_MAX_INTERRUPT_EN_REGS 8 | ||
36 | #define RC5T583_MAX_INTERRUPT_MASK_REGS 9 | 37 | #define RC5T583_MAX_INTERRUPT_MASK_REGS 9 |
37 | 38 | ||
38 | /* Interrupt enable register */ | 39 | /* Interrupt enable register */ |
@@ -304,7 +305,7 @@ struct rc5t583 { | |||
304 | uint8_t intc_inten_reg; | 305 | uint8_t intc_inten_reg; |
305 | 306 | ||
306 | /* For group interrupt bits and address */ | 307 | /* For group interrupt bits and address */ |
307 | uint8_t irq_en_reg[RC5T583_MAX_INTERRUPT_MASK_REGS]; | 308 | uint8_t irq_en_reg[RC5T583_MAX_INTERRUPT_EN_REGS]; |
308 | 309 | ||
309 | /* For gpio edge */ | 310 | /* For gpio edge */ |
310 | uint8_t gpedge_reg[RC5T583_MAX_GPEDGE_REG]; | 311 | uint8_t gpedge_reg[RC5T583_MAX_GPEDGE_REG]; |