Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 19 Dec 2013 08:49:06 GMT
From:      Eivind Nicolay Evensen <eivinde@terraplane.org>
To:        freebsd-gnats-submit@FreeBSD.org
Subject:   kern/184987: Missing support for tty DISCARD/^O
Message-ID:  <201312190849.rBJ8n6cY019647@oldred.freebsd.org>
Resent-Message-ID: <201312190850.rBJ8o0vR028451@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help

>Number:         184987
>Category:       kern
>Synopsis:       Missing support for tty DISCARD/^O
>Confidential:   no
>Severity:       non-critical
>Priority:       low
>Responsible:    freebsd-bugs
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          sw-bug
>Submitter-Id:   current-users
>Arrival-Date:   Thu Dec 19 08:50:00 UTC 2013
>Closed-Date:
>Last-Modified:
>Originator:     Eivind Nicolay Evensen
>Release:        8
>Organization:
>Environment:
Multiple
>Description:
In the tty rewrite going from 7 to 8 it seems that support for
DISCARD/^O was either dropped or forgotten.

Here's a diff that gives most of the old functionality,
except output is not automatically turned back on upon input.
>How-To-Repeat:
Have something generate output, ^O doesn't discard the output.
>Fix:


Patch attached with submission follows:

diff -r 91820d9948e0 -r 13f40d577646 sys/kern/tty_ttydisc.c
--- a/sys/kern/tty_ttydisc.c	Fri Feb 22 09:45:32 2013 +0100
+++ b/sys/kern/tty_ttydisc.c	Tue Dec 17 23:03:17 2013 +0100
@@ -448,6 +448,9 @@
 	if (tp->t_flags & TF_ZOMBIE)
 		return (EIO);
 
+	if (tp->t_termios.c_lflag & FLUSHO)
+		return (0);
+
 	/*
 	 * We don't need to check whether the process is the foreground
 	 * process group or if we have a carrier. This is already done
@@ -881,6 +884,14 @@
 
 	/* Special control characters that are implementation dependent. */
 	if (CMP_FLAG(l, IEXTEN)) {
+		/* Discard (^O) */
+		if (CMP_CC(VDISCARD, c)) {
+			if (!(tp->t_termios.c_lflag & FLUSHO))
+				ttyoutq_write_nofrag(&tp->t_outq, "^O", 2);
+			tp->t_termios.c_lflag ^= FLUSHO;
+			return(0);
+		}
+
 		/* Accept the next character as literal. */
 		if (CMP_CC(VLNEXT, c)) {
 			if (CMP_FLAG(l, ECHO)) {


>Release-Note:
>Audit-Trail:
>Unformatted:



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201312190849.rBJ8n6cY019647>