svn commit: r352862 - stable/11/sys/dev/uart

Alexander Motin mav at FreeBSD.org
Sun Sep 29 02:56:23 UTC 2019


Author: mav
Date: Sun Sep 29 02:56:23 2019
New Revision: 352862
URL: https://svnweb.freebsd.org/changeset/base/352862

Log:
  MFC r352369: Relax TX draining in ns8250_bus_transmit().
  
  Since TX interrupt is generated when THRE is set, wait for TEMT set means
  wait for full character transmission time.  At low speeds that may take
  awhile, burning CPU time while holding sc_hwmtx lock, also congested.
  
  This is partial revert of r317659.

Modified:
  stable/11/sys/dev/uart/uart_dev_ns8250.c
Directory Properties:
  stable/11/   (props changed)

Modified: stable/11/sys/dev/uart/uart_dev_ns8250.c
==============================================================================
--- stable/11/sys/dev/uart/uart_dev_ns8250.c	Sun Sep 29 02:55:57 2019	(r352861)
+++ stable/11/sys/dev/uart/uart_dev_ns8250.c	Sun Sep 29 02:56:23 2019	(r352862)
@@ -988,13 +988,8 @@ ns8250_bus_transmit(struct uart_softc *sc)
 
 	bas = &sc->sc_bas;
 	uart_lock(sc->sc_hwmtx);
-	if (sc->sc_txdatasz > 1) {
-		if ((uart_getreg(bas, REG_LSR) & LSR_TEMT) == 0)
-			ns8250_drain(bas, UART_DRAIN_TRANSMITTER);
-	} else {
-		while ((uart_getreg(bas, REG_LSR) & LSR_THRE) == 0)
-			DELAY(4);
-	}
+	while ((uart_getreg(bas, REG_LSR) & LSR_THRE) == 0)
+		DELAY(4);
 	for (i = 0; i < sc->sc_txdatasz; i++) {
 		uart_setreg(bas, REG_DATA, sc->sc_txbuf[i]);
 		uart_barrier(bas);


More information about the svn-src-all mailing list