From: Huang Shijie Date: Fri, 11 Oct 2013 10:31:00 +0000 (+0800) Subject: serial: imx: fix the wrong number of scatterlist entries when xmit->head is 0 X-Git-Url: http://git.cdn.openwrt.org/?a=commitdiff_plain;h=947c74eba85bff743bc15adbdd9193ffff60c29f;p=openwrt%2Fstaging%2Fblogic.git serial: imx: fix the wrong number of scatterlist entries when xmit->head is 0 When the (xmit->tail > xmit->head) is true and the xmit->head is 0, we only need one DMA scatterlist in actually. Current code uses two DMA scatterlists in this case, this is obviously wrong. This patch fixes it. Signed-off-by: Huang Shijie Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/tty/serial/imx.c b/drivers/tty/serial/imx.c index c6c3b160dac7..cadf7e5848b2 100644 --- a/drivers/tty/serial/imx.c +++ b/drivers/tty/serial/imx.c @@ -532,7 +532,7 @@ static void dma_tx_work(struct work_struct *w) return; } - if (xmit->tail > xmit->head) { + if (xmit->tail > xmit->head && xmit->head > 0) { sport->dma_tx_nents = 2; sg_init_table(sgl, 2); sg_set_buf(sgl, xmit->buf + xmit->tail,