From mboxrd@z Thu Jan 1 00:00:00 1970 From: peter@hurleysoftware.com (Peter Hurley) Date: Thu, 19 Nov 2015 18:15:09 -0500 Subject: [PATH RESEND v2 03/10] tty: xuartps: Always enable transmitter in start_tx In-Reply-To: <1447963344-16266-4-git-send-email-soren.brinkmann@xilinx.com> References: <1447963344-16266-1-git-send-email-soren.brinkmann@xilinx.com> <1447963344-16266-4-git-send-email-soren.brinkmann@xilinx.com> Message-ID: <564E57FD.8080900@hurleysoftware.com> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org On 11/19/2015 03:02 PM, Soren Brinkmann wrote: > start_tx must start transmitting characters. Regardless of the state of > the circular buffer, always enable the transmitter hardware. Why? Does cdns_uart_stop_tx() actually stop the transmitter so that data is remains in the transmitter? > Signed-off-by: Soren Brinkmann > --- > drivers/tty/serial/xilinx_uartps.c | 6 +++--- > 1 file changed, 3 insertions(+), 3 deletions(-) > > diff --git a/drivers/tty/serial/xilinx_uartps.c b/drivers/tty/serial/xilinx_uartps.c > index 2c98c357d9a0..df6778d17949 100644 > --- a/drivers/tty/serial/xilinx_uartps.c > +++ b/drivers/tty/serial/xilinx_uartps.c > @@ -512,9 +512,6 @@ static void cdns_uart_start_tx(struct uart_port *port) > { > unsigned int status, numbytes = port->fifosize; > > - if (uart_circ_empty(&port->state->xmit) || uart_tx_stopped(port)) > - return; The test for tx stopped needs to remain; otherwise, transmission will restart even if the tty has been stopped (for example by userspace) or IXON software flow control. Regards, Peter Hurley > - > /* > * Set the TX enable bit and clear the TX disable bit to enable the > * transmitter. > @@ -524,6 +521,9 @@ static void cdns_uart_start_tx(struct uart_port *port) > status |= CDNS_UART_CR_TX_EN; > writel(status, port->membase + CDNS_UART_CR_OFFSET); > > + if (uart_circ_empty(&port->state->xmit) || uart_tx_stopped(port)) > + return; > + > while (numbytes-- && ((readl(port->membase + CDNS_UART_SR_OFFSET) & > CDNS_UART_SR_TXFULL)) != CDNS_UART_SR_TXFULL) { > /* Break if no more data available in the UART buffer */ >