On Tue, Feb 16, 2016 at 3:09 PM, Vladimir Murzin <vladimir.murzin@xxxxxxx> wrote: > On 16/02/16 10:36, Andy Shevchenko wrote: >> On Tue, Feb 16, 2016 at 12:08 PM, Vladimir Murzin >> <vladimir.murzin@xxxxxxx> wrote: >>> This adds support early console for MPS2 UART which can be enabled via >>> earlycon=mps2,0x40004000 >>> +static void mps2_early_putchar(struct uart_port *port, int ch) >>> +{ >>> + >>> + while (readb(port->membase + UARTn_STATE) & UARTn_STATE_TX_FULL) >>> + cpu_relax(); >> >> Infinite busy loop? > > In case of broken hw, yes, but I'm quite unsure how we can help to fix > it. Do you have something in mind? Set sane amount of loops like int count = 100; … while (… && --count) Though I have no idea what to do if count == 0. Perhaps it's a TX overrun state. You may try to recover by flushing TX queue in HW (fifo and / or Tx shift register) if HW supports it. -- With Best Regards, Andy Shevchenko -- To unsubscribe from this list: send the line "unsubscribe linux-api" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html