2 * Copyright (c) 1982, 1986, 1990, 1991, 1993
3 * The Regents of the University of California. All rights reserved.
4 * (c) UNIX System Laboratories, Inc.
5 * All or some portions of this file are derived from material licensed
6 * to the University of California by American Telephone and Telegraph
7 * Co. or Unix System Laboratories, Inc. and are reproduced herein with
8 * the permission of UNIX System Laboratories, Inc.
10 * Copyright (c) 2002 Networks Associates Technologies, Inc.
11 * All rights reserved.
13 * Portions of this software were developed for the FreeBSD Project by
14 * ThinkSec AS and NAI Labs, the Security Research Division of Network
15 * Associates, Inc. under DARPA/SPAWAR contract N66001-01-C-8035
16 * ("CBOSS"), as part of the DARPA CHATS research program.
18 * Redistribution and use in source and binary forms, with or without
19 * modification, are permitted provided that the following conditions
21 * 1. Redistributions of source code must retain the above copyright
22 * notice, this list of conditions and the following disclaimer.
23 * 2. Redistributions in binary form must reproduce the above copyright
24 * notice, this list of conditions and the following disclaimer in the
25 * documentation and/or other materials provided with the distribution.
26 * 4. Neither the name of the University nor the names of its contributors
27 * may be used to endorse or promote products derived from this software
28 * without specific prior written permission.
30 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
31 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
32 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
33 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
34 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
35 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
36 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
37 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
38 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
39 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
42 * @(#)tty.c 8.8 (Berkeley) 1/21/94
47 * o Fix races for sending the start char in ttyflush().
48 * o Handle inter-byte timeout for "MIN > 0, TIME > 0" in ttyselect().
49 * With luck, there will be MIN chars before select() returns().
50 * o Handle CLOCAL consistently for ptys. Perhaps disallow setting it.
51 * o Don't allow input in TS_ZOMBIE case. It would be visible through
53 * o Do the new sio locking stuff here and use it to avoid special
56 * o Move EXTPROC and/or PENDIN to t_state?
57 * o Wrap most of ttioctl in spltty/splx.
58 * o Implement TIOCNOTTY or remove it from <sys/ioctl.h>.
59 * o Send STOP if IXOFF is toggled off while TS_TBLOCK is set.
60 * o Don't allow certain termios flags to affect disciplines other
61 * than TTYDISC. Cancel their effects before switch disciplines
62 * and ignore them if they are set while we are in another
64 * o Now that historical speed conversions are handled here, don't
66 * o Check for TS_CARR_ON being set while everything is closed and not
67 * waiting for carrier. TS_CARR_ON isn't cleared if nothing is open,
68 * so it would live until the next open even if carrier drops.
69 * o Restore TS_WOPEN since it is useful in pstat. It must be cleared
70 * only when _all_ openers leave open().
73 #include <sys/cdefs.h>
74 __FBSDID("$FreeBSD$");
76 #include "opt_compat.h"
79 #include <sys/param.h>
80 #include <sys/systm.h>
81 #include <sys/filio.h>
83 #include <sys/mutex.h>
84 #include <sys/namei.h>
86 #if defined(COMPAT_43TTY)
87 #include <sys/ioctl_compat.h>
94 #include <sys/fcntl.h>
97 #include <sys/kernel.h>
98 #include <sys/vnode.h>
99 #include <sys/serial.h>
100 #include <sys/signalvar.h>
101 #include <sys/resourcevar.h>
102 #include <sys/malloc.h>
103 #include <sys/filedesc.h>
104 #include <sys/sched.h>
105 #include <sys/sysctl.h>
106 #include <sys/timepps.h>
108 #include <machine/stdarg.h>
112 #include <vm/vm_map.h>
114 MALLOC_DEFINE(M_TTYS, "ttys", "tty data structures");
121 static d_open_t ttysopen;
122 static d_close_t ttysclose;
123 static d_read_t ttysrdwr;
124 static d_ioctl_t ttysioctl;
125 static d_purge_t ttypurge;
127 /* Default cdevsw for common tty devices */
128 static struct cdevsw tty_cdevsw = {
129 .d_version = D_VERSION,
135 .d_flags = D_TTY | D_NEEDGIANT,
138 /* Cdevsw for slave tty devices */
139 static struct cdevsw ttys_cdevsw = {
140 .d_version = D_VERSION,
142 .d_close = ttysclose,
145 .d_ioctl = ttysioctl,
147 .d_flags = D_TTY | D_NEEDGIANT,
150 static int proc_compare(struct proc *p1, struct proc *p2);
151 static int ttnread(struct tty *tp);
152 static void ttyecho(int c, struct tty *tp);
153 static int ttyoutput(int c, struct tty *tp);
154 static void ttypend(struct tty *tp);
155 static void ttyretype(struct tty *tp);
156 static void ttyrub(int c, struct tty *tp);
157 static void ttyrubo(struct tty *tp, int cnt);
158 static void ttyunblock(struct tty *tp);
159 static int ttywflush(struct tty *tp);
160 static int filt_ttyread(struct knote *kn, long hint);
161 static void filt_ttyrdetach(struct knote *kn);
162 static int filt_ttywrite(struct knote *kn, long hint);
163 static void filt_ttywdetach(struct knote *kn);
166 * Table with character classes and parity. The 8th bit indicates parity,
167 * the 7th bit indicates the character is an alphameric or underscore (for
168 * ALTWERASE), and the low 6 bits indicate delay type. If the low 6 bits
169 * are 0 then the character needs no special processing on output; classes
170 * other than 0 might be translated or (not currently) require delays.
172 #define E 0x00 /* Even parity. */
173 #define O 0x80 /* Odd parity. */
174 #define PARITY(c) (char_type[c] & O)
176 #define ALPHA 0x40 /* Alpha or underscore. */
177 #define ISALPHA(c) (char_type[(c) & TTY_CHARMASK] & ALPHA)
179 #define CCLASSMASK 0x3f
180 #define CCLASS(c) (char_type[c] & CCLASSMASK)
185 #define NA ORDINARY | ALPHA
191 static u_char const char_type[] = {
192 E|CC, O|CC, O|CC, E|CC, O|CC, E|CC, E|CC, O|CC, /* nul - bel */
193 O|BS, E|TB, E|NL, O|CC, E|VT, O|CR, O|CC, E|CC, /* bs - si */
194 O|CC, E|CC, E|CC, O|CC, E|CC, O|CC, O|CC, E|CC, /* dle - etb */
195 E|CC, O|CC, O|CC, E|CC, O|CC, E|CC, E|CC, O|CC, /* can - us */
196 O|NO, E|NO, E|NO, O|NO, E|NO, O|NO, O|NO, E|NO, /* sp - ' */
197 E|NO, O|NO, O|NO, E|NO, O|NO, E|NO, E|NO, O|NO, /* ( - / */
198 E|NA, O|NA, O|NA, E|NA, O|NA, E|NA, E|NA, O|NA, /* 0 - 7 */
199 O|NA, E|NA, E|NO, O|NO, E|NO, O|NO, O|NO, E|NO, /* 8 - ? */
200 O|NO, E|NA, E|NA, O|NA, E|NA, O|NA, O|NA, E|NA, /* @ - G */
201 E|NA, O|NA, O|NA, E|NA, O|NA, E|NA, E|NA, O|NA, /* H - O */
202 E|NA, O|NA, O|NA, E|NA, O|NA, E|NA, E|NA, O|NA, /* P - W */
203 O|NA, E|NA, E|NA, O|NO, E|NO, O|NO, O|NO, O|NA, /* X - _ */
204 E|NO, O|NA, O|NA, E|NA, O|NA, E|NA, E|NA, O|NA, /* ` - g */
205 O|NA, E|NA, E|NA, O|NA, E|NA, O|NA, O|NA, E|NA, /* h - o */
206 O|NA, E|NA, E|NA, O|NA, E|NA, O|NA, O|NA, E|NA, /* p - w */
207 E|NA, O|NA, O|NA, E|NO, O|NO, E|NO, E|NO, O|CC, /* x - del */
209 * Meta chars; should be settable per character set;
210 * for now, treat them all as normal characters.
212 NA, NA, NA, NA, NA, NA, NA, NA,
213 NA, NA, NA, NA, NA, NA, NA, NA,
214 NA, NA, NA, NA, NA, NA, NA, NA,
215 NA, NA, NA, NA, NA, NA, NA, NA,
216 NA, NA, NA, NA, NA, NA, NA, NA,
217 NA, NA, NA, NA, NA, NA, NA, NA,
218 NA, NA, NA, NA, NA, NA, NA, NA,
219 NA, NA, NA, NA, NA, NA, NA, NA,
220 NA, NA, NA, NA, NA, NA, NA, NA,
221 NA, NA, NA, NA, NA, NA, NA, NA,
222 NA, NA, NA, NA, NA, NA, NA, NA,
223 NA, NA, NA, NA, NA, NA, NA, NA,
224 NA, NA, NA, NA, NA, NA, NA, NA,
225 NA, NA, NA, NA, NA, NA, NA, NA,
226 NA, NA, NA, NA, NA, NA, NA, NA,
227 NA, NA, NA, NA, NA, NA, NA, NA,
238 /* Macros to clear/set/test flags. */
239 #define SET(t, f) (t) |= (f)
240 #define CLR(t, f) (t) &= ~(f)
241 #define ISSET(t, f) ((t) & (f))
243 #undef MAX_INPUT /* XXX wrong in <sys/syslimits.h> */
244 #define MAX_INPUT TTYHOG /* XXX limit is usually larger for !ICANON */
247 * list of struct tty where pstat(8) can pick it up with sysctl
249 * The lock order is to grab the list mutex before the tty mutex.
250 * Together with additions going on the tail of the list, this allows
251 * the sysctl to avoid doing retries.
253 static TAILQ_HEAD(, tty) tty_list = TAILQ_HEAD_INITIALIZER(tty_list);
254 static struct mtx tty_list_mutex;
255 MTX_SYSINIT(tty_list, &tty_list_mutex, "ttylist", MTX_DEF);
257 static struct unrhdr *tty_unit;
259 static int drainwait = 5*60;
260 SYSCTL_INT(_kern, OID_AUTO, drainwait, CTLFLAG_RW, &drainwait,
261 0, "Output drain timeout in seconds");
264 tty_gettp(struct cdev *dev)
269 csw = dev_refthread(dev);
270 KASSERT(csw != NULL, ("No cdevsw in ttycode (%s)", devtoname(dev)));
271 KASSERT(csw->d_flags & D_TTY,
272 ("non D_TTY (%s) in tty code", devtoname(dev)));
276 ("no tty pointer on (%s) in tty code", devtoname(dev)));
281 * Initial open of tty, or (re)entry to standard tty line discipline.
284 tty_open(struct cdev *device, struct tty *tp)
291 if (!ISSET(tp->t_state, TS_ISOPEN)) {
293 SET(tp->t_state, TS_ISOPEN);
294 if (ISSET(tp->t_cflag, CLOCAL))
295 SET(tp->t_state, TS_CONNECTED);
296 bzero(&tp->t_winsize, sizeof(tp->t_winsize));
298 /* XXX don't hang forever on output */
299 if (tp->t_timeout < 0)
300 tp->t_timeout = drainwait*hz;
307 * Handle close() on a tty line: flush and set to initial state,
308 * bumping generation number so that pending read/write calls
309 * can detect recycling of the tty.
310 * XXX our caller should have done `spltty(); l_close(); tty_close();'
311 * and l_close() should have flushed, but we repeat the spltty() and
312 * the flush in case there are buggy callers.
315 tty_close(struct tty *tp)
319 funsetown(&tp->t_sigio);
324 ttyflush(tp, FREAD | FWRITE);
325 clist_free_cblocks(&tp->t_canq);
326 clist_free_cblocks(&tp->t_outq);
327 clist_free_cblocks(&tp->t_rawq);
330 tp->t_line = TTYDISC;
333 tp->t_session = NULL;
334 ostate = tp->t_state;
336 knlist_clear(&tp->t_rsel.si_note, 0);
337 knlist_clear(&tp->t_wsel.si_note, 0);
339 * Both final close and revocation close might end up calling
340 * this method. Only the thread clearing TS_ISOPEN should
341 * release the reference to the tty.
343 if (ISSET(ostate, TS_ISOPEN))
349 #define FLUSHQ(q) { \
351 ndflush(q, (q)->c_cc); \
354 /* Is 'c' a line delimiter ("break" character)? */
355 #define TTBREAKC(c, lflag) \
356 ((c) == '\n' || (((c) == cc[VEOF] || \
357 (c) == cc[VEOL] || ((c) == cc[VEOL2] && lflag & IEXTEN)) && \
358 (c) != _POSIX_VDISABLE))
361 * Process input of a single character received on a tty.
364 ttyinput(int c, struct tty *tp)
366 tcflag_t iflag, lflag;
371 * If input is pending take it first.
374 if (ISSET(lflag, PENDIN))
379 if (ISSET(lflag, ICANON)) {
389 * Block further input iff:
390 * current input > threshold AND input is available to user program
391 * AND input flow control is enabled and not yet invoked.
392 * The 3 is slop for PARMRK.
395 if (tp->t_rawq.c_cc + tp->t_canq.c_cc > tp->t_ihiwat - 3 &&
396 (!ISSET(lflag, ICANON) || tp->t_canq.c_cc != 0) &&
397 (ISSET(tp->t_cflag, CRTS_IFLOW) || ISSET(iflag, IXOFF)) &&
398 !ISSET(tp->t_state, TS_TBLOCK))
401 /* Handle exceptional conditions (break, parity, framing). */
403 err = (ISSET(c, TTY_ERRORMASK));
405 CLR(c, TTY_ERRORMASK);
406 if (ISSET(err, TTY_BI)) {
407 if (ISSET(iflag, IGNBRK))
409 if (ISSET(iflag, BRKINT)) {
410 ttyflush(tp, FREAD | FWRITE);
411 if (tp->t_pgrp != NULL) {
412 PGRP_LOCK(tp->t_pgrp);
413 pgsignal(tp->t_pgrp, SIGINT, 1);
414 PGRP_UNLOCK(tp->t_pgrp);
418 if (ISSET(iflag, PARMRK))
420 } else if ((ISSET(err, TTY_PE) && ISSET(iflag, INPCK))
421 || ISSET(err, TTY_FE)) {
422 if (ISSET(iflag, IGNPAR))
424 else if (ISSET(iflag, PARMRK)) {
426 if (tp->t_rawq.c_cc + tp->t_canq.c_cc >
429 (void)putc(0377 | TTY_QUOTE, &tp->t_rawq);
430 (void)putc(0 | TTY_QUOTE, &tp->t_rawq);
431 (void)putc(c | TTY_QUOTE, &tp->t_rawq);
438 if (!ISSET(tp->t_state, TS_TYPEN) && ISSET(iflag, ISTRIP))
440 if (!ISSET(lflag, EXTPROC)) {
442 * Check for literal nexting very first
444 if (ISSET(tp->t_state, TS_LNCH)) {
446 CLR(tp->t_state, TS_LNCH);
449 * Scan for special characters. This code
450 * is really just a big case statement with
451 * non-constant cases. The bottom of the
452 * case statement is labeled ``endcase'', so goto
453 * it after a case match, or similar.
457 * Control chars which aren't controlled
458 * by ICANON, ISIG, or IXON.
460 if (ISSET(lflag, IEXTEN)) {
461 if (CCEQ(cc[VLNEXT], c)) {
462 if (ISSET(lflag, ECHO)) {
463 if (ISSET(lflag, ECHOE)) {
464 (void)ttyoutput('^', tp);
465 (void)ttyoutput('\b', tp);
469 SET(tp->t_state, TS_LNCH);
472 if (CCEQ(cc[VDISCARD], c)) {
473 if (ISSET(lflag, FLUSHO))
474 CLR(tp->t_lflag, FLUSHO);
476 ttyflush(tp, FWRITE);
478 if (tp->t_rawq.c_cc + tp->t_canq.c_cc)
480 SET(tp->t_lflag, FLUSHO);
488 if (ISSET(lflag, ISIG)) {
489 if (CCEQ(cc[VINTR], c) || CCEQ(cc[VQUIT], c)) {
490 if (!ISSET(lflag, NOFLSH))
491 ttyflush(tp, FREAD | FWRITE);
493 if (tp->t_pgrp != NULL) {
494 PGRP_LOCK(tp->t_pgrp);
496 CCEQ(cc[VINTR], c) ? SIGINT : SIGQUIT, 1);
497 PGRP_UNLOCK(tp->t_pgrp);
501 if (CCEQ(cc[VSUSP], c)) {
502 if (!ISSET(lflag, NOFLSH))
505 if (tp->t_pgrp != NULL) {
506 PGRP_LOCK(tp->t_pgrp);
507 pgsignal(tp->t_pgrp, SIGTSTP, 1);
508 PGRP_UNLOCK(tp->t_pgrp);
514 * Handle start/stop characters.
516 if (ISSET(iflag, IXON)) {
517 if (CCEQ(cc[VSTOP], c)) {
518 if (!ISSET(tp->t_state, TS_TTSTOP)) {
519 SET(tp->t_state, TS_TTSTOP);
523 if (!CCEQ(cc[VSTART], c))
526 * if VSTART == VSTOP then toggle
530 if (CCEQ(cc[VSTART], c))
534 * IGNCR, ICRNL, & INLCR
537 if (ISSET(iflag, IGNCR))
539 else if (ISSET(iflag, ICRNL))
541 } else if (c == '\n' && ISSET(iflag, INLCR))
544 if (!ISSET(tp->t_lflag, EXTPROC) && ISSET(lflag, ICANON)) {
546 * From here on down canonical mode character
547 * processing takes place.
550 * erase or erase2 (^H / ^?)
552 if (CCEQ(cc[VERASE], c) || CCEQ(cc[VERASE2], c) ) {
554 ttyrub(unputc(&tp->t_rawq), tp);
560 if (CCEQ(cc[VKILL], c)) {
561 if (ISSET(lflag, ECHOKE) &&
562 tp->t_rawq.c_cc == tp->t_rocount &&
563 !ISSET(lflag, ECHOPRT))
564 while (tp->t_rawq.c_cc)
565 ttyrub(unputc(&tp->t_rawq), tp);
568 if (ISSET(lflag, ECHOK) ||
569 ISSET(lflag, ECHOKE))
574 CLR(tp->t_state, TS_LOCAL);
580 if (CCEQ(cc[VWERASE], c) && ISSET(lflag, IEXTEN)) {
586 while ((c = unputc(&tp->t_rawq)) == ' ' || c == '\t')
591 * erase last char of word and remember the
592 * next chars type (for ALTWERASE)
595 c = unputc(&tp->t_rawq);
598 if (c == ' ' || c == '\t') {
599 (void)putc(c, &tp->t_rawq);
608 c = unputc(&tp->t_rawq);
611 } while (c != ' ' && c != '\t' &&
612 (!ISSET(lflag, ALTWERASE) || ISALPHA(c) == ctype));
613 (void)putc(c, &tp->t_rawq);
619 if (CCEQ(cc[VREPRINT], c) && ISSET(lflag, IEXTEN)) {
624 * ^T - kernel info and generate SIGINFO
626 if (CCEQ(cc[VSTATUS], c) && ISSET(lflag, IEXTEN)) {
627 if (ISSET(lflag, ISIG) && tp->t_pgrp != NULL) {
628 PGRP_LOCK(tp->t_pgrp);
629 pgsignal(tp->t_pgrp, SIGINFO, 1);
630 PGRP_UNLOCK(tp->t_pgrp);
632 if (!ISSET(lflag, NOKERNINFO))
638 * Check for input buffer overflow
640 if (tp->t_rawq.c_cc + tp->t_canq.c_cc >= MAX_INPUT) {
642 if (ISSET(iflag, IMAXBEL)) {
643 if (tp->t_outq.c_cc < tp->t_ohiwat)
644 (void)ttyoutput(CTRL('g'), tp);
649 if ( c == 0377 && ISSET(iflag, PARMRK) && !ISSET(iflag, ISTRIP)
650 && ISSET(iflag, IGNBRK|IGNPAR) != (IGNBRK|IGNPAR))
651 (void)putc(0377 | TTY_QUOTE, &tp->t_rawq);
654 * Put data char in q for user and
655 * wakeup on seeing a line delimiter.
657 if (putc(c, &tp->t_rawq) >= 0) {
658 if (!ISSET(lflag, ICANON)) {
663 if (TTBREAKC(c, lflag)) {
665 catq(&tp->t_rawq, &tp->t_canq);
667 } else if (tp->t_rocount++ == 0)
668 tp->t_rocol = tp->t_column;
669 if (ISSET(tp->t_state, TS_ERASE)) {
671 * end of prterase \.../
673 CLR(tp->t_state, TS_ERASE);
674 (void)ttyoutput('/', tp);
678 if (CCEQ(cc[VEOF], c) && ISSET(lflag, ECHO)) {
680 * Place the cursor over the '^' of the ^D.
682 i = imin(2, tp->t_column - i);
684 (void)ttyoutput('\b', tp);
691 * IXANY means allow any character to restart output.
693 if (ISSET(tp->t_state, TS_TTSTOP) &&
694 !ISSET(iflag, IXANY) && cc[VSTART] != cc[VSTOP])
697 CLR(tp->t_lflag, FLUSHO);
698 CLR(tp->t_state, TS_TTSTOP);
700 return (ttstart(tp));
704 * Output a single character on a tty, doing output processing
705 * as needed (expanding tabs, newline processing, etc.).
706 * Returns < 0 if succeeds, otherwise returns char to resend.
710 ttyoutput(int c, struct tty *tp)
716 if (!ISSET(oflag, OPOST)) {
717 if (ISSET(tp->t_lflag, FLUSHO))
719 if (putc(c, &tp->t_outq))
726 * Do tab expansion if OXTABS is set. Special case if we external
727 * processing, we don't do the tab expansion because we'll probably
728 * get it wrong. If tab expansion needs to be done, let it happen
731 CLR(c, ~TTY_CHARMASK);
733 ISSET(oflag, OXTABS) && !ISSET(tp->t_lflag, EXTPROC)) {
734 c = 8 - (tp->t_column & 7);
735 if (!ISSET(tp->t_lflag, FLUSHO)) {
736 s = spltty(); /* Don't interrupt tabs. */
737 c -= b_to_q(" ", c, &tp->t_outq);
743 return (c ? -1 : '\t');
745 if (c == CEOT && ISSET(oflag, ONOEOT))
749 * Newline translation: if ONLCR is set,
750 * translate newline into "\r\n".
752 if (c == '\n' && ISSET(tp->t_oflag, ONLCR)) {
755 if (!ISSET(tp->t_lflag, FLUSHO) && putc('\r', &tp->t_outq))
758 /* If OCRNL is set, translate "\r" into "\n". */
759 else if (c == '\r' && ISSET(tp->t_oflag, OCRNL))
761 /* If ONOCR is set, don't transmit CRs when on column 0. */
762 else if (c == '\r' && ISSET(tp->t_oflag, ONOCR) && tp->t_column == 0)
767 if (!ISSET(tp->t_lflag, FLUSHO) && putc(c, &tp->t_outq))
779 if (ISSET(tp->t_oflag, ONLCR | ONLRET))
789 col = (col + 8) & ~7;
797 * Ioctls for all tty devices. Called after line-discipline specific ioctl
798 * has been called to do discipline-specific functions and/or reject any
799 * of these ioctl commands.
803 ttioctl(struct tty *tp, u_long cmd, void *data, int flag)
808 int s, error, bits, sig, sig2;
810 td = curthread; /* XXX */
813 /* If the ioctl involves modification, hang if in the background. */
837 #if defined(COMPAT_43TTY)
847 sx_slock(&proctree_lock);
849 while (isbackground(p, tp) && !(p->p_flag & P_PPWAIT) &&
850 !SIGISMEMBER(p->p_sigacts->ps_sigignore, SIGTTOU) &&
851 !SIGISMEMBER(td->td_sigmask, SIGTTOU)) {
854 if (pgrp->pg_jobc == 0) {
855 sx_sunlock(&proctree_lock);
859 sx_sunlock(&proctree_lock);
860 pgsignal(pgrp, SIGTTOU, 1);
862 error = ttysleep(tp, &lbolt, TTOPRI | PCATCH, "ttybg1",
866 sx_slock(&proctree_lock);
870 sx_sunlock(&proctree_lock);
875 if (tp->t_modem != NULL) {
878 tt_modem(tp, SER_DTR, 0);
881 tt_modem(tp, 0, SER_DTR);
885 sig = (bits & (TIOCM_DTR | TIOCM_RTS)) >> 1;
886 sig2 = ((~bits) & (TIOCM_DTR | TIOCM_RTS)) >> 1;
887 tt_modem(tp, sig, sig2);
891 sig = (bits & (TIOCM_DTR | TIOCM_RTS)) >> 1;
892 tt_modem(tp, sig, 0);
896 sig = (bits & (TIOCM_DTR | TIOCM_RTS)) >> 1;
897 tt_modem(tp, 0, sig);
900 sig = tt_modem(tp, 0, 0);
901 /* See <sys/serial.h. for the "<< 1" stuff */
902 bits = TIOCM_LE + (sig << 1);
910 if (tp->t_pps != NULL) {
911 error = pps_ioctl(cmd, data, tp->t_pps);
912 if (error != ENOIOCTL)
916 switch (cmd) { /* Process the ioctl. */
917 case FIOASYNC: /* set/clear async i/o */
920 SET(tp->t_state, TS_ASYNC);
922 CLR(tp->t_state, TS_ASYNC);
925 case FIONBIO: /* set/clear non-blocking i/o */
926 break; /* XXX: delete. */
927 case FIONREAD: /* get # bytes to read */
929 *(int *)data = ttnread(tp);
935 * Policy -- Don't allow FIOSETOWN on someone else's
938 if (tp->t_session != NULL && !isctty(p, tp))
941 error = fsetown(*(int *)data, &tp->t_sigio);
946 if (tp->t_session != NULL && !isctty(p, tp))
948 *(int *)data = fgetown(&tp->t_sigio);
951 case TIOCEXCL: /* set exclusive use of tty */
953 SET(tp->t_state, TS_XCLUDE);
956 case TIOCFLUSH: { /* flush buffers */
957 int flags = *(int *)data;
960 flags = FREAD | FWRITE;
962 flags &= FREAD | FWRITE;
966 case TIOCCONS: /* become virtual console */
968 struct nameidata nid;
970 if (constty && constty != tp &&
971 ISSET(constty->t_state, TS_CONNECTED))
974 /* Ensure user can open the real console. */
975 NDINIT(&nid, LOOKUP, LOCKLEAF | FOLLOW, UIO_SYSSPACE,
977 if ((error = namei(&nid)) != 0)
979 NDFREE(&nid, NDF_ONLY_PNBUF);
980 error = VOP_ACCESS(nid.ni_vp, VREAD, td->td_ucred, td);
986 } else if (tp == constty)
989 case TIOCDRAIN: /* wait till output drained */
994 case TIOCGETA: { /* get termios struct */
995 struct termios *t = (struct termios *)data;
997 bcopy(&tp->t_termios, t, sizeof(struct termios));
1000 case TIOCGETD: /* get line discipline */
1001 *(int *)data = tp->t_line;
1003 case TIOCGWINSZ: /* get window size */
1004 *(struct winsize *)data = tp->t_winsize;
1006 case TIOCGPGRP: /* get pgrp of tty */
1009 *(int *)data = tp->t_pgrp ? tp->t_pgrp->pg_id : NO_PID;
1012 case TIOCHPCL: /* hang up on last close */
1014 SET(tp->t_cflag, HUPCL);
1019 *(int *)data = tp->t_dtr_wait * 100 / hz;
1022 /* must be root since the wait applies to following logins */
1023 error = priv_check(td, PRIV_TTY_DTRWAIT);
1026 tp->t_dtr_wait = *(int *)data * hz / 100;
1028 case TIOCNXCL: /* reset exclusive use of tty */
1030 CLR(tp->t_state, TS_XCLUDE);
1033 case TIOCOUTQ: /* output queue size */
1034 *(int *)data = tp->t_outq.c_cc;
1036 case TIOCSETA: /* set termios struct */
1037 case TIOCSETAW: /* drain output, set */
1038 case TIOCSETAF: { /* drn out, fls in, set */
1039 struct termios *t = (struct termios *)data;
1041 if (t->c_ispeed == 0)
1042 t->c_ispeed = t->c_ospeed;
1043 if (t->c_ispeed == 0)
1044 t->c_ispeed = tp->t_ospeed;
1045 if (t->c_ispeed == 0)
1048 if (cmd == TIOCSETAW || cmd == TIOCSETAF) {
1049 error = ttywait(tp);
1054 if (cmd == TIOCSETAF)
1055 ttyflush(tp, FREAD);
1057 if (!ISSET(t->c_cflag, CIGNORE)) {
1059 * Set device hardware.
1061 error = tt_param(tp, t);
1066 if (ISSET(t->c_cflag, CLOCAL) &&
1067 !ISSET(tp->t_cflag, CLOCAL)) {
1069 * XXX disconnections would be too hard to
1070 * get rid of without this kludge. The only
1071 * way to get rid of controlling terminals
1072 * is to exit from the session leader.
1074 CLR(tp->t_state, TS_ZOMBIE);
1076 wakeup(TSA_CARR_ON(tp));
1080 if ((ISSET(tp->t_state, TS_CARR_ON) ||
1081 ISSET(t->c_cflag, CLOCAL)) &&
1082 !ISSET(tp->t_state, TS_ZOMBIE))
1083 SET(tp->t_state, TS_CONNECTED);
1085 CLR(tp->t_state, TS_CONNECTED);
1086 tp->t_cflag = t->c_cflag;
1087 tp->t_ispeed = t->c_ispeed;
1088 if (t->c_ospeed != 0)
1089 tp->t_ospeed = t->c_ospeed;
1092 if (ISSET(t->c_lflag, ICANON) != ISSET(tp->t_lflag, ICANON) &&
1094 if (ISSET(t->c_lflag, ICANON))
1095 SET(tp->t_lflag, PENDIN);
1098 * XXX we really shouldn't allow toggling
1099 * ICANON while we're in a non-termios line
1100 * discipline. Now we have to worry about
1101 * panicing for a null queue.
1103 if (tp->t_canq.c_cbreserved > 0 &&
1104 tp->t_rawq.c_cbreserved > 0) {
1105 catq(&tp->t_rawq, &tp->t_canq);
1107 * XXX the queue limits may be
1108 * different, so the old queue
1109 * swapping method no longer works.
1111 catq(&tp->t_canq, &tp->t_rawq);
1113 CLR(tp->t_lflag, PENDIN);
1117 tp->t_iflag = t->c_iflag;
1118 tp->t_oflag = t->c_oflag;
1120 * Make the EXTPROC bit read only.
1122 if (ISSET(tp->t_lflag, EXTPROC))
1123 SET(t->c_lflag, EXTPROC);
1125 CLR(t->c_lflag, EXTPROC);
1126 tp->t_lflag = t->c_lflag | ISSET(tp->t_lflag, PENDIN);
1127 if (t->c_cc[VMIN] != tp->t_cc[VMIN] ||
1128 t->c_cc[VTIME] != tp->t_cc[VTIME])
1130 bcopy(t->c_cc, tp->t_cc, sizeof(t->c_cc));
1134 case TIOCSETD: { /* set line discipline */
1135 int t = *(int *)data;
1137 if ((u_int)t >= nlinesw)
1139 if (t == tp->t_line)
1142 ttyld_close(tp, flag);
1144 /* XXX: we should use the correct cdev here */
1145 error = ttyld_open(tp, tp->t_dev);
1148 * If we fail to switch line discipline we cannot
1149 * fall back to the previous, because we can not
1150 * trust that ldisc to open successfully either.
1151 * Fall back to the default ldisc which we know
1152 * will allways succeed.
1154 tp->t_line = TTYDISC;
1155 (void)ttyld_open(tp, tp->t_dev);
1161 case TIOCSTART: /* start output, like ^Q */
1163 if (ISSET(tp->t_state, TS_TTSTOP) ||
1164 ISSET(tp->t_lflag, FLUSHO)) {
1165 CLR(tp->t_lflag, FLUSHO);
1166 CLR(tp->t_state, TS_TTSTOP);
1171 case TIOCSTI: /* simulate terminal input */
1172 if ((flag & FREAD) == 0 && priv_check(td, PRIV_TTY_STI))
1174 if (!isctty(p, tp) && priv_check(td, PRIV_TTY_STI))
1177 ttyld_rint(tp, *(u_char *)data);
1180 case TIOCSTOP: /* stop output, like ^S */
1182 if (!ISSET(tp->t_state, TS_TTSTOP)) {
1183 SET(tp->t_state, TS_TTSTOP);
1188 case TIOCSCTTY: /* become controlling tty */
1189 /* Session ctty vnode pointer set in vnode layer. */
1190 sx_slock(&proctree_lock);
1191 if (!SESS_LEADER(p) ||
1192 ((p->p_session->s_ttyvp || tp->t_session) &&
1193 (tp->t_session != p->p_session))) {
1194 sx_sunlock(&proctree_lock);
1197 tp->t_session = p->p_session;
1198 tp->t_pgrp = p->p_pgrp;
1199 SESS_LOCK(p->p_session);
1200 ttyref(tp); /* ttyrel(): kern_proc.c:pgdelete() */
1201 p->p_session->s_ttyp = tp;
1202 SESS_UNLOCK(p->p_session);
1204 p->p_flag |= P_CONTROLT;
1206 sx_sunlock(&proctree_lock);
1208 case TIOCSPGRP: { /* set pgrp of tty */
1209 sx_slock(&proctree_lock);
1210 pgrp = pgfind(*(int *)data);
1211 if (!isctty(p, tp)) {
1214 sx_sunlock(&proctree_lock);
1218 sx_sunlock(&proctree_lock);
1222 if (pgrp->pg_session != p->p_session) {
1223 sx_sunlock(&proctree_lock);
1226 sx_sunlock(&proctree_lock);
1230 case TIOCSTAT: /* simulate control-T */
1235 case TIOCSWINSZ: /* set window size */
1236 if (bcmp((caddr_t)&tp->t_winsize, data,
1237 sizeof (struct winsize))) {
1238 tp->t_winsize = *(struct winsize *)data;
1239 if (tp->t_pgrp != NULL) {
1240 PGRP_LOCK(tp->t_pgrp);
1241 pgsignal(tp->t_pgrp, SIGWINCH, 1);
1242 PGRP_UNLOCK(tp->t_pgrp);
1246 case TIOCSDRAINWAIT:
1247 error = priv_check(td, PRIV_TTY_DRAINWAIT);
1250 tp->t_timeout = *(int *)data * hz;
1251 wakeup(TSA_OCOMPLETE(tp));
1252 wakeup(TSA_OLOWAT(tp));
1254 case TIOCGDRAINWAIT:
1255 *(int *)data = tp->t_timeout / hz;
1258 return (tt_break(tp, 1));
1260 return (tt_break(tp, 0));
1262 #if defined(COMPAT_43TTY)
1263 return (ttcompat(tp, cmd, data, flag));
1272 ttypoll(struct cdev *dev, int events, struct thread *td)
1278 tp = tty_gettp(dev);
1280 if (tp == NULL) /* XXX used to return ENXIO, but that means true! */
1281 return ((events & (POLLIN | POLLOUT | POLLRDNORM | POLLWRNORM))
1285 if (events & (POLLIN | POLLRDNORM)) {
1286 if (ISSET(tp->t_state, TS_ZOMBIE))
1287 revents |= (events & (POLLIN | POLLRDNORM)) |
1289 else if (ttnread(tp) > 0)
1290 revents |= events & (POLLIN | POLLRDNORM);
1292 selrecord(td, &tp->t_rsel);
1294 if (events & POLLOUT) {
1295 if (ISSET(tp->t_state, TS_ZOMBIE))
1297 else if (tp->t_outq.c_cc <= tp->t_olowat &&
1298 ISSET(tp->t_state, TS_CONNECTED))
1299 revents |= events & POLLOUT;
1301 selrecord(td, &tp->t_wsel);
1307 static struct filterops ttyread_filtops =
1308 { 1, NULL, filt_ttyrdetach, filt_ttyread };
1309 static struct filterops ttywrite_filtops =
1310 { 1, NULL, filt_ttywdetach, filt_ttywrite };
1313 ttykqfilter(struct cdev *dev, struct knote *kn)
1316 struct knlist *klist;
1319 tp = tty_gettp(dev);
1321 switch (kn->kn_filter) {
1323 klist = &tp->t_rsel.si_note;
1324 kn->kn_fop = &ttyread_filtops;
1327 klist = &tp->t_wsel.si_note;
1328 kn->kn_fop = &ttywrite_filtops;
1334 kn->kn_hook = (caddr_t)dev;
1337 knlist_add(klist, kn, 0);
1344 filt_ttyrdetach(struct knote *kn)
1346 struct tty *tp = ((struct cdev *)kn->kn_hook)->si_tty;
1349 knlist_remove(&tp->t_rsel.si_note, kn, 0);
1354 filt_ttyread(struct knote *kn, long hint)
1356 struct tty *tp = ((struct cdev *)kn->kn_hook)->si_tty;
1358 kn->kn_data = ttnread(tp);
1359 if (ISSET(tp->t_state, TS_ZOMBIE)) {
1360 kn->kn_flags |= EV_EOF;
1363 return (kn->kn_data > 0);
1367 filt_ttywdetach(struct knote *kn)
1369 struct tty *tp = ((struct cdev *)kn->kn_hook)->si_tty;
1372 knlist_remove(&tp->t_wsel.si_note, kn, 0);
1377 filt_ttywrite(struct knote *kn, long hint)
1379 struct tty *tp = ((struct cdev *)kn->kn_hook)->si_tty;
1381 kn->kn_data = tp->t_outq.c_cc;
1382 if (ISSET(tp->t_state, TS_ZOMBIE))
1384 return (kn->kn_data <= tp->t_olowat &&
1385 ISSET(tp->t_state, TS_CONNECTED));
1389 * Must be called at spltty().
1392 ttnread(struct tty *tp)
1396 if (ISSET(tp->t_lflag, PENDIN))
1398 nread = tp->t_canq.c_cc;
1399 if (!ISSET(tp->t_lflag, ICANON)) {
1400 nread += tp->t_rawq.c_cc;
1401 if (nread < tp->t_cc[VMIN] && tp->t_cc[VTIME] == 0)
1408 * Wait for output to drain.
1411 ttywait(struct tty *tp)
1417 while ((tp->t_outq.c_cc || ISSET(tp->t_state, TS_BUSY)) &&
1418 ISSET(tp->t_state, TS_CONNECTED) && tp->t_oproc) {
1420 if ((tp->t_outq.c_cc || ISSET(tp->t_state, TS_BUSY)) &&
1421 ISSET(tp->t_state, TS_CONNECTED)) {
1422 SET(tp->t_state, TS_SO_OCOMPLETE);
1423 error = ttysleep(tp, TSA_OCOMPLETE(tp),
1424 TTOPRI | PCATCH, "ttywai",
1427 if (error == EWOULDBLOCK)
1434 if (!error && (tp->t_outq.c_cc || ISSET(tp->t_state, TS_BUSY)))
1441 * Flush if successfully wait.
1444 ttywflush(struct tty *tp)
1448 if ((error = ttywait(tp)) == 0)
1449 ttyflush(tp, FREAD);
1454 * Flush tty read and/or write queues, notifying anyone waiting.
1457 ttyflush(struct tty *tp, int rw)
1466 FLUSHQ(&tp->t_outq);
1467 CLR(tp->t_state, TS_TTSTOP);
1471 FLUSHQ(&tp->t_canq);
1472 FLUSHQ(&tp->t_rawq);
1473 CLR(tp->t_lflag, PENDIN);
1476 CLR(tp->t_state, TS_LOCAL);
1478 if (ISSET(tp->t_state, TS_TBLOCK)) {
1480 FLUSHQ(&tp->t_outq);
1484 * Don't let leave any state that might clobber the
1485 * next line discipline (although we should do more
1486 * to send the START char). Not clearing the state
1487 * may have caused the "putc to a clist with no
1488 * reserved cblocks" panic/printf.
1490 CLR(tp->t_state, TS_TBLOCK);
1492 #if 0 /* forget it, sleeping isn't always safe and we don't know when it is */
1493 if (ISSET(tp->t_iflag, IXOFF)) {
1495 * XXX wait a bit in the hope that the stop
1496 * character (if any) will go out. Waiting
1497 * isn't good since it allows races. This
1498 * will be fixed when the stop character is
1499 * put in a special queue. Don't bother with
1500 * the checks in ttywait() since the timeout
1503 SET(tp->t_state, TS_SO_OCOMPLETE);
1504 ttysleep(tp, TSA_OCOMPLETE(tp), TTOPRI,
1507 * Don't try sending the stop character again.
1509 CLR(tp->t_state, TS_TBLOCK);
1516 FLUSHQ(&tp->t_outq);
1523 * Copy in the default termios characters.
1526 termioschars(struct termios *t)
1529 bcopy(ttydefchars, t->c_cc, sizeof t->c_cc);
1536 ttychars(struct tty *tp)
1539 termioschars(&tp->t_termios);
1543 * Handle input high water. Send stop character for the IXOFF case. Turn
1544 * on our input flow control bit and propagate the changes to the driver.
1545 * XXX the stop character should be put in a special high priority queue.
1548 ttyblock(struct tty *tp)
1551 SET(tp->t_state, TS_TBLOCK);
1552 if (ISSET(tp->t_iflag, IXOFF) && tp->t_cc[VSTOP] != _POSIX_VDISABLE &&
1553 putc(tp->t_cc[VSTOP], &tp->t_outq) != 0)
1554 CLR(tp->t_state, TS_TBLOCK); /* try again later */
1559 * Handle input low water. Send start character for the IXOFF case. Turn
1560 * off our input flow control bit and propagate the changes to the driver.
1561 * XXX the start character should be put in a special high priority queue.
1564 ttyunblock(struct tty *tp)
1567 CLR(tp->t_state, TS_TBLOCK);
1568 if (ISSET(tp->t_iflag, IXOFF) && tp->t_cc[VSTART] != _POSIX_VDISABLE &&
1569 putc(tp->t_cc[VSTART], &tp->t_outq) != 0)
1570 SET(tp->t_state, TS_TBLOCK); /* try again later */
1575 /* Not used by any current (i386) drivers. */
1577 * Restart after an inter-char delay.
1580 ttrstrt(void *tp_arg)
1585 KASSERT(tp_arg != NULL, ("ttrstrt"));
1590 CLR(tp->t_state, TS_TIMEOUT);
1598 ttstart(struct tty *tp)
1606 * "close" a line discipline
1609 ttylclose(struct tty *tp, int flag)
1612 if (flag & FNONBLOCK || ttywflush(tp))
1613 ttyflush(tp, FREAD | FWRITE);
1618 * Handle modem control transition on a tty.
1619 * Flag indicates new state of carrier.
1620 * Returns 0 if the line should be turned off, otherwise 1.
1623 ttymodem(struct tty *tp, int flag)
1626 if (ISSET(tp->t_state, TS_CARR_ON) && ISSET(tp->t_cflag, MDMBUF)) {
1628 * MDMBUF: do flow control according to carrier flag
1629 * XXX TS_CAR_OFLOW doesn't do anything yet. TS_TTSTOP
1630 * works if IXON and IXANY are clear.
1633 CLR(tp->t_state, TS_CAR_OFLOW);
1634 CLR(tp->t_state, TS_TTSTOP);
1636 } else if (!ISSET(tp->t_state, TS_CAR_OFLOW)) {
1637 SET(tp->t_state, TS_CAR_OFLOW);
1638 SET(tp->t_state, TS_TTSTOP);
1641 } else if (flag == 0) {
1645 CLR(tp->t_state, TS_CARR_ON);
1646 if (ISSET(tp->t_state, TS_ISOPEN) &&
1647 !ISSET(tp->t_cflag, CLOCAL)) {
1648 SET(tp->t_state, TS_ZOMBIE);
1649 CLR(tp->t_state, TS_CONNECTED);
1650 if (tp->t_session) {
1651 sx_slock(&proctree_lock);
1652 if (tp->t_session && tp->t_session->s_leader) {
1655 p = tp->t_session->s_leader;
1660 sx_sunlock(&proctree_lock);
1662 ttyflush(tp, FREAD | FWRITE);
1669 SET(tp->t_state, TS_CARR_ON);
1670 if (!ISSET(tp->t_state, TS_ZOMBIE))
1671 SET(tp->t_state, TS_CONNECTED);
1672 wakeup(TSA_CARR_ON(tp));
1680 * Reinput pending characters after state switch
1684 ttypend(struct tty *tp)
1689 CLR(tp->t_lflag, PENDIN);
1690 SET(tp->t_state, TS_TYPEN);
1692 * XXX this assumes too much about clist internals. It may even
1693 * fail if the cblock slush pool is empty. We can't allocate more
1694 * cblocks here because we are called from an interrupt handler
1695 * and clist_alloc_cblocks() can wait.
1698 bzero(&tp->t_rawq, sizeof tp->t_rawq);
1699 tp->t_rawq.c_cbmax = tq.c_cbmax;
1700 tp->t_rawq.c_cbreserved = tq.c_cbreserved;
1701 while ((c = getc(&tq)) >= 0)
1703 CLR(tp->t_state, TS_TYPEN);
1707 * Process a read call on a tty device.
1710 ttread(struct tty *tp, struct uio *uio, int flag)
1715 cc_t *cc = tp->t_cc;
1718 int s, first, error = 0;
1719 int has_stime = 0, last_cc = 0;
1720 long slp = 0; /* XXX this should be renamed `timo'. */
1721 struct timeval stime;
1728 lflag = tp->t_lflag;
1730 * take pending input first
1732 if (ISSET(lflag, PENDIN)) {
1734 splx(s); /* reduce latency */
1736 lflag = tp->t_lflag; /* XXX ttypend() clobbers it */
1740 * Hang process if it's in the background.
1742 if (isbackground(p, tp)) {
1744 sx_slock(&proctree_lock);
1746 if (SIGISMEMBER(p->p_sigacts->ps_sigignore, SIGTTIN) ||
1747 SIGISMEMBER(td->td_sigmask, SIGTTIN) ||
1748 (p->p_flag & P_PPWAIT) || p->p_pgrp->pg_jobc == 0) {
1750 sx_sunlock(&proctree_lock);
1756 sx_sunlock(&proctree_lock);
1757 pgsignal(pg, SIGTTIN, 1);
1759 error = ttysleep(tp, &lbolt, TTIPRI | PCATCH, "ttybg2", 0);
1765 if (ISSET(tp->t_state, TS_ZOMBIE)) {
1767 return (0); /* EOF */
1771 * If canonical, use the canonical queue,
1772 * else use the raw queue.
1774 * (should get rid of clists...)
1776 qp = ISSET(lflag, ICANON) ? &tp->t_canq : &tp->t_rawq;
1778 if (flag & IO_NDELAY) {
1781 if (!ISSET(lflag, ICANON) && cc[VMIN] == 0) {
1786 return (EWOULDBLOCK);
1788 if (!ISSET(lflag, ICANON)) {
1791 struct timeval timecopy;
1794 * Check each of the four combinations.
1795 * (m > 0 && t == 0) is the normal read case.
1796 * It should be fairly efficient, so we check that and its
1797 * companion case (m == 0 && t == 0) first.
1798 * For the other two cases, we compute the target sleep time
1807 /* m, t and qp->c_cc are all 0. 0 is enough input. */
1811 t *= 100000; /* time in us */
1812 #define diff(t1, t2) (((t1).tv_sec - (t2).tv_sec) * 1000000 + \
1813 ((t1).tv_usec - (t2).tv_usec))
1819 getmicrotime(&timecopy);
1821 /* first character, start timer */
1825 } else if (qp->c_cc > last_cc) {
1826 /* got a character, restart timer */
1830 /* nothing, check expiration */
1831 slp = t - diff(timecopy, stime);
1836 } else { /* m == 0 */
1839 getmicrotime(&timecopy);
1845 slp = t - diff(timecopy, stime);
1847 /* Timed out, but 0 is enough input. */
1855 struct timeval tv; /* XXX style bug. */
1857 tv.tv_sec = slp / 1000000;
1858 tv.tv_usec = slp % 1000000;
1861 * XXX bad variable names. slp was the timeout in
1862 * usec. Now it is the timeout in ticks.
1867 if (qp->c_cc <= 0) {
1870 * There is no input, or not enough input and we can block.
1872 error = ttysleep(tp, TSA_HUP_OR_INPUT(tp), TTIPRI | PCATCH,
1873 ISSET(tp->t_state, TS_CONNECTED) ?
1874 "ttyin" : "ttyhup", (int)slp);
1876 if (error == EWOULDBLOCK)
1881 * XXX what happens if another process eats some input
1882 * while we are asleep (not just here)? It would be
1883 * safest to detect changes and reset our state variables
1884 * (has_stime and last_cc).
1892 * Input present, check for input mapping and processing.
1895 if (ISSET(lflag, ICANON | ISIG))
1901 icc = imin(uio->uio_resid, IBUFSIZ);
1902 icc = q_to_b(qp, ibuf, icc);
1908 error = uiomove(ibuf, icc, uio);
1910 * XXX if there was an error then we should ungetc() the
1911 * unmoved chars and reduce icc here.
1915 if (uio->uio_resid == 0)
1929 * delayed suspend (^Y)
1931 if (CCEQ(cc[VDSUSP], c) &&
1932 ISSET(lflag, IEXTEN | ISIG) == (IEXTEN | ISIG)) {
1933 if (tp->t_pgrp != NULL) {
1934 PGRP_LOCK(tp->t_pgrp);
1935 pgsignal(tp->t_pgrp, SIGTSTP, 1);
1936 PGRP_UNLOCK(tp->t_pgrp);
1939 error = ttysleep(tp, &lbolt, TTIPRI | PCATCH,
1948 * Interpret EOF only in canonical mode.
1950 if (CCEQ(cc[VEOF], c) && ISSET(lflag, ICANON))
1953 * Give user character.
1955 error = ureadc(c, uio);
1957 /* XXX should ungetc(c, qp). */
1959 if (uio->uio_resid == 0)
1962 * In canonical mode check for a "break character"
1963 * marking the end of a "line of input".
1965 if (ISSET(lflag, ICANON) && TTBREAKC(c, lflag))
1972 * Look to unblock input now that (presumably)
1973 * the input queue has gone down.
1976 if (ISSET(tp->t_state, TS_TBLOCK) &&
1977 tp->t_rawq.c_cc + tp->t_canq.c_cc <= tp->t_ilowat)
1985 * Check the output queue on tp for space for a kernel message (from uprintf
1986 * or tprintf). Allow some space over the normal hiwater mark so we don't
1987 * lose messages due to normal flow control, but don't let the tty run amok.
1988 * Sleeps here are not interruptible, but we return prematurely if new signals
1992 ttycheckoutq(struct tty *tp, int wait)
2001 hiwat = tp->t_ohiwat;
2002 SIGEMPTYSET(oldmask);
2006 oldmask = td->td_siglist;
2009 if (tp->t_outq.c_cc > hiwat + OBUFSIZ + 100)
2010 while (tp->t_outq.c_cc > hiwat) {
2012 if (tp->t_outq.c_cc <= hiwat)
2019 if (!SIGSETEQ(td->td_siglist, oldmask)) {
2025 SET(tp->t_state, TS_SO_OLOWAT);
2026 tsleep(TSA_OLOWAT(tp), PZERO - 1, "ttoutq", hz);
2033 * Process a write call on a tty device.
2036 ttwrite(struct tty *tp, struct uio *uio, int flag)
2042 int i, hiwat, cnt, error, s;
2045 hiwat = tp->t_ohiwat;
2046 cnt = uio->uio_resid;
2053 if (ISSET(tp->t_state, TS_ZOMBIE)) {
2055 if (uio->uio_resid == cnt)
2059 if (!ISSET(tp->t_state, TS_CONNECTED)) {
2060 if (flag & IO_NDELAY) {
2062 error = EWOULDBLOCK;
2065 error = ttysleep(tp, TSA_CARR_ON(tp), TTIPRI | PCATCH,
2074 * Hang the process if it's in the background.
2076 sx_slock(&proctree_lock);
2078 if (isbackground(p, tp) &&
2079 ISSET(tp->t_lflag, TOSTOP) && !(p->p_flag & P_PPWAIT) &&
2080 !SIGISMEMBER(p->p_sigacts->ps_sigignore, SIGTTOU) &&
2081 !SIGISMEMBER(td->td_sigmask, SIGTTOU)) {
2082 if (p->p_pgrp->pg_jobc == 0) {
2084 sx_sunlock(&proctree_lock);
2089 PGRP_LOCK(p->p_pgrp);
2090 sx_sunlock(&proctree_lock);
2091 pgsignal(p->p_pgrp, SIGTTOU, 1);
2092 PGRP_UNLOCK(p->p_pgrp);
2093 error = ttysleep(tp, &lbolt, TTIPRI | PCATCH, "ttybg4", 0);
2099 sx_sunlock(&proctree_lock);
2102 * Process the user's data in at most OBUFSIZ chunks. Perform any
2103 * output translation. Keep track of high water mark, sleep on
2104 * overflow awaiting device aid in acquiring new space.
2106 while (uio->uio_resid > 0 || cc > 0) {
2107 if (ISSET(tp->t_lflag, FLUSHO)) {
2111 if (tp->t_outq.c_cc > hiwat)
2114 * Grab a hunk of data from the user, unless we have some
2115 * leftover from last time.
2118 cc = imin(uio->uio_resid, OBUFSIZ);
2120 error = uiomove(cp, cc, uio);
2127 * If nothing fancy need be done, grab those characters we
2128 * can handle without any of ttyoutput's processing and
2129 * just transfer them to the output q. For those chars
2130 * which require special processing (as indicated by the
2131 * bits in char_type), call ttyoutput. After processing
2132 * a hunk of data, look for FLUSHO so ^O's will take effect
2136 if (!ISSET(tp->t_oflag, OPOST))
2139 ce = cc - scanc((u_int)cc, (u_char *)cp,
2140 char_type, CCLASSMASK);
2142 * If ce is zero, then we're processing
2143 * a special character through ttyoutput.
2147 if (ttyoutput(*cp, tp) >= 0) {
2148 /* No Clists, wait a bit. */
2150 if (flag & IO_NDELAY) {
2151 error = EWOULDBLOCK;
2154 error = ttysleep(tp, &lbolt,
2163 if (ISSET(tp->t_lflag, FLUSHO) ||
2164 tp->t_outq.c_cc > hiwat)
2170 * A bunch of normal characters have been found.
2171 * Transfer them en masse to the output queue and
2172 * continue processing at the top of the loop.
2173 * If there are any further characters in this
2174 * <= OBUFSIZ chunk, the first should be a character
2175 * requiring special handling by ttyoutput.
2178 i = b_to_q(cp, ce, &tp->t_outq);
2181 cp += ce, cc -= ce, tk_nout += ce;
2184 /* No Clists, wait a bit. */
2186 if (flag & IO_NDELAY) {
2187 error = EWOULDBLOCK;
2190 error = ttysleep(tp, &lbolt, TTOPRI | PCATCH,
2196 if (ISSET(tp->t_lflag, FLUSHO) ||
2197 tp->t_outq.c_cc > hiwat)
2204 * If cc is nonzero, we leave the uio structure inconsistent, as the
2205 * offset and iov pointers have moved forward, but it doesn't matter
2206 * (the call will either return short or restart with a new uio).
2208 uio->uio_resid += cc;
2215 * This can only occur if FLUSHO is set in t_lflag,
2216 * or if ttstart/oproc is synchronous (or very fast).
2218 if (tp->t_outq.c_cc <= hiwat) {
2222 if (flag & IO_NDELAY) {
2224 uio->uio_resid += cc;
2225 return (uio->uio_resid == cnt ? EWOULDBLOCK : 0);
2227 SET(tp->t_state, TS_SO_OLOWAT);
2228 error = ttysleep(tp, TSA_OLOWAT(tp), TTOPRI | PCATCH, "ttywri",
2231 if (error == EWOULDBLOCK)
2239 * Rubout one character from the rawq of tp
2240 * as cleanly as possible.
2243 ttyrub(int c, struct tty *tp)
2249 if (!ISSET(tp->t_lflag, ECHO) || ISSET(tp->t_lflag, EXTPROC))
2251 CLR(tp->t_lflag, FLUSHO);
2252 if (ISSET(tp->t_lflag, ECHOE)) {
2253 if (tp->t_rocount == 0) {
2255 * Screwed by ttwrite; retype
2260 if (c == ('\t' | TTY_QUOTE) || c == ('\n' | TTY_QUOTE))
2263 CLR(c, ~TTY_CHARMASK);
2264 switch (CCLASS(c)) {
2273 if (ISSET(tp->t_lflag, ECHOCTL))
2277 if (tp->t_rocount < tp->t_rawq.c_cc) {
2282 savecol = tp->t_column;
2283 SET(tp->t_state, TS_CNTTB);
2284 SET(tp->t_lflag, FLUSHO);
2285 tp->t_column = tp->t_rocol;
2286 cp = tp->t_rawq.c_cf;
2288 tabc = *cp; /* XXX FIX NEXTC */
2289 for (; cp; cp = nextc(&tp->t_rawq, cp, &tabc))
2291 CLR(tp->t_lflag, FLUSHO);
2292 CLR(tp->t_state, TS_CNTTB);
2295 /* savecol will now be length of the tab. */
2296 savecol -= tp->t_column;
2297 tp->t_column += savecol;
2299 savecol = 8; /* overflow screw */
2300 while (--savecol >= 0)
2301 (void)ttyoutput('\b', tp);
2304 #define PANICSTR "ttyrub: would panic c = %d, val = %d\n"
2305 (void)printf(PANICSTR, c, CCLASS(c));
2307 panic(PANICSTR, c, CCLASS(c));
2311 } else if (ISSET(tp->t_lflag, ECHOPRT)) {
2312 if (!ISSET(tp->t_state, TS_ERASE)) {
2313 SET(tp->t_state, TS_ERASE);
2314 (void)ttyoutput('\\', tp);
2318 ttyecho(tp->t_cc[VERASE], tp);
2320 * This code may be executed not only when an ERASE key
2321 * is pressed, but also when ^U (KILL) or ^W (WERASE) are.
2322 * So, I didn't think it was worthwhile to pass the extra
2323 * information (which would need an extra parameter,
2324 * changing every call) needed to distinguish the ERASE2
2325 * case from the ERASE.
2332 * Back over cnt characters, erasing them.
2335 ttyrubo(struct tty *tp, int cnt)
2339 (void)ttyoutput('\b', tp);
2340 (void)ttyoutput(' ', tp);
2341 (void)ttyoutput('\b', tp);
2347 * Reprint the rawq line. Note, it is assumed that c_cc has already
2351 ttyretype(struct tty *tp)
2356 /* Echo the reprint character. */
2357 if (tp->t_cc[VREPRINT] != _POSIX_VDISABLE)
2358 ttyecho(tp->t_cc[VREPRINT], tp);
2360 (void)ttyoutput('\n', tp);
2364 * FIX: NEXTC IS BROKEN - DOESN'T CHECK QUOTE
2365 * BIT OF FIRST CHAR.
2368 for (cp = tp->t_canq.c_cf, c = (cp != NULL ? *cp : 0);
2369 cp != NULL; cp = nextc(&tp->t_canq, cp, &c))
2371 for (cp = tp->t_rawq.c_cf, c = (cp != NULL ? *cp : 0);
2372 cp != NULL; cp = nextc(&tp->t_rawq, cp, &c))
2374 CLR(tp->t_state, TS_ERASE);
2377 tp->t_rocount = tp->t_rawq.c_cc;
2382 * Echo a typed character to the terminal.
2385 ttyecho(int c, struct tty *tp)
2388 if (!ISSET(tp->t_state, TS_CNTTB))
2389 CLR(tp->t_lflag, FLUSHO);
2390 if ((!ISSET(tp->t_lflag, ECHO) &&
2391 (c != '\n' || !ISSET(tp->t_lflag, ECHONL))) ||
2392 ISSET(tp->t_lflag, EXTPROC))
2394 if (ISSET(tp->t_lflag, ECHOCTL) &&
2395 ((ISSET(c, TTY_CHARMASK) <= 037 && c != '\t' && c != '\n') ||
2396 ISSET(c, TTY_CHARMASK) == 0177)) {
2397 (void)ttyoutput('^', tp);
2398 CLR(c, ~TTY_CHARMASK);
2404 (void)ttyoutput(c, tp);
2408 * Wake up any readers on a tty.
2411 ttwakeup(struct tty *tp)
2414 if (SEL_WAITING(&tp->t_rsel))
2415 selwakeuppri(&tp->t_rsel, TTIPRI);
2416 if (ISSET(tp->t_state, TS_ASYNC) && tp->t_sigio != NULL)
2417 pgsigio(&tp->t_sigio, SIGIO, (tp->t_session != NULL));
2418 wakeup(TSA_HUP_OR_INPUT(tp));
2419 KNOTE_UNLOCKED(&tp->t_rsel.si_note, 0);
2423 * Wake up any writers on a tty.
2426 ttwwakeup(struct tty *tp)
2429 if (SEL_WAITING(&tp->t_wsel) && tp->t_outq.c_cc <= tp->t_olowat)
2430 selwakeuppri(&tp->t_wsel, TTOPRI);
2431 if (ISSET(tp->t_state, TS_ASYNC) && tp->t_sigio != NULL)
2432 pgsigio(&tp->t_sigio, SIGIO, (tp->t_session != NULL));
2433 if (ISSET(tp->t_state, TS_BUSY | TS_SO_OCOMPLETE) ==
2434 TS_SO_OCOMPLETE && tp->t_outq.c_cc == 0) {
2435 CLR(tp->t_state, TS_SO_OCOMPLETE);
2436 wakeup(TSA_OCOMPLETE(tp));
2438 if (ISSET(tp->t_state, TS_SO_OLOWAT) &&
2439 tp->t_outq.c_cc <= tp->t_olowat) {
2440 CLR(tp->t_state, TS_SO_OLOWAT);
2441 wakeup(TSA_OLOWAT(tp));
2443 KNOTE_UNLOCKED(&tp->t_wsel.si_note, 0);
2447 * Look up a code for a specified speed in a conversion table;
2448 * used by drivers to map software speed values to hardware parameters.
2451 ttspeedtab(int speed, struct speedtab *table)
2454 for ( ; table->sp_speed != -1; table++)
2455 if (table->sp_speed == speed)
2456 return (table->sp_code);
2461 * Set input and output watermarks and buffer sizes. For input, the
2462 * high watermark is about one second's worth of input above empty, the
2463 * low watermark is slightly below high water, and the buffer size is a
2464 * driver-dependent amount above high water. For output, the watermarks
2465 * are near the ends of the buffer, with about 1 second's worth of input
2466 * between them. All this only applies to the standard line discipline.
2469 ttsetwater(struct tty *tp)
2471 int cps, ttmaxhiwat, x;
2474 clist_alloc_cblocks(&tp->t_canq, TTYHOG, 512);
2475 switch (tp->t_ispeedwat) {
2477 cps = tp->t_ispeed / 10;
2481 * This case is for old drivers that don't know about
2482 * t_ispeedwat. Arrange for them to get the old buffer
2483 * sizes and watermarks.
2485 cps = TTYHOG - 2 * 256;
2486 tp->t_ififosize = 2 * 256;
2489 cps = tp->t_ispeedwat / 10;
2493 tp->t_ilowat = 7 * cps / 8;
2494 x = cps + tp->t_ififosize;
2495 clist_alloc_cblocks(&tp->t_rawq, x, x);
2498 switch (tp->t_ospeedwat) {
2500 cps = tp->t_ospeed / 10;
2501 ttmaxhiwat = 2 * TTMAXHIWAT;
2504 cps = tp->t_ospeed / 10;
2505 ttmaxhiwat = TTMAXHIWAT;
2508 cps = tp->t_ospeedwat / 10;
2509 ttmaxhiwat = 8 * TTMAXHIWAT;
2512 #define CLAMP(x, h, l) ((x) > h ? h : ((x) < l) ? l : (x))
2513 tp->t_olowat = x = CLAMP(cps / 2, TTMAXLOWAT, TTMINLOWAT);
2515 x = CLAMP(x, ttmaxhiwat, TTMINHIWAT); /* XXX clamps are too magic */
2516 tp->t_ohiwat = roundup(x, CBSIZE); /* XXX for compat */
2517 x = imax(tp->t_ohiwat, TTMAXHIWAT); /* XXX for compat/safety */
2519 clist_alloc_cblocks(&tp->t_outq, x, x);
2524 * Report on state of foreground process group.
2527 ttyinfo(struct tty *tp)
2529 struct timeval utime, stime;
2530 struct proc *p, *pick;
2532 const char *stateprefix, *state;
2536 char comm[MAXCOMLEN + 1];
2538 if (ttycheckoutq(tp,0) == 0)
2541 /* Print load average. */
2542 load = (averunnable.ldavg[0] * 100 + FSCALE / 2) >> FSHIFT;
2543 ttyprintf(tp, "load: %d.%02d ", load / 100, load % 100);
2546 * On return following a ttyprintf(), we set tp->t_rocount to 0 so
2547 * that pending input will be retyped on BS.
2549 if (tp->t_session == NULL) {
2550 ttyprintf(tp, "not a controlling terminal\n");
2554 if (tp->t_pgrp == NULL) {
2555 ttyprintf(tp, "no foreground process group\n");
2559 PGRP_LOCK(tp->t_pgrp);
2560 if (LIST_EMPTY(&tp->t_pgrp->pg_members)) {
2561 PGRP_UNLOCK(tp->t_pgrp);
2562 ttyprintf(tp, "empty foreground process group\n");
2568 * Pick the most interesting process and copy some of its
2569 * state for printing later. sched_lock must be held for
2570 * most parts of this. Holding it throughout is simplest
2571 * and prevents even unimportant inconsistencies in the
2572 * copy of the state, but may increase interrupt latency
2576 mtx_lock_spin(&sched_lock);
2577 LIST_FOREACH(p, &tp->t_pgrp->pg_members, p_pglist)
2578 if (proc_compare(pick, p))
2581 /*^T can only show state for 1 thread. just pick the first. */
2582 td = FIRST_THREAD_IN_PROC(pick);
2584 if (TD_IS_RUNNING(td))
2586 else if (TD_ON_RUNQ(td) || TD_CAN_RUN(td))
2588 else if (TD_IS_SLEEPING(td)) {
2589 /* XXX: If we're sleeping, are we ever not in a queue? */
2590 if (TD_ON_SLEEPQ(td))
2591 state = td->td_wmesg;
2593 state = "sleeping without queue";
2594 } else if (TD_ON_LOCK(td)) {
2595 state = td->td_lockname;
2597 } else if (TD_IS_SUSPENDED(td))
2598 state = "suspended";
2599 else if (TD_AWAITING_INTR(td))
2603 pctcpu = (sched_pctcpu(td) * 10000 + FSCALE / 2) >> FSHIFT;
2604 if (pick->p_state == PRS_NEW || pick->p_state == PRS_ZOMBIE)
2607 rss = pgtok(vmspace_resident_count(pick->p_vmspace));
2608 mtx_unlock_spin(&sched_lock);
2610 PGRP_UNLOCK(tp->t_pgrp);
2611 calcru(pick, &utime, &stime);
2613 bcopy(pick->p_comm, comm, sizeof(comm));
2616 /* Print command, pid, state, utime, stime, %cpu, and rss. */
2618 " cmd: %s %d [%s%s] %ld.%02ldu %ld.%02lds %d%% %ldk\n",
2619 comm, pid, stateprefix, state,
2620 (long)utime.tv_sec, utime.tv_usec / 10000,
2621 (long)stime.tv_sec, stime.tv_usec / 10000,
2627 * Returns 1 if p2 is "better" than p1
2629 * The algorithm for picking the "interesting" process is thus:
2631 * 1) Only foreground processes are eligible - implied.
2632 * 2) Runnable processes are favored over anything else. The runner
2633 * with the highest cpu utilization is picked (p_estcpu). Ties are
2634 * broken by picking the highest pid.
2635 * 3) The sleeper with the shortest sleep time is next. With ties,
2636 * we pick out just "short-term" sleepers (P_SINTR == 0).
2637 * 4) Further ties are broken by picking the highest pid.
2639 #define ISRUN(p, val) \
2641 struct thread *td; \
2643 FOREACH_THREAD_IN_PROC(p, td) { \
2644 if (TD_ON_RUNQ(td) || \
2645 TD_IS_RUNNING(td)) { \
2652 #define TESTAB(a, b) ((a)<<1 | (b))
2658 proc_compare(struct proc *p1, struct proc *p2)
2663 mtx_assert(&sched_lock, MA_OWNED);
2671 * see if at least one of them is runnable
2673 switch (TESTAB(esta, estb)) {
2680 * tie - favor one with highest recent cpu utilization
2683 FOREACH_THREAD_IN_PROC(p1, td)
2684 esta += td->td_estcpu;
2685 FOREACH_THREAD_IN_PROC(p2, td)
2686 estb += td->td_estcpu;
2691 return (p2->p_pid > p1->p_pid); /* tie - return highest pid */
2696 switch (TESTAB(p1->p_state == PRS_ZOMBIE, p2->p_state == PRS_ZOMBIE)) {
2702 return (p2->p_pid > p1->p_pid); /* tie - return highest pid */
2707 * pick the one with the smallest sleep time
2709 if (p2->p_slptime > p1->p_slptime)
2711 if (p1->p_slptime > p2->p_slptime)
2714 * favor one sleeping in a non-interruptible sleep
2716 if (p1->p_sflag & PS_SINTR && (p2->p_sflag & PS_SINTR) == 0)
2718 if (p2->p_sflag & PS_SINTR && (p1->p_sflag & PS_SINTR) == 0)
2721 return (p2->p_pid > p1->p_pid); /* tie - return highest pid */
2725 * Output char to tty; console putchar style.
2728 tputchar(int c, struct tty *tp)
2733 if (!ISSET(tp->t_state, TS_CONNECTED)) {
2738 (void)ttyoutput('\r', tp);
2739 (void)ttyoutput(c, tp);
2746 * Sleep on chan, returning ERESTART if tty changed while we napped and
2747 * returning any errors (e.g. EINTR/EWOULDBLOCK) reported by tsleep. If
2748 * the tty is revoked, restarting a pending call will redo validation done
2749 * at the start of the call.
2752 ttysleep(struct tty *tp, void *chan, int pri, char *wmesg, int timo)
2758 error = tsleep(chan, pri, wmesg, timo);
2759 if (tp->t_state & TS_GONE)
2763 return (tp->t_gen == gen ? 0 : ERESTART);
2767 * Gain a reference to a TTY
2770 ttyref(struct tty *tp)
2774 mtx_lock(&tp->t_mtx);
2775 KASSERT(tp->t_refcnt > 0,
2776 ("ttyref(): tty refcnt is %d (%s)",
2777 tp->t_refcnt, tp->t_dev != NULL ? devtoname(tp->t_dev) : "??"));
2779 mtx_unlock(&tp->t_mtx);
2784 * Drop a reference to a TTY.
2785 * When reference count drops to zero, we free it.
2788 ttyrel(struct tty *tp)
2792 mtx_lock(&tty_list_mutex);
2793 mtx_lock(&tp->t_mtx);
2794 KASSERT(tp->t_refcnt > 0,
2795 ("ttyrel(): tty refcnt is %d (%s)",
2796 tp->t_refcnt, tp->t_dev != NULL ? devtoname(tp->t_dev) : "??"));
2799 mtx_unlock(&tp->t_mtx);
2800 mtx_unlock(&tty_list_mutex);
2803 TAILQ_REMOVE(&tty_list, tp, t_list);
2804 mtx_unlock(&tp->t_mtx);
2805 mtx_unlock(&tty_list_mutex);
2806 knlist_destroy(&tp->t_rsel.si_note);
2807 knlist_destroy(&tp->t_wsel.si_note);
2808 mtx_destroy(&tp->t_mtx);
2814 * Allocate a tty struct. Clists in the struct will be allocated by
2822 tp = malloc(sizeof *tp, M_TTYS, M_WAITOK | M_ZERO);
2823 mtx_init(&tp->t_mtx, "tty", NULL, MTX_DEF);
2826 * Set up the initial state
2830 tp->t_dtr_wait = 3 * hz;
2832 ttyinitmode(tp, 0, 0);
2833 bcopy(ttydefchars, tp->t_init_in.c_cc, sizeof tp->t_init_in.c_cc);
2835 /* Make callout the same as callin */
2836 tp->t_init_out = tp->t_init_in;
2838 mtx_lock(&tty_list_mutex);
2839 TAILQ_INSERT_TAIL(&tty_list, tp, t_list);
2840 mtx_unlock(&tty_list_mutex);
2841 knlist_init(&tp->t_rsel.si_note, &tp->t_mtx, NULL, NULL, NULL);
2842 knlist_init(&tp->t_wsel.si_note, &tp->t_mtx, NULL, NULL, NULL);
2847 ttypurge(struct cdev *dev)
2850 if (dev->si_tty == NULL)
2852 ttygone(dev->si_tty);
2858 * Create the device entries for this tty thereby opening it for business.
2860 * The flags argument controls if "cua" units are created.
2862 * The t_sc filed is copied to si_drv1 in the created cdevs. This
2863 * is particularly important for ->t_cioctl() users.
2865 * XXX: implement the init and lock devices by cloning.
2869 ttycreate(struct tty *tp, int flags, const char *fmt, ...)
2871 char namebuf[SPECNAMELEN - 3]; /* XXX space for "tty" */
2872 struct cdevsw *csw = NULL;
2876 int i, minor, sminor, sunit;
2878 mtx_assert(&Giant, MA_OWNED);
2880 if (tty_unit == NULL)
2881 tty_unit = new_unrhdr(0, 0xffff, NULL);
2883 sunit = alloc_unr(tty_unit);
2884 tp->t_devunit = sunit;
2890 KASSERT(csw->d_purge == NULL || csw->d_purge == ttypurge,
2891 ("tty should not have d_purge"));
2893 csw->d_purge = ttypurge;
2895 minor = unit2minor(unit);
2896 sminor = unit2minor(sunit);
2898 i = vsnrprintf(namebuf, sizeof namebuf, 32, fmt, ap);
2900 KASSERT(i < sizeof namebuf, ("Too long tty name (%s)", namebuf));
2902 cp = make_dev(csw, minor,
2903 UID_ROOT, GID_WHEEL, 0600, "tty%s", namebuf);
2907 cp->si_drv1 = tp->t_sc;
2909 cp = make_dev(&ttys_cdevsw, sminor | MINOR_INIT,
2910 UID_ROOT, GID_WHEEL, 0600, "tty%s.init", namebuf);
2911 dev_depends(tp->t_dev, cp);
2912 cp->si_drv1 = tp->t_sc;
2913 cp->si_drv2 = &tp->t_init_in;
2916 cp = make_dev(&ttys_cdevsw, sminor | MINOR_LOCK,
2917 UID_ROOT, GID_WHEEL, 0600, "tty%s.lock", namebuf);
2918 dev_depends(tp->t_dev, cp);
2919 cp->si_drv1 = tp->t_sc;
2920 cp->si_drv2 = &tp->t_lock_in;
2923 if (flags & TS_CALLOUT) {
2924 cp = make_dev(csw, minor | MINOR_CALLOUT,
2925 UID_UUCP, GID_DIALER, 0660, "cua%s", namebuf);
2926 dev_depends(tp->t_dev, cp);
2927 cp->si_drv1 = tp->t_sc;
2930 cp = make_dev(&ttys_cdevsw, sminor | MINOR_CALLOUT | MINOR_INIT,
2931 UID_UUCP, GID_DIALER, 0660, "cua%s.init", namebuf);
2932 dev_depends(tp->t_dev, cp);
2933 cp->si_drv1 = tp->t_sc;
2934 cp->si_drv2 = &tp->t_init_out;
2937 cp = make_dev(&ttys_cdevsw, sminor | MINOR_CALLOUT | MINOR_LOCK,
2938 UID_UUCP, GID_DIALER, 0660, "cua%s.lock", namebuf);
2939 dev_depends(tp->t_dev, cp);
2940 cp->si_drv1 = tp->t_sc;
2941 cp->si_drv2 = &tp->t_lock_out;
2949 * This function is called when the hardware disappears. We set a flag
2950 * and wake up stuff so all sleeping threads will notice.
2953 ttygone(struct tty *tp)
2956 tp->t_state |= TS_GONE;
2957 wakeup(&tp->t_dtr_wait);
2958 wakeup(TSA_CARR_ON(tp));
2959 wakeup(TSA_HUP_OR_INPUT(tp));
2960 wakeup(TSA_OCOMPLETE(tp));
2961 wakeup(TSA_OLOWAT(tp));
2968 * Called when the driver is ready to free the tty structure.
2970 * XXX: This shall sleep until all threads have left the driver.
2974 ttyfree(struct tty *tp)
2978 mtx_assert(&Giant, MA_OWNED);
2980 unit = tp->t_devunit;
2981 destroy_dev(tp->t_mdev);
2982 free_unr(tty_unit, unit);
2986 sysctl_kern_ttys(SYSCTL_HANDLER_ARGS)
2988 struct tty *tp, *tp2;
2993 mtx_lock(&tty_list_mutex);
2994 tp = TAILQ_FIRST(&tty_list);
2997 mtx_unlock(&tty_list_mutex);
2998 while (tp != NULL) {
2999 bzero(&xt, sizeof xt);
3000 xt.xt_size = sizeof xt;
3001 #define XT_COPY(field) xt.xt_##field = tp->t_##field
3002 xt.xt_rawcc = tp->t_rawq.c_cc;
3003 xt.xt_cancc = tp->t_canq.c_cc;
3004 xt.xt_outcc = tp->t_outq.c_cc;
3006 if (tp->t_dev != NULL)
3007 xt.xt_dev = dev2udev(tp->t_dev);
3011 if (tp->t_pgrp != NULL)
3012 xt.xt_pgid = tp->t_pgrp->pg_id;
3013 if (tp->t_session != NULL)
3014 xt.xt_sid = tp->t_session->s_sid;
3028 error = SYSCTL_OUT(req, &xt, sizeof xt);
3033 mtx_lock(&tty_list_mutex);
3034 tp2 = TAILQ_NEXT(tp, t_list);
3037 mtx_unlock(&tty_list_mutex);
3044 SYSCTL_PROC(_kern, OID_AUTO, ttys, CTLTYPE_OPAQUE|CTLFLAG_RD,
3045 0, 0, sysctl_kern_ttys, "S,xtty", "All ttys");
3046 SYSCTL_LONG(_kern, OID_AUTO, tty_nin, CTLFLAG_RD,
3047 &tk_nin, 0, "Total TTY in characters");
3048 SYSCTL_LONG(_kern, OID_AUTO, tty_nout, CTLFLAG_RD,
3049 &tk_nout, 0, "Total TTY out characters");
3052 nottystop(struct tty *tp, int rw)
3059 ttyopen(struct cdev *dev, int flag, int mode, struct thread *td)
3069 * We jump to this label after all non-interrupted sleeps to pick
3070 * up any changes of the device state.
3073 if (tp->t_state & TS_GONE)
3075 error = ttydtrwaitsleep(tp);
3078 if (tp->t_state & TS_ISOPEN) {
3080 * The device is open, so everything has been initialized.
3083 if (ISCALLOUT(dev) && !tp->t_actout)
3085 if (tp->t_actout && !ISCALLOUT(dev)) {
3086 if (flag & O_NONBLOCK)
3088 error = tsleep(&tp->t_actout,
3089 TTIPRI | PCATCH, "ttybi", 0);
3090 if (error != 0 || (tp->t_flags & TS_GONE))
3094 if (tp->t_state & TS_XCLUDE && priv_check(td,
3095 PRIV_TTY_EXCLUSIVE))
3099 * The device isn't open, so there are no conflicts.
3100 * Initialize it. Initialization is done twice in many
3101 * cases: to preempt sleeping callin opens if we are
3102 * callout, and to complete a callin open after DCD rises.
3104 tp->t_termios = ISCALLOUT(dev) ? tp->t_init_out : tp->t_init_in;
3105 tp->t_cflag = tp->t_termios.c_cflag;
3106 if (tp->t_modem != NULL)
3107 tt_modem(tp, SER_DTR | SER_RTS, 0);
3109 error = tt_param(tp, &tp->t_termios);
3112 error = tt_open(tp, dev);
3115 if (ISCALLOUT(dev) || (tt_modem(tp, 0, 0) & SER_DCD))
3119 * Wait for DCD if necessary.
3121 if (!(tp->t_state & TS_CARR_ON) && !ISCALLOUT(dev)
3122 && !(tp->t_cflag & CLOCAL) && !(flag & O_NONBLOCK)) {
3124 error = tsleep(TSA_CARR_ON(tp), TTIPRI | PCATCH, "ttydcd", 0);
3126 if (error != 0 || (tp->t_state & TS_GONE))
3130 error = ttyld_open(tp, dev);
3132 if (tp->t_state & TS_ISOPEN && ISCALLOUT(dev))
3133 tp->t_actout = TRUE;
3136 if (!(tp->t_state & TS_ISOPEN) && tp->t_wopeners == 0)
3142 ttyclose(struct cdev *dev, int flag, int mode, struct thread *td)
3147 ttyld_close(tp, flag);
3150 tp->t_do_timestamp = 0;
3151 if (tp->t_pps != NULL)
3152 tp->t_pps->ppsparam.mode = 0;
3158 ttyread(struct cdev *dev, struct uio *uio, int flag)
3162 tp = tty_gettp(dev);
3164 if (tp->t_state & TS_GONE)
3166 return (ttyld_read(tp, uio, flag));
3170 ttywrite(struct cdev *dev, struct uio *uio, int flag)
3174 tp = tty_gettp(dev);
3176 if (tp->t_state & TS_GONE)
3178 return (ttyld_write(tp, uio, flag));
3182 ttyioctl(struct cdev *dev, u_long cmd, caddr_t data, int flag, struct thread *td)
3189 if (cmd == TIOCSETA || cmd == TIOCSETAW || cmd == TIOCSETAF) {
3191 struct termios *dt = (struct termios *)data;
3192 struct termios *lt =
3193 ISCALLOUT(dev) ? &tp->t_lock_out : &tp->t_lock_in;
3195 dt->c_iflag = (tp->t_iflag & lt->c_iflag)
3196 | (dt->c_iflag & ~lt->c_iflag);
3197 dt->c_oflag = (tp->t_oflag & lt->c_oflag)
3198 | (dt->c_oflag & ~lt->c_oflag);
3199 dt->c_cflag = (tp->t_cflag & lt->c_cflag)
3200 | (dt->c_cflag & ~lt->c_cflag);
3201 dt->c_lflag = (tp->t_lflag & lt->c_lflag)
3202 | (dt->c_lflag & ~lt->c_lflag);
3203 for (cc = 0; cc < NCCS; ++cc)
3204 if (lt->c_cc[cc] != 0)
3205 dt->c_cc[cc] = tp->t_cc[cc];
3206 if (lt->c_ispeed != 0)
3207 dt->c_ispeed = tp->t_ispeed;
3208 if (lt->c_ospeed != 0)
3209 dt->c_ospeed = tp->t_ospeed;
3212 error = ttyld_ioctl(tp, cmd, data, flag, td);
3213 if (error == ENOIOCTL)
3214 error = ttioctl(tp, cmd, data, flag);
3216 if (error != ENOIOCTL)
3222 ttyldoptim(struct tty *tp)
3227 if (!(t->c_iflag & (ICRNL | IGNCR | IMAXBEL | INLCR | ISTRIP | IXON))
3228 && (!(t->c_iflag & BRKINT) || (t->c_iflag & IGNBRK))
3229 && (!(t->c_iflag & PARMRK)
3230 || (t->c_iflag & (IGNPAR | IGNBRK)) == (IGNPAR | IGNBRK))
3231 && !(t->c_lflag & (ECHO | ICANON | IEXTEN | ISIG | PENDIN))
3232 && linesw[tp->t_line]->l_rint == ttyinput)
3233 tp->t_state |= TS_CAN_BYPASS_L_RINT;
3235 tp->t_state &= ~TS_CAN_BYPASS_L_RINT;
3239 ttydtrwaitwakeup(void *arg)
3244 tp->t_state &= ~TS_DTR_WAIT;
3245 wakeup(&tp->t_dtr_wait);
3250 ttydtrwaitstart(struct tty *tp)
3253 if (tp->t_dtr_wait == 0)
3255 if (tp->t_state & TS_DTR_WAIT)
3257 timeout(ttydtrwaitwakeup, tp, tp->t_dtr_wait);
3258 tp->t_state |= TS_DTR_WAIT;
3262 ttydtrwaitsleep(struct tty *tp)
3267 while (error == 0) {
3268 if (tp->t_state & TS_GONE)
3270 else if (!(tp->t_state & TS_DTR_WAIT))
3273 error = tsleep(&tp->t_dtr_wait, TTIPRI | PCATCH,
3280 ttysopen(struct cdev *dev, int flag, int mode, struct thread *td)
3286 ("ttysopen(): no tty pointer on device (%s)", devtoname(dev)));
3287 if (tp->t_state & TS_GONE)
3293 ttysclose(struct cdev *dev, int flag, int mode, struct thread *td)
3300 ttysrdwr(struct cdev *dev, struct uio *uio, int flag)
3307 ttysioctl(struct cdev *dev, u_long cmd, caddr_t data, int flag, struct thread *td)
3315 ("ttysopen(): no tty pointer on device (%s)", devtoname(dev)));
3316 if (tp->t_state & TS_GONE)
3321 error = priv_check(td, PRIV_TTY_SETA);
3324 *ct = *(struct termios *)data;
3327 *(struct termios *)data = *ct;
3330 *(int *)data = TTYDISC;
3333 bzero(data, sizeof(struct winsize));
3336 if (tp->t_cioctl != NULL)
3337 return(tp->t_cioctl(dev, cmd, data, flag, td));
3343 * Initialize a tty to sane modes.
3346 ttyinitmode(struct tty *tp, int echo, int speed)
3350 speed = TTYDEF_SPEED;
3351 tp->t_init_in.c_iflag = TTYDEF_IFLAG;
3352 tp->t_init_in.c_oflag = TTYDEF_OFLAG;
3353 tp->t_init_in.c_cflag = TTYDEF_CFLAG;
3355 tp->t_init_in.c_lflag = TTYDEF_LFLAG_ECHO;
3357 tp->t_init_in.c_lflag = TTYDEF_LFLAG_NOECHO;
3359 tp->t_init_in.c_ispeed = tp->t_init_in.c_ospeed = speed;
3360 termioschars(&tp->t_init_in);
3361 tp->t_init_out = tp->t_init_in;
3362 tp->t_termios = tp->t_init_in;
3366 * Use more "normal" termios paramters for consoles.
3369 ttyconsolemode(struct tty *tp, int speed)
3373 speed = TTYDEF_SPEED;
3374 ttyinitmode(tp, 1, speed);
3375 tp->t_init_in.c_cflag |= CLOCAL;
3376 tp->t_lock_out.c_cflag = tp->t_lock_in.c_cflag = CLOCAL;
3377 tp->t_lock_out.c_ispeed = tp->t_lock_out.c_ospeed =
3378 tp->t_lock_in.c_ispeed = tp->t_lock_in.c_ospeed = speed;
3379 tp->t_init_out = tp->t_init_in;
3380 tp->t_termios = tp->t_init_in;
3385 * Record the relationship between the serial ports notion of modem control
3386 * signals and the one used in certain ioctls in a way the compiler can enforce
3387 * XXX: We should define TIOCM_* in terms of SER_ if we can limit the
3388 * XXX: consequences of the #include work that would take.
3390 CTASSERT(SER_DTR == TIOCM_DTR / 2);
3391 CTASSERT(SER_RTS == TIOCM_RTS / 2);
3392 CTASSERT(SER_STX == TIOCM_ST / 2);
3393 CTASSERT(SER_SRX == TIOCM_SR / 2);
3394 CTASSERT(SER_CTS == TIOCM_CTS / 2);
3395 CTASSERT(SER_DCD == TIOCM_DCD / 2);
3396 CTASSERT(SER_RI == TIOCM_RI / 2);
3397 CTASSERT(SER_DSR == TIOCM_DSR / 2);