On Fri, Mar 15, 2013 at 01:24:52PM -0700, Greg Kroah-Hartman wrote: > On Thu, Feb 28, 2013 at 02:34:21PM +0200, Heikki Krogerus wrote: > > Hi, > > > > On Thu, Feb 28, 2013 at 12:42:06PM +0100, Gregory CLEMENT wrote: > > > >> Would you agree with this kind of patch to fix the issue? > > > >> > > > >> diff --git a/drivers/tty/serial/8250/8250.c b/drivers/tty/serial/8250/8250.c > > > >> index e2ac25a..0b284c6 100644 > > > >> --- a/drivers/tty/serial/8250/8250.c > > > >> +++ b/drivers/tty/serial/8250/8250.c > > > >> @@ -1119,7 +1119,7 @@ static void autoconfig(struct uart_8250_port *up, unsigned int probeflags) > > > >> serial_out(up, UART_LCR, 0); > > > >> > > > >> serial_out(up, UART_FCR, UART_FCR_ENABLE_FIFO); > > > >> - scratch = serial_in(up, UART_IIR) >> 6; > > > >> + scratch = (serial_in(up, UART_IIR) & 0xFF) >> 6; > > > >> > > > >> switch (scratch) { > > > >> case 0: > > > > > > > > Instead, can you test if it's enough for you to set the reg-io-width > > > > to 1 instead of 4: > > > > > > Yes indeed it worked and it seems to be the correct description of my > > > hardware. So I will fix the dtsi file. > > > > > > However isn't buggy to use a function as it returned a char whereas > > > it returns an int? > > > > Yes, the driver should probable be cleaned. > > > > It seems to be happening in quite a few places in 8250.c. > > autoconfig_16550a() has pretty much identical code in it, where > > UART_IIR is read to unsigned char and shifted without a mask. > > Can someone send me the correct fix here, if they want it included in > 3.9-final? The fix is in arm-soc/fixes slated for merging into 3.9: commit e366154f70c54dee3665d1c0f780007e514412f3 Author: Heikki Krogerus <heikki.krogerus@xxxxxxxxxxxxxxx> Date: Wed Mar 6 11:23:33 2013 +0100 arm: mvebu: Reduce reg-io-width with UARTs Setting the reg-io-width to 1 byte represents more accurate description of the HW. This will fix an issue where UART driver causes kernel panic during bootup. Gregory CLEMENT traced the issue to autoconfig() in 8250.c, where the existence of FIFO is checked from UART_IIR register. The register is now read as 32-bit value as the reg-io-width is set to 4-bytes. The retuned value seems to contain bogus data for bits 31:8, causing the issue. Signed-off-by: Heikki Krogerus <heikki.krogerus@xxxxxxxxxxxxxxx> Cc: Gregory CLEMENT <gregory.clement@xxxxxxxxxxxxxxxxxx> Cc: Masami Hiramatsu <masami.hiramatsu.pt@xxxxxxxxxxx> Tested-by: Gregory CLEMENT <gregory.clement@xxxxxxxxxxxxxxxxxx> Acked-by: Gregory CLEMENT <gregory.clement@xxxxxxxxxxxxxxxxxx> Tested-by: Masami Hiramatsu <masami.hiramatsu.pt@xxxxxxxxxxx> Tested-by: Thomas Petazzoni <thomas.petazzoni@xxxxxxxxxxxxxxxxxx> Signed-off-by: Jason Cooper <jason@xxxxxxxxxxxxxx> arch/arm/boot/dts/armada-370-xp.dtsi | 4 ++-- arch/arm/boot/dts/armada-xp.dtsi | 4 ++-- thx, Jason. -- To unsubscribe from this list: send the line "unsubscribe linux-serial" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html