From: Eric W. Biederman Date: Sat, 12 Jul 2008 20:47:53 +0000 (-0700) Subject: serial8250: sanity check nr_uarts on all paths. X-Git-Tag: v2.6.26~14 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=05d81d2222beec7b63ac8c1c8cdb5bb4f82c2bad;p=users%2Fhch%2Fdma-mapping.git serial8250: sanity check nr_uarts on all paths. I had 8250.nr_uarts=16 in the boot line of a test kernel and I had a weird mysterious crash in sysfs. After taking an in-depth look I realized that CONFIG_SERIAL_8250_NR_UARTS was set to 4 and I was walking off the end of the serial8250_ports array. Ouch!!! Don't let this happen to someone else. Signed-off-by: Eric W. Biederman Acked-by: Alan Cox Cc: Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds --- diff --git a/drivers/serial/8250.c b/drivers/serial/8250.c index 1bc00b721e9d..be95e55b228b 100644 --- a/drivers/serial/8250.c +++ b/drivers/serial/8250.c @@ -2623,6 +2623,9 @@ static struct console serial8250_console = { static int __init serial8250_console_init(void) { + if (nr_uarts > UART_NR) + nr_uarts = UART_NR; + serial8250_isa_init_ports(); register_console(&serial8250_console); return 0;