aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/tty
diff options
context:
space:
mode:
authorRobin Gong <b38343@freescale.com>2014-07-11 05:47:17 -0400
committerFugang Duan <b38611@freescale.com>2014-07-14 01:08:57 -0400
commitf7c1dc0720d1f6f9bbe732c67a9115887d6b05d4 (patch)
tree489e7a2da8b158be151cde9a5931eda1f6e2044e /drivers/tty
parent01864d57b3f15c3ed84a53da1c55368cdd9202c7 (diff)
ENGR00322581-03 tty: serial: imx: start rx_dma once RXFIFO is not empty
Start rx_dma once RXFIFO is not empty that can avoid dma request lost and causes data delay issue. Signed-off-by: Robin Gong <b38343@freescale.com> Signed-off-by: Fugang Duan <B38611@freescale.com>
Diffstat (limited to 'drivers/tty')
-rw-r--r--drivers/tty/serial/imx.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/drivers/tty/serial/imx.c b/drivers/tty/serial/imx.c
index 81ee2f23d0a8..c73c05b33c49 100644
--- a/drivers/tty/serial/imx.c
+++ b/drivers/tty/serial/imx.c
@@ -936,8 +936,21 @@ static void dma_rx_callback(void *data)
936 tty_flip_buffer_push(port); 936 tty_flip_buffer_push(port);
937 937
938 start_rx_dma(sport); 938 start_rx_dma(sport);
939 } else 939 } else if (readl(sport->port.membase + USR2) & USR2_RDR) {
940 /*
941 * start rx_dma directly once data in RXFIFO, more efficient
942 * than before:
943 * 1. call imx_rx_dma_done to stop dma if no data received
944 * 2. wait next RDR interrupt to start dma transfer.
945 */
946 start_rx_dma(sport);
947 } else {
948 /*
949 * stop dma to prevent too many IDLE event trigged if no data
950 * in RXFIFO
951 */
940 imx_rx_dma_done(sport); 952 imx_rx_dma_done(sport);
953 }
941} 954}
942 955
943static int start_rx_dma(struct imx_port *sport) 956static int start_rx_dma(struct imx_port *sport)