mirror of
https://github.com/torvalds/linux.git
synced 2024-11-19 02:21:47 +00:00
omap2/3/4: serial: introduce errata handling
introduce silicon specific quirks as a errata handling mechanism as a start UART_ERRATA_FIFO_FULL_ABORT is used to handle the override for fifo full condition for rx and tx. Signed-off-by: Nishanth Menon <nm@ti.com> Signed-off-by: Tony Lindgren <tony@atomide.com>
This commit is contained in:
parent
bfe6977ac7
commit
5a927b36f5
@ -37,6 +37,8 @@
|
|||||||
#define UART_OMAP_NO_EMPTY_FIFO_READ_IP_REV 0x52
|
#define UART_OMAP_NO_EMPTY_FIFO_READ_IP_REV 0x52
|
||||||
#define UART_OMAP_WER 0x17 /* Wake-up enable register */
|
#define UART_OMAP_WER 0x17 /* Wake-up enable register */
|
||||||
|
|
||||||
|
#define UART_ERRATA_FIFO_FULL_ABORT (0x1 << 0)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* NOTE: By default the serial timeout is disabled as it causes lost characters
|
* NOTE: By default the serial timeout is disabled as it causes lost characters
|
||||||
* over the serial ports. This means that the UART clocks will stay on until
|
* over the serial ports. This means that the UART clocks will stay on until
|
||||||
@ -64,6 +66,7 @@ struct omap_uart_state {
|
|||||||
struct list_head node;
|
struct list_head node;
|
||||||
struct platform_device pdev;
|
struct platform_device pdev;
|
||||||
|
|
||||||
|
u32 errata;
|
||||||
#if defined(CONFIG_ARCH_OMAP3) && defined(CONFIG_PM)
|
#if defined(CONFIG_ARCH_OMAP3) && defined(CONFIG_PM)
|
||||||
int context_valid;
|
int context_valid;
|
||||||
|
|
||||||
@ -756,11 +759,13 @@ void __init omap_serial_init_port(int port)
|
|||||||
* omap3xxx: Never read empty UART fifo on UARTs
|
* omap3xxx: Never read empty UART fifo on UARTs
|
||||||
* with IP rev >=0x52
|
* with IP rev >=0x52
|
||||||
*/
|
*/
|
||||||
if (cpu_is_omap44xx()) {
|
if (cpu_is_omap44xx())
|
||||||
uart->p->serial_in = serial_in_override;
|
uart->errata |= UART_ERRATA_FIFO_FULL_ABORT;
|
||||||
uart->p->serial_out = serial_out_override;
|
else if ((serial_read_reg(uart->p, UART_OMAP_MVER) & 0xFF)
|
||||||
} else if ((serial_read_reg(uart->p, UART_OMAP_MVER) & 0xFF)
|
>= UART_OMAP_NO_EMPTY_FIFO_READ_IP_REV)
|
||||||
>= UART_OMAP_NO_EMPTY_FIFO_READ_IP_REV) {
|
uart->errata |= UART_ERRATA_FIFO_FULL_ABORT;
|
||||||
|
|
||||||
|
if (uart->errata & UART_ERRATA_FIFO_FULL_ABORT) {
|
||||||
uart->p->serial_in = serial_in_override;
|
uart->p->serial_in = serial_in_override;
|
||||||
uart->p->serial_out = serial_out_override;
|
uart->p->serial_out = serial_out_override;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user