Commit 361de091 authored by Rafał Miłecki's avatar Rafał Miłecki Committed by Kalle Valo

bcma: fix buffer size caused crash in bcma_core_mips_print_irq()

Used buffer wasn't big enough to hold whole strings. Example output of
this function is:
[    0.180892] bcma: bus0: core 0x0800, irq: 2(S)* 3  4  5  6  D  I
[    0.180948] bcma: bus0: core 0x0812, irq: 2(S)  3* 4  5  6  D  I
[    0.180998] bcma: bus0: core 0x082d, irq: 2(S)  3  4* 5  6  D  I
[    0.181046] bcma: bus0: core 0x082c, irq: 2(S)  3  4  5  6  D  I*
which means we need to store up to 24 chars.

Fixes: 758f7e06 ("bcma: Use bcma_debug and not pr_cont in MIPS driver")
Signed-off-by: default avatarRafał Miłecki <rafal@milecki.pl>
Cc: stable@vger.kernel.org # v4.15+
Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
parent a8d7aa17
...@@ -184,7 +184,7 @@ static void bcma_core_mips_print_irq(struct bcma_device *dev, unsigned int irq) ...@@ -184,7 +184,7 @@ static void bcma_core_mips_print_irq(struct bcma_device *dev, unsigned int irq)
{ {
int i; int i;
static const char *irq_name[] = {"2(S)", "3", "4", "5", "6", "D", "I"}; static const char *irq_name[] = {"2(S)", "3", "4", "5", "6", "D", "I"};
char interrupts[20]; char interrupts[25];
char *ints = interrupts; char *ints = interrupts;
for (i = 0; i < ARRAY_SIZE(irq_name); i++) for (i = 0; i < ARRAY_SIZE(irq_name); i++)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment