aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/serial
diff options
context:
space:
mode:
authorSonic Zhang <sonic.zhang@analog.com>2009-06-11 08:45:07 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2009-06-11 11:51:04 -0400
commit0efa4f2c944fabffc81918cc86d4d17dba39a021 (patch)
treed5d2c07d6177eb04555b4a6483db9aaea1d434f1 /drivers/serial
parent35ff69357949cfff5c3d8e3038b77146872e3bd3 (diff)
Blackfin Serial Driver: annotate anomalies 05000215 and 05000099
Add some comments for how these anomalies are addressed: 05000215 - UART TX Interrupt Masked Erroneously We always clear ETBEI within last UART TX interrupt to end a string. It is always set when starting a new tx transfer. 05000099 - UART Line Status Register (UART_LSR) Bits Are Not Updated at the Same Time This anomaly affects driver only in POLL code where multi bits of UART_LSR are checked. It doesn't affect current bfin_5xx.c driver. Signed-off-by: Sonic Zhang <sonic.zhang@analog.com> Signed-off-by: Mike Frysinger <vapier@gentoo.org> Signed-off-by: Alan Cox <alan@linux.intel.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/serial')
-rw-r--r--drivers/serial/bfin_5xx.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/drivers/serial/bfin_5xx.c b/drivers/serial/bfin_5xx.c
index 854e96dfb070..ab583ef3a305 100644
--- a/drivers/serial/bfin_5xx.c
+++ b/drivers/serial/bfin_5xx.c
@@ -330,6 +330,11 @@ static void bfin_serial_tx_chars(struct bfin_serial_port *uart)
330 /* Clear TFI bit */ 330 /* Clear TFI bit */
331 UART_PUT_LSR(uart, TFI); 331 UART_PUT_LSR(uart, TFI);
332#endif 332#endif
333 /* Anomaly notes:
334 * 05000215 - we always clear ETBEI within last UART TX
335 * interrupt to end a string. It is always set
336 * when start a new tx.
337 */
333 UART_CLEAR_IER(uart, ETBEI); 338 UART_CLEAR_IER(uart, ETBEI);
334 return; 339 return;
335 } 340 }
@@ -528,6 +533,11 @@ static irqreturn_t bfin_serial_dma_tx_int(int irq, void *dev_id)
528 if (!(get_dma_curr_irqstat(uart->tx_dma_channel)&DMA_RUN)) { 533 if (!(get_dma_curr_irqstat(uart->tx_dma_channel)&DMA_RUN)) {
529 disable_dma(uart->tx_dma_channel); 534 disable_dma(uart->tx_dma_channel);
530 clear_dma_irqstat(uart->tx_dma_channel); 535 clear_dma_irqstat(uart->tx_dma_channel);
536 /* Anomaly notes:
537 * 05000215 - we always clear ETBEI within last UART TX
538 * interrupt to end a string. It is always set
539 * when start a new tx.
540 */
531 UART_CLEAR_IER(uart, ETBEI); 541 UART_CLEAR_IER(uart, ETBEI);
532 xmit->tail = (xmit->tail + uart->tx_count) & (UART_XMIT_SIZE - 1); 542 xmit->tail = (xmit->tail + uart->tx_count) & (UART_XMIT_SIZE - 1);
533 uart->port.icount.tx += uart->tx_count; 543 uart->port.icount.tx += uart->tx_count;
@@ -969,6 +979,10 @@ static void bfin_serial_reset_irda(struct uart_port *port)
969} 979}
970 980
971#ifdef CONFIG_CONSOLE_POLL 981#ifdef CONFIG_CONSOLE_POLL
982/* Anomaly notes:
983 * 05000099 - Because we only use THRE in poll_put and DR in poll_get,
984 * losing other bits of UART_LSR is not a problem here.
985 */
972static void bfin_serial_poll_put_char(struct uart_port *port, unsigned char chr) 986static void bfin_serial_poll_put_char(struct uart_port *port, unsigned char chr)
973{ 987{
974 struct bfin_serial_port *uart = (struct bfin_serial_port *)port; 988 struct bfin_serial_port *uart = (struct bfin_serial_port *)port;