Module Name:    src
Committed By:   riastradh
Date:           Fri Feb 17 23:38:55 UTC 2023

Modified Files:
        src/sys/dev/usb: ucom.c

Log Message:
ucom(4): Nix broken error branch.

This error branch was introduced to make the system act, when a USB
serial adapter is yanked, as if the other end had spat out a line
feed in an attempt to wake any sleeping readers so they will stop
using the USB serial port.

This is no longer necessary, because ttycancel will wake them anyway,
and it is actually harmful because it puts stuff in the output queue
(CR LF) that will never be processed, causing subsequent users to
hang trying to open the device.

Problem found and patch tested by tih@.


To generate a diff of this commit:
cvs rdiff -u -r1.134 -r1.135 src/sys/dev/usb/ucom.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/dev/usb/ucom.c
diff -u src/sys/dev/usb/ucom.c:1.134 src/sys/dev/usb/ucom.c:1.135
--- src/sys/dev/usb/ucom.c:1.134	Wed Oct 26 23:48:43 2022
+++ src/sys/dev/usb/ucom.c	Fri Feb 17 23:38:54 2023
@@ -1,4 +1,4 @@
-/*	$NetBSD: ucom.c,v 1.134 2022/10/26 23:48:43 riastradh Exp $	*/
+/*	$NetBSD: ucom.c,v 1.135 2023/02/17 23:38:54 riastradh Exp $	*/
 
 /*
  * Copyright (c) 1998, 2000 The NetBSD Foundation, Inc.
@@ -34,7 +34,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ucom.c,v 1.134 2022/10/26 23:48:43 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ucom.c,v 1.135 2023/02/17 23:38:54 riastradh Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_usb.h"
@@ -1446,18 +1446,8 @@ ucomreadcb(struct usbd_xfer *xfer, void 
 
 	if (status == USBD_CANCELLED || status == USBD_IOERROR ||
 	    sc->sc_closing) {
-
 		DPRINTF("... done (status %jd closing %jd)",
 		    status, sc->sc_closing, 0, 0);
-
-		if (status == USBD_IOERROR || sc->sc_closing) {
-			/* Send something to wake upper layer */
-			(tp->t_linesw->l_rint)('\n', tp);
-			ttylock(tp);	/* XXX */
-			ttwakeup(tp);
-			ttyunlock(tp);	/* XXX */
-		}
-
 		mutex_exit(&sc->sc_lock);
 		return;
 	}

Reply via email to