diff options
| author | Robin Gong <b38343@freescale.com> | 2014-07-11 05:47:17 -0400 |
|---|---|---|
| committer | Fugang Duan <b38611@freescale.com> | 2014-07-14 01:08:57 -0400 |
| commit | f7c1dc0720d1f6f9bbe732c67a9115887d6b05d4 (patch) | |
| tree | 489e7a2da8b158be151cde9a5931eda1f6e2044e /drivers/tty | |
| parent | 01864d57b3f15c3ed84a53da1c55368cdd9202c7 (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.c | 15 |
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 | ||
| 943 | static int start_rx_dma(struct imx_port *sport) | 956 | static int start_rx_dma(struct imx_port *sport) |
