提交 1f74dfa8 编写于 作者: L Long Cheng 提交者: Greg Kroah-Hartman

serial: 8250-mtk: modify uart DMA rx

Modify uart rx and complete for DMA
Signed-off-by: NLong Cheng <long.cheng@mediatek.com>
Reviewed-by: NVinod Koul <vkoul@kernel.org>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 c7ad9ba0
...@@ -47,7 +47,6 @@ ...@@ -47,7 +47,6 @@
#define MTK_UART_DMA_EN_RX 0x5 #define MTK_UART_DMA_EN_RX 0x5
#define MTK_UART_ESCAPE_CHAR 0x77 /* Escape char added under sw fc */ #define MTK_UART_ESCAPE_CHAR 0x77 /* Escape char added under sw fc */
#define MTK_UART_TX_SIZE UART_XMIT_SIZE
#define MTK_UART_RX_SIZE 0x8000 #define MTK_UART_RX_SIZE 0x8000
#define MTK_UART_TX_TRIGGER 1 #define MTK_UART_TX_TRIGGER 1
#define MTK_UART_RX_TRIGGER MTK_UART_RX_SIZE #define MTK_UART_RX_TRIGGER MTK_UART_RX_SIZE
...@@ -89,28 +88,30 @@ static void mtk8250_dma_rx_complete(void *param) ...@@ -89,28 +88,30 @@ static void mtk8250_dma_rx_complete(void *param)
struct mtk8250_data *data = up->port.private_data; struct mtk8250_data *data = up->port.private_data;
struct tty_port *tty_port = &up->port.state->port; struct tty_port *tty_port = &up->port.state->port;
struct dma_tx_state state; struct dma_tx_state state;
int copied, total, cnt;
unsigned char *ptr; unsigned char *ptr;
int copied;
dma_sync_single_for_cpu(dma->rxchan->device->dev, dma->rx_addr, if (data->rx_status == DMA_RX_SHUTDOWN)
dma->rx_size, DMA_FROM_DEVICE); return;
dmaengine_tx_status(dma->rxchan, dma->rx_cookie, &state); dmaengine_tx_status(dma->rxchan, dma->rx_cookie, &state);
total = dma->rx_size - state.residue;
cnt = total;
if (data->rx_status == DMA_RX_SHUTDOWN) if ((data->rx_pos + cnt) > dma->rx_size)
return; cnt = dma->rx_size - data->rx_pos;
if ((data->rx_pos + state.residue) <= dma->rx_size) { ptr = (unsigned char *)(data->rx_pos + dma->rx_buf);
ptr = (unsigned char *)(data->rx_pos + dma->rx_buf); copied = tty_insert_flip_string(tty_port, ptr, cnt);
copied = tty_insert_flip_string(tty_port, ptr, state.residue); data->rx_pos += cnt;
} else {
ptr = (unsigned char *)(data->rx_pos + dma->rx_buf); if (total > cnt) {
copied = tty_insert_flip_string(tty_port, ptr,
dma->rx_size - data->rx_pos);
ptr = (unsigned char *)(dma->rx_buf); ptr = (unsigned char *)(dma->rx_buf);
copied += tty_insert_flip_string(tty_port, ptr, cnt = total - cnt;
data->rx_pos + state.residue - dma->rx_size); copied += tty_insert_flip_string(tty_port, ptr, cnt);
data->rx_pos = cnt;
} }
up->port.icount.rx += copied; up->port.icount.rx += copied;
tty_flip_buffer_push(tty_port); tty_flip_buffer_push(tty_port);
...@@ -121,9 +122,7 @@ static void mtk8250_dma_rx_complete(void *param) ...@@ -121,9 +122,7 @@ static void mtk8250_dma_rx_complete(void *param)
static void mtk8250_rx_dma(struct uart_8250_port *up) static void mtk8250_rx_dma(struct uart_8250_port *up)
{ {
struct uart_8250_dma *dma = up->dma; struct uart_8250_dma *dma = up->dma;
struct mtk8250_data *data = up->port.private_data;
struct dma_async_tx_descriptor *desc; struct dma_async_tx_descriptor *desc;
struct dma_tx_state state;
desc = dmaengine_prep_slave_single(dma->rxchan, dma->rx_addr, desc = dmaengine_prep_slave_single(dma->rxchan, dma->rx_addr,
dma->rx_size, DMA_DEV_TO_MEM, dma->rx_size, DMA_DEV_TO_MEM,
...@@ -138,12 +137,6 @@ static void mtk8250_rx_dma(struct uart_8250_port *up) ...@@ -138,12 +137,6 @@ static void mtk8250_rx_dma(struct uart_8250_port *up)
dma->rx_cookie = dmaengine_submit(desc); dma->rx_cookie = dmaengine_submit(desc);
dmaengine_tx_status(dma->rxchan, dma->rx_cookie, &state);
data->rx_pos = state.residue;
dma_sync_single_for_device(dma->rxchan->device->dev, dma->rx_addr,
dma->rx_size, DMA_FROM_DEVICE);
dma_async_issue_pending(dma->rxchan); dma_async_issue_pending(dma->rxchan);
} }
...@@ -156,13 +149,11 @@ static void mtk8250_dma_enable(struct uart_8250_port *up) ...@@ -156,13 +149,11 @@ static void mtk8250_dma_enable(struct uart_8250_port *up)
if (data->rx_status != DMA_RX_START) if (data->rx_status != DMA_RX_START)
return; return;
dma->rxconf.direction = DMA_DEV_TO_MEM; dma->rxconf.src_port_window_size = dma->rx_size;
dma->rxconf.src_addr_width = dma->rx_size / 1024; dma->rxconf.src_addr = dma->rx_addr;
dma->rxconf.src_addr = dma->rx_addr;
dma->txconf.direction = DMA_MEM_TO_DEV; dma->txconf.dst_port_window_size = UART_XMIT_SIZE;
dma->txconf.dst_addr_width = MTK_UART_TX_SIZE / 1024; dma->txconf.dst_addr = dma->tx_addr;
dma->txconf.dst_addr = dma->tx_addr;
serial_out(up, UART_FCR, UART_FCR_ENABLE_FIFO | UART_FCR_CLEAR_RCVR | serial_out(up, UART_FCR, UART_FCR_ENABLE_FIFO | UART_FCR_CLEAR_RCVR |
UART_FCR_CLEAR_XMIT); UART_FCR_CLEAR_XMIT);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册