diff options
| author | Dmitry Torokhov <[email protected]> | 2023-08-30 16:06:38 -0700 | 
|---|---|---|
| committer | Dmitry Torokhov <[email protected]> | 2023-08-30 16:06:38 -0700 | 
| commit | 1ac731c529cd4d6adbce134754b51ff7d822b145 (patch) | |
| tree | 143ab3f35ca5f3b69f583c84e6964b17139c2ec1 /drivers/tty/serial/stm32-usart.c | |
| parent | 07b4c950f27bef0362dc6ad7ee713aab61d58149 (diff) | |
| parent | 54116d442e001e1b6bd482122043b1870998a1f3 (diff) | |
Merge branch 'next' into for-linus
Prepare input updates for 6.6 merge window.
Diffstat (limited to 'drivers/tty/serial/stm32-usart.c')
| -rw-r--r-- | drivers/tty/serial/stm32-usart.c | 6 | 
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/tty/serial/stm32-usart.c b/drivers/tty/serial/stm32-usart.c index 767ff9fdb2e5..1e38fc9b10c1 100644 --- a/drivers/tty/serial/stm32-usart.c +++ b/drivers/tty/serial/stm32-usart.c @@ -693,8 +693,9 @@ static void stm32_usart_transmit_chars(struct uart_port *port)  	int ret;  	if (!stm32_port->hw_flow_control && -	    port->rs485.flags & SER_RS485_ENABLED) { -		stm32_port->txdone = false; +	    port->rs485.flags & SER_RS485_ENABLED && +	    (port->x_char || +	     !(uart_circ_empty(xmit) || uart_tx_stopped(port)))) {  		stm32_usart_tc_interrupt_disable(port);  		stm32_usart_rs485_rts_enable(port);  	} @@ -743,7 +744,6 @@ static void stm32_usart_transmit_chars(struct uart_port *port)  		stm32_usart_tx_interrupt_disable(port);  		if (!stm32_port->hw_flow_control &&  		    port->rs485.flags & SER_RS485_ENABLED) { -			stm32_port->txdone = true;  			stm32_usart_tc_interrupt_enable(port);  		}  	}  |