1 /*- 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. 9 * 10 * Redistribution and use in source and binary forms, with or without 11 * modification, are permitted provided that the following conditions 12 * are met: 13 * 1. Redistributions of source code must retain the above copyright 14 * notice, this list of conditions and the following disclaimer. 15 * 2. Redistributions in binary form must reproduce the above copyright 16 * notice, this list of conditions and the following disclaimer in the 17 * documentation and/or other materials provided with the distribution. 18 * 3. All advertising materials mentioning features or use of this software 19 * must display the following acknowledgement: 20 * This product includes software developed by the University of 21 * California, Berkeley and its contributors. 22 * 4. Neither the name of the University nor the names of its contributors 23 * may be used to endorse or promote products derived from this software 24 * without specific prior written permission. 25 * 26 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 27 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 28 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 29 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 30 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 31 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 32 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 33 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 34 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 35 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 36 * SUCH DAMAGE. 37 * 38 * @(#)tty.c 8.8 (Berkeley) 1/21/94 39 * $FreeBSD$ 40 */ 41 42 /*- 43 * TODO: 44 * o Fix races for sending the start char in ttyflush(). 45 * o Handle inter-byte timeout for "MIN > 0, TIME > 0" in ttyselect(). 46 * With luck, there will be MIN chars before select() returns(). 47 * o Handle CLOCAL consistently for ptys. Perhaps disallow setting it. 48 * o Don't allow input in TS_ZOMBIE case. It would be visible through 49 * FIONREAD. 50 * o Do the new sio locking stuff here and use it to avoid special 51 * case for EXTPROC? 52 * o Lock PENDIN too? 53 * o Move EXTPROC and/or PENDIN to t_state? 54 * o Wrap most of ttioctl in spltty/splx. 55 * o Implement TIOCNOTTY or remove it from <sys/ioctl.h>. 56 * o Send STOP if IXOFF is toggled off while TS_TBLOCK is set. 57 * o Don't allow certain termios flags to affect disciplines other 58 * than TTYDISC. Cancel their effects before switch disciplines 59 * and ignore them if they are set while we are in another 60 * discipline. 61 * o Now that historical speed conversions are handled here, don't 62 * do them in drivers. 63 * o Check for TS_CARR_ON being set while everything is closed and not 64 * waiting for carrier. TS_CARR_ON isn't cleared if nothing is open, 65 * so it would live until the next open even if carrier drops. 66 * o Restore TS_WOPEN since it is useful in pstat. It must be cleared 67 * only when _all_ openers leave open(). 68 */ 69 70 #include "snp.h" 71 #include "opt_compat.h" 72 #include "opt_uconsole.h" 73 74 #include <sys/param.h> 75 #include <sys/systm.h> 76 #include <sys/filio.h> 77 #if defined(COMPAT_43) || defined(COMPAT_SUNOS) 78 #include <sys/ioctl_compat.h> 79 #endif 80 #include <sys/proc.h> 81 #define TTYDEFCHARS 82 #include <sys/tty.h> 83 #undef TTYDEFCHARS 84 #include <sys/fcntl.h> 85 #include <sys/conf.h> 86 #include <sys/dkstat.h> 87 #include <sys/poll.h> 88 #include <sys/kernel.h> 89 #include <sys/vnode.h> 90 #include <sys/signalvar.h> 91 #include <sys/resourcevar.h> 92 #include <sys/malloc.h> 93 #include <sys/filedesc.h> 94 #if NSNP > 0 95 #include <sys/snoop.h> 96 #endif 97 #include <sys/sysctl.h> 98 99 #include <vm/vm.h> 100 #include <sys/lock.h> 101 #include <vm/pmap.h> 102 #include <vm/vm_map.h> 103 104 MALLOC_DEFINE(M_TTYS, "ttys", "tty data structures"); 105 106 static int proc_compare __P((struct proc *p1, struct proc *p2)); 107 static int ttnread __P((struct tty *tp)); 108 static void ttyecho __P((int c, struct tty *tp)); 109 static int ttyoutput __P((int c, register struct tty *tp)); 110 static void ttypend __P((struct tty *tp)); 111 static void ttyretype __P((struct tty *tp)); 112 static void ttyrub __P((int c, struct tty *tp)); 113 static void ttyrubo __P((struct tty *tp, int cnt)); 114 static void ttyunblock __P((struct tty *tp)); 115 static int ttywflush __P((struct tty *tp)); 116 117 /* 118 * Table with character classes and parity. The 8th bit indicates parity, 119 * the 7th bit indicates the character is an alphameric or underscore (for 120 * ALTWERASE), and the low 6 bits indicate delay type. If the low 6 bits 121 * are 0 then the character needs no special processing on output; classes 122 * other than 0 might be translated or (not currently) require delays. 123 */ 124 #define E 0x00 /* Even parity. */ 125 #define O 0x80 /* Odd parity. */ 126 #define PARITY(c) (char_type[c] & O) 127 128 #define ALPHA 0x40 /* Alpha or underscore. */ 129 #define ISALPHA(c) (char_type[(c) & TTY_CHARMASK] & ALPHA) 130 131 #define CCLASSMASK 0x3f 132 #define CCLASS(c) (char_type[c] & CCLASSMASK) 133 134 #define BS BACKSPACE 135 #define CC CONTROL 136 #define CR RETURN 137 #define NA ORDINARY | ALPHA 138 #define NL NEWLINE 139 #define NO ORDINARY 140 #define TB TAB 141 #define VT VTAB 142 143 static u_char const char_type[] = { 144 E|CC, O|CC, O|CC, E|CC, O|CC, E|CC, E|CC, O|CC, /* nul - bel */ 145 O|BS, E|TB, E|NL, O|CC, E|VT, O|CR, O|CC, E|CC, /* bs - si */ 146 O|CC, E|CC, E|CC, O|CC, E|CC, O|CC, O|CC, E|CC, /* dle - etb */ 147 E|CC, O|CC, O|CC, E|CC, O|CC, E|CC, E|CC, O|CC, /* can - us */ 148 O|NO, E|NO, E|NO, O|NO, E|NO, O|NO, O|NO, E|NO, /* sp - ' */ 149 E|NO, O|NO, O|NO, E|NO, O|NO, E|NO, E|NO, O|NO, /* ( - / */ 150 E|NA, O|NA, O|NA, E|NA, O|NA, E|NA, E|NA, O|NA, /* 0 - 7 */ 151 O|NA, E|NA, E|NO, O|NO, E|NO, O|NO, O|NO, E|NO, /* 8 - ? */ 152 O|NO, E|NA, E|NA, O|NA, E|NA, O|NA, O|NA, E|NA, /* @ - G */ 153 E|NA, O|NA, O|NA, E|NA, O|NA, E|NA, E|NA, O|NA, /* H - O */ 154 E|NA, O|NA, O|NA, E|NA, O|NA, E|NA, E|NA, O|NA, /* P - W */ 155 O|NA, E|NA, E|NA, O|NO, E|NO, O|NO, O|NO, O|NA, /* X - _ */ 156 E|NO, O|NA, O|NA, E|NA, O|NA, E|NA, E|NA, O|NA, /* ` - g */ 157 O|NA, E|NA, E|NA, O|NA, E|NA, O|NA, O|NA, E|NA, /* h - o */ 158 O|NA, E|NA, E|NA, O|NA, E|NA, O|NA, O|NA, E|NA, /* p - w */ 159 E|NA, O|NA, O|NA, E|NO, O|NO, E|NO, E|NO, O|CC, /* x - del */ 160 /* 161 * Meta chars; should be settable per character set; 162 * for now, treat them all as normal characters. 163 */ 164 NA, NA, NA, NA, NA, NA, NA, NA, 165 NA, NA, NA, NA, NA, NA, NA, NA, 166 NA, NA, NA, NA, NA, NA, NA, NA, 167 NA, NA, NA, NA, NA, NA, NA, NA, 168 NA, NA, NA, NA, NA, NA, NA, NA, 169 NA, NA, NA, NA, NA, NA, NA, NA, 170 NA, NA, NA, NA, NA, NA, NA, NA, 171 NA, NA, NA, NA, NA, NA, NA, NA, 172 NA, NA, NA, NA, NA, NA, NA, NA, 173 NA, NA, NA, NA, NA, NA, NA, NA, 174 NA, NA, NA, NA, NA, NA, NA, NA, 175 NA, NA, NA, NA, NA, NA, NA, NA, 176 NA, NA, NA, NA, NA, NA, NA, NA, 177 NA, NA, NA, NA, NA, NA, NA, NA, 178 NA, NA, NA, NA, NA, NA, NA, NA, 179 NA, NA, NA, NA, NA, NA, NA, NA, 180 }; 181 #undef BS 182 #undef CC 183 #undef CR 184 #undef NA 185 #undef NL 186 #undef NO 187 #undef TB 188 #undef VT 189 190 /* Macros to clear/set/test flags. */ 191 #define SET(t, f) (t) |= (f) 192 #define CLR(t, f) (t) &= ~(f) 193 #define ISSET(t, f) ((t) & (f)) 194 195 #undef MAX_INPUT /* XXX wrong in <sys/syslimits.h> */ 196 #define MAX_INPUT TTYHOG /* XXX limit is usually larger for !ICANON */ 197 198 /* 199 * list of struct tty where pstat(8) can pick it up with sysctl 200 */ 201 static SLIST_HEAD(, tty) tty_list; 202 203 static int drainwait = 5*60; 204 SYSCTL_INT(_kern, OID_AUTO, drainwait, CTLFLAG_RW, &drainwait, 205 0, "Output drain timeout in seconds"); 206 207 /* 208 * Initial open of tty, or (re)entry to standard tty line discipline. 209 */ 210 int 211 ttyopen(device, tp) 212 dev_t device; 213 register struct tty *tp; 214 { 215 int s; 216 217 s = spltty(); 218 tp->t_dev = device; 219 if (!ISSET(tp->t_state, TS_ISOPEN)) { 220 SET(tp->t_state, TS_ISOPEN); 221 if (ISSET(tp->t_cflag, CLOCAL)) 222 SET(tp->t_state, TS_CONNECTED); 223 bzero(&tp->t_winsize, sizeof(tp->t_winsize)); 224 } 225 /* XXX don't hang forever on output */ 226 if (tp->t_timeout < 0) 227 tp->t_timeout = drainwait*hz; 228 ttsetwater(tp); 229 splx(s); 230 return (0); 231 } 232 233 /* 234 * Handle close() on a tty line: flush and set to initial state, 235 * bumping generation number so that pending read/write calls 236 * can detect recycling of the tty. 237 * XXX our caller should have done `spltty(); l_close(); ttyclose();' 238 * and l_close() should have flushed, but we repeat the spltty() and 239 * the flush in case there are buggy callers. 240 */ 241 int 242 ttyclose(tp) 243 register struct tty *tp; 244 { 245 int s; 246 247 funsetown(tp->t_sigio); 248 s = spltty(); 249 if (constty == tp) 250 constty = NULL; 251 252 ttyflush(tp, FREAD | FWRITE); 253 clist_free_cblocks(&tp->t_canq); 254 clist_free_cblocks(&tp->t_outq); 255 clist_free_cblocks(&tp->t_rawq); 256 257 #if NSNP > 0 258 if (ISSET(tp->t_state, TS_SNOOP) && tp->t_sc != NULL) 259 snpdown((struct snoop *)tp->t_sc); 260 #endif 261 262 tp->t_gen++; 263 tp->t_line = TTYDISC; 264 tp->t_pgrp = NULL; 265 tp->t_session = NULL; 266 tp->t_state = 0; 267 splx(s); 268 return (0); 269 } 270 271 #define FLUSHQ(q) { \ 272 if ((q)->c_cc) \ 273 ndflush(q, (q)->c_cc); \ 274 } 275 276 /* Is 'c' a line delimiter ("break" character)? */ 277 #define TTBREAKC(c, lflag) \ 278 ((c) == '\n' || (((c) == cc[VEOF] || \ 279 (c) == cc[VEOL] || ((c) == cc[VEOL2] && lflag & IEXTEN)) && \ 280 (c) != _POSIX_VDISABLE)) 281 282 /* 283 * Process input of a single character received on a tty. 284 */ 285 int 286 ttyinput(c, tp) 287 register int c; 288 register struct tty *tp; 289 { 290 register tcflag_t iflag, lflag; 291 register cc_t *cc; 292 int i, err; 293 294 /* 295 * If input is pending take it first. 296 */ 297 lflag = tp->t_lflag; 298 if (ISSET(lflag, PENDIN)) 299 ttypend(tp); 300 /* 301 * Gather stats. 302 */ 303 if (ISSET(lflag, ICANON)) { 304 ++tk_cancc; 305 ++tp->t_cancc; 306 } else { 307 ++tk_rawcc; 308 ++tp->t_rawcc; 309 } 310 ++tk_nin; 311 312 /* 313 * Block further input iff: 314 * current input > threshold AND input is available to user program 315 * AND input flow control is enabled and not yet invoked. 316 * The 3 is slop for PARMRK. 317 */ 318 iflag = tp->t_iflag; 319 if (tp->t_rawq.c_cc + tp->t_canq.c_cc > tp->t_ihiwat - 3 && 320 (!ISSET(lflag, ICANON) || tp->t_canq.c_cc != 0) && 321 (ISSET(tp->t_cflag, CRTS_IFLOW) || ISSET(iflag, IXOFF)) && 322 !ISSET(tp->t_state, TS_TBLOCK)) 323 ttyblock(tp); 324 325 /* Handle exceptional conditions (break, parity, framing). */ 326 cc = tp->t_cc; 327 err = (ISSET(c, TTY_ERRORMASK)); 328 if (err) { 329 CLR(c, TTY_ERRORMASK); 330 if (ISSET(err, TTY_BI)) { 331 if (ISSET(iflag, IGNBRK)) 332 return (0); 333 if (ISSET(iflag, BRKINT)) { 334 ttyflush(tp, FREAD | FWRITE); 335 pgsignal(tp->t_pgrp, SIGINT, 1); 336 goto endcase; 337 } 338 if (ISSET(iflag, PARMRK)) 339 goto parmrk; 340 } else if ((ISSET(err, TTY_PE) && ISSET(iflag, INPCK)) 341 || ISSET(err, TTY_FE)) { 342 if (ISSET(iflag, IGNPAR)) 343 return (0); 344 else if (ISSET(iflag, PARMRK)) { 345 parmrk: 346 if (tp->t_rawq.c_cc + tp->t_canq.c_cc > 347 MAX_INPUT - 3) 348 goto input_overflow; 349 (void)putc(0377 | TTY_QUOTE, &tp->t_rawq); 350 (void)putc(0 | TTY_QUOTE, &tp->t_rawq); 351 (void)putc(c | TTY_QUOTE, &tp->t_rawq); 352 goto endcase; 353 } else 354 c = 0; 355 } 356 } 357 358 if (!ISSET(tp->t_state, TS_TYPEN) && ISSET(iflag, ISTRIP)) 359 CLR(c, 0x80); 360 if (!ISSET(lflag, EXTPROC)) { 361 /* 362 * Check for literal nexting very first 363 */ 364 if (ISSET(tp->t_state, TS_LNCH)) { 365 SET(c, TTY_QUOTE); 366 CLR(tp->t_state, TS_LNCH); 367 } 368 /* 369 * Scan for special characters. This code 370 * is really just a big case statement with 371 * non-constant cases. The bottom of the 372 * case statement is labeled ``endcase'', so goto 373 * it after a case match, or similar. 374 */ 375 376 /* 377 * Control chars which aren't controlled 378 * by ICANON, ISIG, or IXON. 379 */ 380 if (ISSET(lflag, IEXTEN)) { 381 if (CCEQ(cc[VLNEXT], c)) { 382 if (ISSET(lflag, ECHO)) { 383 if (ISSET(lflag, ECHOE)) { 384 (void)ttyoutput('^', tp); 385 (void)ttyoutput('\b', tp); 386 } else 387 ttyecho(c, tp); 388 } 389 SET(tp->t_state, TS_LNCH); 390 goto endcase; 391 } 392 if (CCEQ(cc[VDISCARD], c)) { 393 if (ISSET(lflag, FLUSHO)) 394 CLR(tp->t_lflag, FLUSHO); 395 else { 396 ttyflush(tp, FWRITE); 397 ttyecho(c, tp); 398 if (tp->t_rawq.c_cc + tp->t_canq.c_cc) 399 ttyretype(tp); 400 SET(tp->t_lflag, FLUSHO); 401 } 402 goto startoutput; 403 } 404 } 405 /* 406 * Signals. 407 */ 408 if (ISSET(lflag, ISIG)) { 409 if (CCEQ(cc[VINTR], c) || CCEQ(cc[VQUIT], c)) { 410 if (!ISSET(lflag, NOFLSH)) 411 ttyflush(tp, FREAD | FWRITE); 412 ttyecho(c, tp); 413 pgsignal(tp->t_pgrp, 414 CCEQ(cc[VINTR], c) ? SIGINT : SIGQUIT, 1); 415 goto endcase; 416 } 417 if (CCEQ(cc[VSUSP], c)) { 418 if (!ISSET(lflag, NOFLSH)) 419 ttyflush(tp, FREAD); 420 ttyecho(c, tp); 421 pgsignal(tp->t_pgrp, SIGTSTP, 1); 422 goto endcase; 423 } 424 } 425 /* 426 * Handle start/stop characters. 427 */ 428 if (ISSET(iflag, IXON)) { 429 if (CCEQ(cc[VSTOP], c)) { 430 if (!ISSET(tp->t_state, TS_TTSTOP)) { 431 SET(tp->t_state, TS_TTSTOP); 432 (*tp->t_stop)(tp, 0); 433 return (0); 434 } 435 if (!CCEQ(cc[VSTART], c)) 436 return (0); 437 /* 438 * if VSTART == VSTOP then toggle 439 */ 440 goto endcase; 441 } 442 if (CCEQ(cc[VSTART], c)) 443 goto restartoutput; 444 } 445 /* 446 * IGNCR, ICRNL, & INLCR 447 */ 448 if (c == '\r') { 449 if (ISSET(iflag, IGNCR)) 450 return (0); 451 else if (ISSET(iflag, ICRNL)) 452 c = '\n'; 453 } else if (c == '\n' && ISSET(iflag, INLCR)) 454 c = '\r'; 455 } 456 if (!ISSET(tp->t_lflag, EXTPROC) && ISSET(lflag, ICANON)) { 457 /* 458 * From here on down canonical mode character 459 * processing takes place. 460 */ 461 /* 462 * erase (^H / ^?) 463 */ 464 if (CCEQ(cc[VERASE], c)) { 465 if (tp->t_rawq.c_cc) 466 ttyrub(unputc(&tp->t_rawq), tp); 467 goto endcase; 468 } 469 /* 470 * kill (^U) 471 */ 472 if (CCEQ(cc[VKILL], c)) { 473 if (ISSET(lflag, ECHOKE) && 474 tp->t_rawq.c_cc == tp->t_rocount && 475 !ISSET(lflag, ECHOPRT)) 476 while (tp->t_rawq.c_cc) 477 ttyrub(unputc(&tp->t_rawq), tp); 478 else { 479 ttyecho(c, tp); 480 if (ISSET(lflag, ECHOK) || 481 ISSET(lflag, ECHOKE)) 482 ttyecho('\n', tp); 483 FLUSHQ(&tp->t_rawq); 484 tp->t_rocount = 0; 485 } 486 CLR(tp->t_state, TS_LOCAL); 487 goto endcase; 488 } 489 /* 490 * word erase (^W) 491 */ 492 if (CCEQ(cc[VWERASE], c) && ISSET(lflag, IEXTEN)) { 493 int ctype; 494 495 /* 496 * erase whitespace 497 */ 498 while ((c = unputc(&tp->t_rawq)) == ' ' || c == '\t') 499 ttyrub(c, tp); 500 if (c == -1) 501 goto endcase; 502 /* 503 * erase last char of word and remember the 504 * next chars type (for ALTWERASE) 505 */ 506 ttyrub(c, tp); 507 c = unputc(&tp->t_rawq); 508 if (c == -1) 509 goto endcase; 510 if (c == ' ' || c == '\t') { 511 (void)putc(c, &tp->t_rawq); 512 goto endcase; 513 } 514 ctype = ISALPHA(c); 515 /* 516 * erase rest of word 517 */ 518 do { 519 ttyrub(c, tp); 520 c = unputc(&tp->t_rawq); 521 if (c == -1) 522 goto endcase; 523 } while (c != ' ' && c != '\t' && 524 (!ISSET(lflag, ALTWERASE) || ISALPHA(c) == ctype)); 525 (void)putc(c, &tp->t_rawq); 526 goto endcase; 527 } 528 /* 529 * reprint line (^R) 530 */ 531 if (CCEQ(cc[VREPRINT], c) && ISSET(lflag, IEXTEN)) { 532 ttyretype(tp); 533 goto endcase; 534 } 535 /* 536 * ^T - kernel info and generate SIGINFO 537 */ 538 if (CCEQ(cc[VSTATUS], c) && ISSET(lflag, IEXTEN)) { 539 if (ISSET(lflag, ISIG)) 540 pgsignal(tp->t_pgrp, SIGINFO, 1); 541 if (!ISSET(lflag, NOKERNINFO)) 542 ttyinfo(tp); 543 goto endcase; 544 } 545 } 546 /* 547 * Check for input buffer overflow 548 */ 549 if (tp->t_rawq.c_cc + tp->t_canq.c_cc >= MAX_INPUT) { 550 input_overflow: 551 if (ISSET(iflag, IMAXBEL)) { 552 if (tp->t_outq.c_cc < tp->t_ohiwat) 553 (void)ttyoutput(CTRL('g'), tp); 554 } 555 goto endcase; 556 } 557 558 if ( c == 0377 && ISSET(iflag, PARMRK) && !ISSET(iflag, ISTRIP) 559 && ISSET(iflag, IGNBRK|IGNPAR) != (IGNBRK|IGNPAR)) 560 (void)putc(0377 | TTY_QUOTE, &tp->t_rawq); 561 562 /* 563 * Put data char in q for user and 564 * wakeup on seeing a line delimiter. 565 */ 566 if (putc(c, &tp->t_rawq) >= 0) { 567 if (!ISSET(lflag, ICANON)) { 568 ttwakeup(tp); 569 ttyecho(c, tp); 570 goto endcase; 571 } 572 if (TTBREAKC(c, lflag)) { 573 tp->t_rocount = 0; 574 catq(&tp->t_rawq, &tp->t_canq); 575 ttwakeup(tp); 576 } else if (tp->t_rocount++ == 0) 577 tp->t_rocol = tp->t_column; 578 if (ISSET(tp->t_state, TS_ERASE)) { 579 /* 580 * end of prterase \.../ 581 */ 582 CLR(tp->t_state, TS_ERASE); 583 (void)ttyoutput('/', tp); 584 } 585 i = tp->t_column; 586 ttyecho(c, tp); 587 if (CCEQ(cc[VEOF], c) && ISSET(lflag, ECHO)) { 588 /* 589 * Place the cursor over the '^' of the ^D. 590 */ 591 i = imin(2, tp->t_column - i); 592 while (i > 0) { 593 (void)ttyoutput('\b', tp); 594 i--; 595 } 596 } 597 } 598 endcase: 599 /* 600 * IXANY means allow any character to restart output. 601 */ 602 if (ISSET(tp->t_state, TS_TTSTOP) && 603 !ISSET(iflag, IXANY) && cc[VSTART] != cc[VSTOP]) 604 return (0); 605 restartoutput: 606 CLR(tp->t_lflag, FLUSHO); 607 CLR(tp->t_state, TS_TTSTOP); 608 startoutput: 609 return (ttstart(tp)); 610 } 611 612 /* 613 * Output a single character on a tty, doing output processing 614 * as needed (expanding tabs, newline processing, etc.). 615 * Returns < 0 if succeeds, otherwise returns char to resend. 616 * Must be recursive. 617 */ 618 static int 619 ttyoutput(c, tp) 620 register int c; 621 register struct tty *tp; 622 { 623 register tcflag_t oflag; 624 register int col, s; 625 626 oflag = tp->t_oflag; 627 if (!ISSET(oflag, OPOST)) { 628 if (ISSET(tp->t_lflag, FLUSHO)) 629 return (-1); 630 if (putc(c, &tp->t_outq)) 631 return (c); 632 tk_nout++; 633 tp->t_outcc++; 634 return (-1); 635 } 636 /* 637 * Do tab expansion if OXTABS is set. Special case if we external 638 * processing, we don't do the tab expansion because we'll probably 639 * get it wrong. If tab expansion needs to be done, let it happen 640 * externally. 641 */ 642 CLR(c, ~TTY_CHARMASK); 643 if (c == '\t' && 644 ISSET(oflag, OXTABS) && !ISSET(tp->t_lflag, EXTPROC)) { 645 c = 8 - (tp->t_column & 7); 646 if (!ISSET(tp->t_lflag, FLUSHO)) { 647 s = spltty(); /* Don't interrupt tabs. */ 648 c -= b_to_q(" ", c, &tp->t_outq); 649 tk_nout += c; 650 tp->t_outcc += c; 651 splx(s); 652 } 653 tp->t_column += c; 654 return (c ? -1 : '\t'); 655 } 656 if (c == CEOT && ISSET(oflag, ONOEOT)) 657 return (-1); 658 659 /* 660 * Newline translation: if ONLCR is set, 661 * translate newline into "\r\n". 662 */ 663 if (c == '\n' && ISSET(tp->t_oflag, ONLCR)) { 664 tk_nout++; 665 tp->t_outcc++; 666 if (putc('\r', &tp->t_outq)) 667 return (c); 668 } 669 tk_nout++; 670 tp->t_outcc++; 671 if (!ISSET(tp->t_lflag, FLUSHO) && putc(c, &tp->t_outq)) 672 return (c); 673 674 col = tp->t_column; 675 switch (CCLASS(c)) { 676 case BACKSPACE: 677 if (col > 0) 678 --col; 679 break; 680 case CONTROL: 681 break; 682 case NEWLINE: 683 case RETURN: 684 col = 0; 685 break; 686 case ORDINARY: 687 ++col; 688 break; 689 case TAB: 690 col = (col + 8) & ~7; 691 break; 692 } 693 tp->t_column = col; 694 return (-1); 695 } 696 697 /* 698 * Ioctls for all tty devices. Called after line-discipline specific ioctl 699 * has been called to do discipline-specific functions and/or reject any 700 * of these ioctl commands. 701 */ 702 /* ARGSUSED */ 703 int 704 ttioctl(tp, cmd, data, flag) 705 register struct tty *tp; 706 u_long cmd; 707 int flag; 708 void *data; 709 { 710 register struct proc *p; 711 int s, error; 712 713 p = curproc; /* XXX */ 714 715 /* If the ioctl involves modification, hang if in the background. */ 716 switch (cmd) { 717 case TIOCCBRK: 718 case TIOCCONS: 719 case TIOCDRAIN: 720 case TIOCEXCL: 721 case TIOCFLUSH: 722 #ifdef TIOCHPCL 723 case TIOCHPCL: 724 #endif 725 case TIOCNXCL: 726 case TIOCSBRK: 727 case TIOCSCTTY: 728 case TIOCSDRAINWAIT: 729 case TIOCSETA: 730 case TIOCSETAF: 731 case TIOCSETAW: 732 case TIOCSETD: 733 case TIOCSPGRP: 734 case TIOCSTART: 735 case TIOCSTAT: 736 case TIOCSTI: 737 case TIOCSTOP: 738 case TIOCSWINSZ: 739 #if defined(COMPAT_43) || defined(COMPAT_SUNOS) 740 case TIOCLBIC: 741 case TIOCLBIS: 742 case TIOCLSET: 743 case TIOCSETC: 744 case OTIOCSETD: 745 case TIOCSETN: 746 case TIOCSETP: 747 case TIOCSLTC: 748 #endif 749 while (isbackground(p, tp) && !(p->p_flag & P_PPWAIT) && 750 !SIGISMEMBER(p->p_sigignore, SIGTTOU) && 751 !SIGISMEMBER(p->p_sigmask, SIGTTOU)) { 752 if (p->p_pgrp->pg_jobc == 0) 753 return (EIO); 754 pgsignal(p->p_pgrp, SIGTTOU, 1); 755 error = ttysleep(tp, &lbolt, TTOPRI | PCATCH, "ttybg1", 756 0); 757 if (error) 758 return (error); 759 } 760 break; 761 } 762 763 switch (cmd) { /* Process the ioctl. */ 764 case FIOASYNC: /* set/clear async i/o */ 765 s = spltty(); 766 if (*(int *)data) 767 SET(tp->t_state, TS_ASYNC); 768 else 769 CLR(tp->t_state, TS_ASYNC); 770 splx(s); 771 break; 772 case FIONBIO: /* set/clear non-blocking i/o */ 773 break; /* XXX: delete. */ 774 case FIONREAD: /* get # bytes to read */ 775 s = spltty(); 776 *(int *)data = ttnread(tp); 777 splx(s); 778 break; 779 780 case FIOSETOWN: 781 /* 782 * Policy -- Don't allow FIOSETOWN on someone else's 783 * controlling tty 784 */ 785 if (tp->t_session != NULL && !isctty(p, tp)) 786 return (ENOTTY); 787 788 error = fsetown(*(int *)data, &tp->t_sigio); 789 if (error) 790 return (error); 791 break; 792 case FIOGETOWN: 793 if (tp->t_session != NULL && !isctty(p, tp)) 794 return (ENOTTY); 795 *(int *)data = fgetown(tp->t_sigio); 796 break; 797 798 case TIOCEXCL: /* set exclusive use of tty */ 799 s = spltty(); 800 SET(tp->t_state, TS_XCLUDE); 801 splx(s); 802 break; 803 case TIOCFLUSH: { /* flush buffers */ 804 register int flags = *(int *)data; 805 806 if (flags == 0) 807 flags = FREAD | FWRITE; 808 else 809 flags &= FREAD | FWRITE; 810 ttyflush(tp, flags); 811 break; 812 } 813 case TIOCCONS: /* become virtual console */ 814 if (*(int *)data) { 815 if (constty && constty != tp && 816 ISSET(constty->t_state, TS_CONNECTED)) 817 return (EBUSY); 818 #ifndef UCONSOLE 819 if ((error = suser(p)) != 0) 820 return (error); 821 #endif 822 constty = tp; 823 } else if (tp == constty) 824 constty = NULL; 825 break; 826 case TIOCDRAIN: /* wait till output drained */ 827 error = ttywait(tp); 828 if (error) 829 return (error); 830 break; 831 case TIOCGETA: { /* get termios struct */ 832 struct termios *t = (struct termios *)data; 833 834 bcopy(&tp->t_termios, t, sizeof(struct termios)); 835 break; 836 } 837 case TIOCGETD: /* get line discipline */ 838 *(int *)data = tp->t_line; 839 break; 840 case TIOCGWINSZ: /* get window size */ 841 *(struct winsize *)data = tp->t_winsize; 842 break; 843 case TIOCGPGRP: /* get pgrp of tty */ 844 if (!isctty(p, tp)) 845 return (ENOTTY); 846 *(int *)data = tp->t_pgrp ? tp->t_pgrp->pg_id : NO_PID; 847 break; 848 #ifdef TIOCHPCL 849 case TIOCHPCL: /* hang up on last close */ 850 s = spltty(); 851 SET(tp->t_cflag, HUPCL); 852 splx(s); 853 break; 854 #endif 855 case TIOCNXCL: /* reset exclusive use of tty */ 856 s = spltty(); 857 CLR(tp->t_state, TS_XCLUDE); 858 splx(s); 859 break; 860 case TIOCOUTQ: /* output queue size */ 861 *(int *)data = tp->t_outq.c_cc; 862 break; 863 case TIOCSETA: /* set termios struct */ 864 case TIOCSETAW: /* drain output, set */ 865 case TIOCSETAF: { /* drn out, fls in, set */ 866 register struct termios *t = (struct termios *)data; 867 868 if (t->c_ispeed == 0) 869 t->c_ispeed = t->c_ospeed; 870 if (t->c_ispeed == 0) 871 t->c_ispeed = tp->t_ospeed; 872 if (t->c_ispeed == 0) 873 return (EINVAL); 874 s = spltty(); 875 if (cmd == TIOCSETAW || cmd == TIOCSETAF) { 876 error = ttywait(tp); 877 if (error) { 878 splx(s); 879 return (error); 880 } 881 if (cmd == TIOCSETAF) 882 ttyflush(tp, FREAD); 883 } 884 if (!ISSET(t->c_cflag, CIGNORE)) { 885 /* 886 * Set device hardware. 887 */ 888 if (tp->t_param && (error = (*tp->t_param)(tp, t))) { 889 splx(s); 890 return (error); 891 } 892 if (ISSET(t->c_cflag, CLOCAL) && 893 !ISSET(tp->t_cflag, CLOCAL)) { 894 /* 895 * XXX disconnections would be too hard to 896 * get rid of without this kludge. The only 897 * way to get rid of controlling terminals 898 * is to exit from the session leader. 899 */ 900 CLR(tp->t_state, TS_ZOMBIE); 901 902 wakeup(TSA_CARR_ON(tp)); 903 ttwakeup(tp); 904 ttwwakeup(tp); 905 } 906 if ((ISSET(tp->t_state, TS_CARR_ON) || 907 ISSET(t->c_cflag, CLOCAL)) && 908 !ISSET(tp->t_state, TS_ZOMBIE)) 909 SET(tp->t_state, TS_CONNECTED); 910 else 911 CLR(tp->t_state, TS_CONNECTED); 912 tp->t_cflag = t->c_cflag; 913 tp->t_ispeed = t->c_ispeed; 914 if (t->c_ospeed != 0) 915 tp->t_ospeed = t->c_ospeed; 916 ttsetwater(tp); 917 } 918 if (ISSET(t->c_lflag, ICANON) != ISSET(tp->t_lflag, ICANON) && 919 cmd != TIOCSETAF) { 920 if (ISSET(t->c_lflag, ICANON)) 921 SET(tp->t_lflag, PENDIN); 922 else { 923 /* 924 * XXX we really shouldn't allow toggling 925 * ICANON while we're in a non-termios line 926 * discipline. Now we have to worry about 927 * panicing for a null queue. 928 */ 929 if (tp->t_canq.c_cbreserved > 0 && 930 tp->t_rawq.c_cbreserved > 0) { 931 catq(&tp->t_rawq, &tp->t_canq); 932 /* 933 * XXX the queue limits may be 934 * different, so the old queue 935 * swapping method no longer works. 936 */ 937 catq(&tp->t_canq, &tp->t_rawq); 938 } 939 CLR(tp->t_lflag, PENDIN); 940 } 941 ttwakeup(tp); 942 } 943 tp->t_iflag = t->c_iflag; 944 tp->t_oflag = t->c_oflag; 945 /* 946 * Make the EXTPROC bit read only. 947 */ 948 if (ISSET(tp->t_lflag, EXTPROC)) 949 SET(t->c_lflag, EXTPROC); 950 else 951 CLR(t->c_lflag, EXTPROC); 952 tp->t_lflag = t->c_lflag | ISSET(tp->t_lflag, PENDIN); 953 if (t->c_cc[VMIN] != tp->t_cc[VMIN] || 954 t->c_cc[VTIME] != tp->t_cc[VTIME]) 955 ttwakeup(tp); 956 bcopy(t->c_cc, tp->t_cc, sizeof(t->c_cc)); 957 splx(s); 958 break; 959 } 960 case TIOCSETD: { /* set line discipline */ 961 register int t = *(int *)data; 962 dev_t device = tp->t_dev; 963 964 if ((u_int)t >= nlinesw) 965 return (ENXIO); 966 if (t != tp->t_line) { 967 s = spltty(); 968 (*linesw[tp->t_line].l_close)(tp, flag); 969 error = (*linesw[t].l_open)(device, tp); 970 if (error) { 971 (void)(*linesw[tp->t_line].l_open)(device, tp); 972 splx(s); 973 return (error); 974 } 975 tp->t_line = t; 976 splx(s); 977 } 978 break; 979 } 980 case TIOCSTART: /* start output, like ^Q */ 981 s = spltty(); 982 if (ISSET(tp->t_state, TS_TTSTOP) || 983 ISSET(tp->t_lflag, FLUSHO)) { 984 CLR(tp->t_lflag, FLUSHO); 985 CLR(tp->t_state, TS_TTSTOP); 986 ttstart(tp); 987 } 988 splx(s); 989 break; 990 case TIOCSTI: /* simulate terminal input */ 991 if ((flag & FREAD) == 0 && suser(p)) 992 return (EPERM); 993 if (!isctty(p, tp) && suser(p)) 994 return (EACCES); 995 s = spltty(); 996 (*linesw[tp->t_line].l_rint)(*(u_char *)data, tp); 997 splx(s); 998 break; 999 case TIOCSTOP: /* stop output, like ^S */ 1000 s = spltty(); 1001 if (!ISSET(tp->t_state, TS_TTSTOP)) { 1002 SET(tp->t_state, TS_TTSTOP); 1003 (*tp->t_stop)(tp, 0); 1004 } 1005 splx(s); 1006 break; 1007 case TIOCSCTTY: /* become controlling tty */ 1008 /* Session ctty vnode pointer set in vnode layer. */ 1009 if (!SESS_LEADER(p) || 1010 ((p->p_session->s_ttyvp || tp->t_session) && 1011 (tp->t_session != p->p_session))) 1012 return (EPERM); 1013 tp->t_session = p->p_session; 1014 tp->t_pgrp = p->p_pgrp; 1015 p->p_session->s_ttyp = tp; 1016 p->p_flag |= P_CONTROLT; 1017 break; 1018 case TIOCSPGRP: { /* set pgrp of tty */ 1019 register struct pgrp *pgrp = pgfind(*(int *)data); 1020 1021 if (!isctty(p, tp)) 1022 return (ENOTTY); 1023 else if (pgrp == NULL || pgrp->pg_session != p->p_session) 1024 return (EPERM); 1025 tp->t_pgrp = pgrp; 1026 break; 1027 } 1028 case TIOCSTAT: /* simulate control-T */ 1029 s = spltty(); 1030 ttyinfo(tp); 1031 splx(s); 1032 break; 1033 case TIOCSWINSZ: /* set window size */ 1034 if (bcmp((caddr_t)&tp->t_winsize, data, 1035 sizeof (struct winsize))) { 1036 tp->t_winsize = *(struct winsize *)data; 1037 pgsignal(tp->t_pgrp, SIGWINCH, 1); 1038 } 1039 break; 1040 case TIOCSDRAINWAIT: 1041 error = suser(p); 1042 if (error) 1043 return (error); 1044 tp->t_timeout = *(int *)data * hz; 1045 wakeup(TSA_OCOMPLETE(tp)); 1046 wakeup(TSA_OLOWAT(tp)); 1047 break; 1048 case TIOCGDRAINWAIT: 1049 *(int *)data = tp->t_timeout / hz; 1050 break; 1051 default: 1052 #if defined(COMPAT_43) || defined(COMPAT_SUNOS) 1053 return (ttcompat(tp, cmd, data, flag)); 1054 #else 1055 return (ENOIOCTL); 1056 #endif 1057 } 1058 return (0); 1059 } 1060 1061 int 1062 ttypoll(dev, events, p) 1063 dev_t dev; 1064 int events; 1065 struct proc *p; 1066 { 1067 int s; 1068 int revents = 0; 1069 struct tty *tp; 1070 1071 tp = dev->si_tty; 1072 if (tp == NULL) /* XXX used to return ENXIO, but that means true! */ 1073 return ((events & (POLLIN | POLLOUT | POLLRDNORM | POLLWRNORM)) 1074 | POLLHUP); 1075 1076 s = spltty(); 1077 if (events & (POLLIN | POLLRDNORM)) { 1078 if (ttnread(tp) > 0 || ISSET(tp->t_state, TS_ZOMBIE)) 1079 revents |= events & (POLLIN | POLLRDNORM); 1080 else 1081 selrecord(p, &tp->t_rsel); 1082 } 1083 if (events & (POLLOUT | POLLWRNORM)) { 1084 if ((tp->t_outq.c_cc <= tp->t_olowat && 1085 ISSET(tp->t_state, TS_CONNECTED)) 1086 || ISSET(tp->t_state, TS_ZOMBIE)) 1087 revents |= events & (POLLOUT | POLLWRNORM); 1088 else 1089 selrecord(p, &tp->t_wsel); 1090 } 1091 splx(s); 1092 return (revents); 1093 } 1094 1095 /* 1096 * Must be called at spltty(). 1097 */ 1098 static int 1099 ttnread(tp) 1100 struct tty *tp; 1101 { 1102 int nread; 1103 1104 if (ISSET(tp->t_lflag, PENDIN)) 1105 ttypend(tp); 1106 nread = tp->t_canq.c_cc; 1107 if (!ISSET(tp->t_lflag, ICANON)) { 1108 nread += tp->t_rawq.c_cc; 1109 if (nread < tp->t_cc[VMIN] && tp->t_cc[VTIME] == 0) 1110 nread = 0; 1111 } 1112 return (nread); 1113 } 1114 1115 /* 1116 * Wait for output to drain. 1117 */ 1118 int 1119 ttywait(tp) 1120 register struct tty *tp; 1121 { 1122 int error, s; 1123 1124 error = 0; 1125 s = spltty(); 1126 while ((tp->t_outq.c_cc || ISSET(tp->t_state, TS_BUSY)) && 1127 ISSET(tp->t_state, TS_CONNECTED) && tp->t_oproc) { 1128 (*tp->t_oproc)(tp); 1129 if ((tp->t_outq.c_cc || ISSET(tp->t_state, TS_BUSY)) && 1130 ISSET(tp->t_state, TS_CONNECTED)) { 1131 SET(tp->t_state, TS_SO_OCOMPLETE); 1132 error = ttysleep(tp, TSA_OCOMPLETE(tp), 1133 TTOPRI | PCATCH, "ttywai", 1134 tp->t_timeout); 1135 if (error) { 1136 if (error == EWOULDBLOCK) 1137 error = EIO; 1138 break; 1139 } 1140 } else 1141 break; 1142 } 1143 if (!error && (tp->t_outq.c_cc || ISSET(tp->t_state, TS_BUSY))) 1144 error = EIO; 1145 splx(s); 1146 return (error); 1147 } 1148 1149 /* 1150 * Flush if successfully wait. 1151 */ 1152 static int 1153 ttywflush(tp) 1154 struct tty *tp; 1155 { 1156 int error; 1157 1158 if ((error = ttywait(tp)) == 0) 1159 ttyflush(tp, FREAD); 1160 return (error); 1161 } 1162 1163 /* 1164 * Flush tty read and/or write queues, notifying anyone waiting. 1165 */ 1166 void 1167 ttyflush(tp, rw) 1168 register struct tty *tp; 1169 int rw; 1170 { 1171 register int s; 1172 1173 s = spltty(); 1174 #if 0 1175 again: 1176 #endif 1177 if (rw & FWRITE) { 1178 FLUSHQ(&tp->t_outq); 1179 CLR(tp->t_state, TS_TTSTOP); 1180 } 1181 (*tp->t_stop)(tp, rw); 1182 if (rw & FREAD) { 1183 FLUSHQ(&tp->t_canq); 1184 FLUSHQ(&tp->t_rawq); 1185 CLR(tp->t_lflag, PENDIN); 1186 tp->t_rocount = 0; 1187 tp->t_rocol = 0; 1188 CLR(tp->t_state, TS_LOCAL); 1189 ttwakeup(tp); 1190 if (ISSET(tp->t_state, TS_TBLOCK)) { 1191 if (rw & FWRITE) 1192 FLUSHQ(&tp->t_outq); 1193 ttyunblock(tp); 1194 1195 /* 1196 * Don't let leave any state that might clobber the 1197 * next line discipline (although we should do more 1198 * to send the START char). Not clearing the state 1199 * may have caused the "putc to a clist with no 1200 * reserved cblocks" panic/printf. 1201 */ 1202 CLR(tp->t_state, TS_TBLOCK); 1203 1204 #if 0 /* forget it, sleeping isn't always safe and we don't know when it is */ 1205 if (ISSET(tp->t_iflag, IXOFF)) { 1206 /* 1207 * XXX wait a bit in the hope that the stop 1208 * character (if any) will go out. Waiting 1209 * isn't good since it allows races. This 1210 * will be fixed when the stop character is 1211 * put in a special queue. Don't bother with 1212 * the checks in ttywait() since the timeout 1213 * will save us. 1214 */ 1215 SET(tp->t_state, TS_SO_OCOMPLETE); 1216 ttysleep(tp, TSA_OCOMPLETE(tp), TTOPRI, 1217 "ttyfls", hz / 10); 1218 /* 1219 * Don't try sending the stop character again. 1220 */ 1221 CLR(tp->t_state, TS_TBLOCK); 1222 goto again; 1223 } 1224 #endif 1225 } 1226 } 1227 if (rw & FWRITE) { 1228 FLUSHQ(&tp->t_outq); 1229 ttwwakeup(tp); 1230 } 1231 splx(s); 1232 } 1233 1234 /* 1235 * Copy in the default termios characters. 1236 */ 1237 void 1238 termioschars(t) 1239 struct termios *t; 1240 { 1241 1242 bcopy(ttydefchars, t->c_cc, sizeof t->c_cc); 1243 } 1244 1245 /* 1246 * Old interface. 1247 */ 1248 void 1249 ttychars(tp) 1250 struct tty *tp; 1251 { 1252 1253 termioschars(&tp->t_termios); 1254 } 1255 1256 /* 1257 * Handle input high water. Send stop character for the IXOFF case. Turn 1258 * on our input flow control bit and propagate the changes to the driver. 1259 * XXX the stop character should be put in a special high priority queue. 1260 */ 1261 void 1262 ttyblock(tp) 1263 struct tty *tp; 1264 { 1265 1266 SET(tp->t_state, TS_TBLOCK); 1267 if (ISSET(tp->t_iflag, IXOFF) && tp->t_cc[VSTOP] != _POSIX_VDISABLE && 1268 putc(tp->t_cc[VSTOP], &tp->t_outq) != 0) 1269 CLR(tp->t_state, TS_TBLOCK); /* try again later */ 1270 ttstart(tp); 1271 } 1272 1273 /* 1274 * Handle input low water. Send start character for the IXOFF case. Turn 1275 * off our input flow control bit and propagate the changes to the driver. 1276 * XXX the start character should be put in a special high priority queue. 1277 */ 1278 static void 1279 ttyunblock(tp) 1280 struct tty *tp; 1281 { 1282 1283 CLR(tp->t_state, TS_TBLOCK); 1284 if (ISSET(tp->t_iflag, IXOFF) && tp->t_cc[VSTART] != _POSIX_VDISABLE && 1285 putc(tp->t_cc[VSTART], &tp->t_outq) != 0) 1286 SET(tp->t_state, TS_TBLOCK); /* try again later */ 1287 ttstart(tp); 1288 } 1289 1290 #ifdef notyet 1291 /* Not used by any current (i386) drivers. */ 1292 /* 1293 * Restart after an inter-char delay. 1294 */ 1295 void 1296 ttrstrt(tp_arg) 1297 void *tp_arg; 1298 { 1299 struct tty *tp; 1300 int s; 1301 1302 KASSERT(tp_arg != NULL, ("ttrstrt")); 1303 1304 tp = tp_arg; 1305 s = spltty(); 1306 1307 CLR(tp->t_state, TS_TIMEOUT); 1308 ttstart(tp); 1309 1310 splx(s); 1311 } 1312 #endif 1313 1314 int 1315 ttstart(tp) 1316 struct tty *tp; 1317 { 1318 1319 if (tp->t_oproc != NULL) /* XXX: Kludge for pty. */ 1320 (*tp->t_oproc)(tp); 1321 return (0); 1322 } 1323 1324 /* 1325 * "close" a line discipline 1326 */ 1327 int 1328 ttylclose(tp, flag) 1329 struct tty *tp; 1330 int flag; 1331 { 1332 1333 if (flag & FNONBLOCK || ttywflush(tp)) 1334 ttyflush(tp, FREAD | FWRITE); 1335 return (0); 1336 } 1337 1338 /* 1339 * Handle modem control transition on a tty. 1340 * Flag indicates new state of carrier. 1341 * Returns 0 if the line should be turned off, otherwise 1. 1342 */ 1343 int 1344 ttymodem(tp, flag) 1345 register struct tty *tp; 1346 int flag; 1347 { 1348 1349 if (ISSET(tp->t_state, TS_CARR_ON) && ISSET(tp->t_cflag, MDMBUF)) { 1350 /* 1351 * MDMBUF: do flow control according to carrier flag 1352 * XXX TS_CAR_OFLOW doesn't do anything yet. TS_TTSTOP 1353 * works if IXON and IXANY are clear. 1354 */ 1355 if (flag) { 1356 CLR(tp->t_state, TS_CAR_OFLOW); 1357 CLR(tp->t_state, TS_TTSTOP); 1358 ttstart(tp); 1359 } else if (!ISSET(tp->t_state, TS_CAR_OFLOW)) { 1360 SET(tp->t_state, TS_CAR_OFLOW); 1361 SET(tp->t_state, TS_TTSTOP); 1362 (*tp->t_stop)(tp, 0); 1363 } 1364 } else if (flag == 0) { 1365 /* 1366 * Lost carrier. 1367 */ 1368 CLR(tp->t_state, TS_CARR_ON); 1369 if (ISSET(tp->t_state, TS_ISOPEN) && 1370 !ISSET(tp->t_cflag, CLOCAL)) { 1371 SET(tp->t_state, TS_ZOMBIE); 1372 CLR(tp->t_state, TS_CONNECTED); 1373 if (tp->t_session && tp->t_session->s_leader) 1374 psignal(tp->t_session->s_leader, SIGHUP); 1375 ttyflush(tp, FREAD | FWRITE); 1376 return (0); 1377 } 1378 } else { 1379 /* 1380 * Carrier now on. 1381 */ 1382 SET(tp->t_state, TS_CARR_ON); 1383 if (!ISSET(tp->t_state, TS_ZOMBIE)) 1384 SET(tp->t_state, TS_CONNECTED); 1385 wakeup(TSA_CARR_ON(tp)); 1386 ttwakeup(tp); 1387 ttwwakeup(tp); 1388 } 1389 return (1); 1390 } 1391 1392 /* 1393 * Reinput pending characters after state switch 1394 * call at spltty(). 1395 */ 1396 static void 1397 ttypend(tp) 1398 register struct tty *tp; 1399 { 1400 struct clist tq; 1401 register int c; 1402 1403 CLR(tp->t_lflag, PENDIN); 1404 SET(tp->t_state, TS_TYPEN); 1405 /* 1406 * XXX this assumes too much about clist internals. It may even 1407 * fail if the cblock slush pool is empty. We can't allocate more 1408 * cblocks here because we are called from an interrupt handler 1409 * and clist_alloc_cblocks() can wait. 1410 */ 1411 tq = tp->t_rawq; 1412 bzero(&tp->t_rawq, sizeof tp->t_rawq); 1413 tp->t_rawq.c_cbmax = tq.c_cbmax; 1414 tp->t_rawq.c_cbreserved = tq.c_cbreserved; 1415 while ((c = getc(&tq)) >= 0) 1416 ttyinput(c, tp); 1417 CLR(tp->t_state, TS_TYPEN); 1418 } 1419 1420 /* 1421 * Process a read call on a tty device. 1422 */ 1423 int 1424 ttread(tp, uio, flag) 1425 register struct tty *tp; 1426 struct uio *uio; 1427 int flag; 1428 { 1429 register struct clist *qp; 1430 register int c; 1431 register tcflag_t lflag; 1432 register cc_t *cc = tp->t_cc; 1433 register struct proc *p = curproc; 1434 int s, first, error = 0; 1435 int has_stime = 0, last_cc = 0; 1436 long slp = 0; /* XXX this should be renamed `timo'. */ 1437 struct timeval stime; 1438 1439 loop: 1440 s = spltty(); 1441 lflag = tp->t_lflag; 1442 /* 1443 * take pending input first 1444 */ 1445 if (ISSET(lflag, PENDIN)) { 1446 ttypend(tp); 1447 splx(s); /* reduce latency */ 1448 s = spltty(); 1449 lflag = tp->t_lflag; /* XXX ttypend() clobbers it */ 1450 } 1451 1452 /* 1453 * Hang process if it's in the background. 1454 */ 1455 if (isbackground(p, tp)) { 1456 splx(s); 1457 if (SIGISMEMBER(p->p_sigignore, SIGTTIN) || 1458 SIGISMEMBER(p->p_sigmask, SIGTTIN) || 1459 (p->p_flag & P_PPWAIT) || p->p_pgrp->pg_jobc == 0) 1460 return (EIO); 1461 pgsignal(p->p_pgrp, SIGTTIN, 1); 1462 error = ttysleep(tp, &lbolt, TTIPRI | PCATCH, "ttybg2", 0); 1463 if (error) 1464 return (error); 1465 goto loop; 1466 } 1467 1468 if (ISSET(tp->t_state, TS_ZOMBIE)) { 1469 splx(s); 1470 return (0); /* EOF */ 1471 } 1472 1473 /* 1474 * If canonical, use the canonical queue, 1475 * else use the raw queue. 1476 * 1477 * (should get rid of clists...) 1478 */ 1479 qp = ISSET(lflag, ICANON) ? &tp->t_canq : &tp->t_rawq; 1480 1481 if (flag & IO_NDELAY) { 1482 if (qp->c_cc > 0) 1483 goto read; 1484 if (!ISSET(lflag, ICANON) && cc[VMIN] == 0) { 1485 splx(s); 1486 return (0); 1487 } 1488 splx(s); 1489 return (EWOULDBLOCK); 1490 } 1491 if (!ISSET(lflag, ICANON)) { 1492 int m = cc[VMIN]; 1493 long t = cc[VTIME]; 1494 struct timeval timecopy; 1495 1496 /* 1497 * Check each of the four combinations. 1498 * (m > 0 && t == 0) is the normal read case. 1499 * It should be fairly efficient, so we check that and its 1500 * companion case (m == 0 && t == 0) first. 1501 * For the other two cases, we compute the target sleep time 1502 * into slp. 1503 */ 1504 if (t == 0) { 1505 if (qp->c_cc < m) 1506 goto sleep; 1507 if (qp->c_cc > 0) 1508 goto read; 1509 1510 /* m, t and qp->c_cc are all 0. 0 is enough input. */ 1511 splx(s); 1512 return (0); 1513 } 1514 t *= 100000; /* time in us */ 1515 #define diff(t1, t2) (((t1).tv_sec - (t2).tv_sec) * 1000000 + \ 1516 ((t1).tv_usec - (t2).tv_usec)) 1517 if (m > 0) { 1518 if (qp->c_cc <= 0) 1519 goto sleep; 1520 if (qp->c_cc >= m) 1521 goto read; 1522 getmicrotime(&timecopy); 1523 if (!has_stime) { 1524 /* first character, start timer */ 1525 has_stime = 1; 1526 stime = timecopy; 1527 slp = t; 1528 } else if (qp->c_cc > last_cc) { 1529 /* got a character, restart timer */ 1530 stime = timecopy; 1531 slp = t; 1532 } else { 1533 /* nothing, check expiration */ 1534 slp = t - diff(timecopy, stime); 1535 if (slp <= 0) 1536 goto read; 1537 } 1538 last_cc = qp->c_cc; 1539 } else { /* m == 0 */ 1540 if (qp->c_cc > 0) 1541 goto read; 1542 getmicrotime(&timecopy); 1543 if (!has_stime) { 1544 has_stime = 1; 1545 stime = timecopy; 1546 slp = t; 1547 } else { 1548 slp = t - diff(timecopy, stime); 1549 if (slp <= 0) { 1550 /* Timed out, but 0 is enough input. */ 1551 splx(s); 1552 return (0); 1553 } 1554 } 1555 } 1556 #undef diff 1557 /* 1558 * Rounding down may make us wake up just short 1559 * of the target, so we round up. 1560 * The formula is ceiling(slp * hz/1000000). 1561 * 32-bit arithmetic is enough for hz < 169. 1562 * XXX see tvtohz() for how to avoid overflow if hz 1563 * is large (divide by `tick' and/or arrange to 1564 * use tvtohz() if hz is large). 1565 */ 1566 slp = (long) (((u_long)slp * hz) + 999999) / 1000000; 1567 goto sleep; 1568 } 1569 if (qp->c_cc <= 0) { 1570 sleep: 1571 /* 1572 * There is no input, or not enough input and we can block. 1573 */ 1574 error = ttysleep(tp, TSA_HUP_OR_INPUT(tp), TTIPRI | PCATCH, 1575 ISSET(tp->t_state, TS_CONNECTED) ? 1576 "ttyin" : "ttyhup", (int)slp); 1577 splx(s); 1578 if (error == EWOULDBLOCK) 1579 error = 0; 1580 else if (error) 1581 return (error); 1582 /* 1583 * XXX what happens if another process eats some input 1584 * while we are asleep (not just here)? It would be 1585 * safest to detect changes and reset our state variables 1586 * (has_stime and last_cc). 1587 */ 1588 slp = 0; 1589 goto loop; 1590 } 1591 read: 1592 splx(s); 1593 /* 1594 * Input present, check for input mapping and processing. 1595 */ 1596 first = 1; 1597 if (ISSET(lflag, ICANON | ISIG)) 1598 goto slowcase; 1599 for (;;) { 1600 char ibuf[IBUFSIZ]; 1601 int icc; 1602 1603 icc = imin(uio->uio_resid, IBUFSIZ); 1604 icc = q_to_b(qp, ibuf, icc); 1605 if (icc <= 0) { 1606 if (first) 1607 goto loop; 1608 break; 1609 } 1610 error = uiomove(ibuf, icc, uio); 1611 /* 1612 * XXX if there was an error then we should ungetc() the 1613 * unmoved chars and reduce icc here. 1614 */ 1615 #if NSNP > 0 1616 if (ISSET(tp->t_lflag, ECHO) && 1617 ISSET(tp->t_state, TS_SNOOP) && tp->t_sc != NULL) 1618 snpin((struct snoop *)tp->t_sc, ibuf, icc); 1619 #endif 1620 if (error) 1621 break; 1622 if (uio->uio_resid == 0) 1623 break; 1624 first = 0; 1625 } 1626 goto out; 1627 slowcase: 1628 for (;;) { 1629 c = getc(qp); 1630 if (c < 0) { 1631 if (first) 1632 goto loop; 1633 break; 1634 } 1635 /* 1636 * delayed suspend (^Y) 1637 */ 1638 if (CCEQ(cc[VDSUSP], c) && 1639 ISSET(lflag, IEXTEN | ISIG) == (IEXTEN | ISIG)) { 1640 pgsignal(tp->t_pgrp, SIGTSTP, 1); 1641 if (first) { 1642 error = ttysleep(tp, &lbolt, TTIPRI | PCATCH, 1643 "ttybg3", 0); 1644 if (error) 1645 break; 1646 goto loop; 1647 } 1648 break; 1649 } 1650 /* 1651 * Interpret EOF only in canonical mode. 1652 */ 1653 if (CCEQ(cc[VEOF], c) && ISSET(lflag, ICANON)) 1654 break; 1655 /* 1656 * Give user character. 1657 */ 1658 error = ureadc(c, uio); 1659 if (error) 1660 /* XXX should ungetc(c, qp). */ 1661 break; 1662 #if NSNP > 0 1663 /* 1664 * Only snoop directly on input in echo mode. Non-echoed 1665 * input will be snooped later iff the application echoes it. 1666 */ 1667 if (ISSET(tp->t_lflag, ECHO) && 1668 ISSET(tp->t_state, TS_SNOOP) && tp->t_sc != NULL) 1669 snpinc((struct snoop *)tp->t_sc, (char)c); 1670 #endif 1671 if (uio->uio_resid == 0) 1672 break; 1673 /* 1674 * In canonical mode check for a "break character" 1675 * marking the end of a "line of input". 1676 */ 1677 if (ISSET(lflag, ICANON) && TTBREAKC(c, lflag)) 1678 break; 1679 first = 0; 1680 } 1681 1682 out: 1683 /* 1684 * Look to unblock input now that (presumably) 1685 * the input queue has gone down. 1686 */ 1687 s = spltty(); 1688 if (ISSET(tp->t_state, TS_TBLOCK) && 1689 tp->t_rawq.c_cc + tp->t_canq.c_cc <= tp->t_ilowat) 1690 ttyunblock(tp); 1691 splx(s); 1692 1693 return (error); 1694 } 1695 1696 /* 1697 * Check the output queue on tp for space for a kernel message (from uprintf 1698 * or tprintf). Allow some space over the normal hiwater mark so we don't 1699 * lose messages due to normal flow control, but don't let the tty run amok. 1700 * Sleeps here are not interruptible, but we return prematurely if new signals 1701 * arrive. 1702 */ 1703 int 1704 ttycheckoutq(tp, wait) 1705 register struct tty *tp; 1706 int wait; 1707 { 1708 int hiwat, s; 1709 sigset_t oldmask; 1710 1711 hiwat = tp->t_ohiwat; 1712 SIGEMPTYSET(oldmask); 1713 s = spltty(); 1714 if (wait) 1715 oldmask = curproc->p_siglist; 1716 if (tp->t_outq.c_cc > hiwat + OBUFSIZ + 100) 1717 while (tp->t_outq.c_cc > hiwat) { 1718 ttstart(tp); 1719 if (tp->t_outq.c_cc <= hiwat) 1720 break; 1721 if (!(wait && SIGSETEQ(curproc->p_siglist, oldmask))) { 1722 splx(s); 1723 return (0); 1724 } 1725 SET(tp->t_state, TS_SO_OLOWAT); 1726 tsleep(TSA_OLOWAT(tp), PZERO - 1, "ttoutq", hz); 1727 } 1728 splx(s); 1729 return (1); 1730 } 1731 1732 /* 1733 * Process a write call on a tty device. 1734 */ 1735 int 1736 ttwrite(tp, uio, flag) 1737 register struct tty *tp; 1738 register struct uio *uio; 1739 int flag; 1740 { 1741 register char *cp = NULL; 1742 register int cc, ce; 1743 register struct proc *p; 1744 int i, hiwat, cnt, error, s; 1745 char obuf[OBUFSIZ]; 1746 1747 hiwat = tp->t_ohiwat; 1748 cnt = uio->uio_resid; 1749 error = 0; 1750 cc = 0; 1751 loop: 1752 s = spltty(); 1753 if (ISSET(tp->t_state, TS_ZOMBIE)) { 1754 splx(s); 1755 if (uio->uio_resid == cnt) 1756 error = EIO; 1757 goto out; 1758 } 1759 if (!ISSET(tp->t_state, TS_CONNECTED)) { 1760 if (flag & IO_NDELAY) { 1761 splx(s); 1762 error = EWOULDBLOCK; 1763 goto out; 1764 } 1765 error = ttysleep(tp, TSA_CARR_ON(tp), TTIPRI | PCATCH, 1766 "ttydcd", 0); 1767 splx(s); 1768 if (error) 1769 goto out; 1770 goto loop; 1771 } 1772 splx(s); 1773 /* 1774 * Hang the process if it's in the background. 1775 */ 1776 p = curproc; 1777 if (isbackground(p, tp) && 1778 ISSET(tp->t_lflag, TOSTOP) && !(p->p_flag & P_PPWAIT) && 1779 !SIGISMEMBER(p->p_sigignore, SIGTTOU) && 1780 !SIGISMEMBER(p->p_sigmask, SIGTTOU)) { 1781 if (p->p_pgrp->pg_jobc == 0) { 1782 error = EIO; 1783 goto out; 1784 } 1785 pgsignal(p->p_pgrp, SIGTTOU, 1); 1786 error = ttysleep(tp, &lbolt, TTIPRI | PCATCH, "ttybg4", 0); 1787 if (error) 1788 goto out; 1789 goto loop; 1790 } 1791 /* 1792 * Process the user's data in at most OBUFSIZ chunks. Perform any 1793 * output translation. Keep track of high water mark, sleep on 1794 * overflow awaiting device aid in acquiring new space. 1795 */ 1796 while (uio->uio_resid > 0 || cc > 0) { 1797 if (ISSET(tp->t_lflag, FLUSHO)) { 1798 uio->uio_resid = 0; 1799 return (0); 1800 } 1801 if (tp->t_outq.c_cc > hiwat) 1802 goto ovhiwat; 1803 /* 1804 * Grab a hunk of data from the user, unless we have some 1805 * leftover from last time. 1806 */ 1807 if (cc == 0) { 1808 cc = imin(uio->uio_resid, OBUFSIZ); 1809 cp = obuf; 1810 error = uiomove(cp, cc, uio); 1811 if (error) { 1812 cc = 0; 1813 break; 1814 } 1815 #if NSNP > 0 1816 if (ISSET(tp->t_state, TS_SNOOP) && tp->t_sc != NULL) 1817 snpin((struct snoop *)tp->t_sc, cp, cc); 1818 #endif 1819 } 1820 /* 1821 * If nothing fancy need be done, grab those characters we 1822 * can handle without any of ttyoutput's processing and 1823 * just transfer them to the output q. For those chars 1824 * which require special processing (as indicated by the 1825 * bits in char_type), call ttyoutput. After processing 1826 * a hunk of data, look for FLUSHO so ^O's will take effect 1827 * immediately. 1828 */ 1829 while (cc > 0) { 1830 if (!ISSET(tp->t_oflag, OPOST)) 1831 ce = cc; 1832 else { 1833 ce = cc - scanc((u_int)cc, (u_char *)cp, 1834 char_type, CCLASSMASK); 1835 /* 1836 * If ce is zero, then we're processing 1837 * a special character through ttyoutput. 1838 */ 1839 if (ce == 0) { 1840 tp->t_rocount = 0; 1841 if (ttyoutput(*cp, tp) >= 0) { 1842 /* No Clists, wait a bit. */ 1843 ttstart(tp); 1844 if (flag & IO_NDELAY) { 1845 error = EWOULDBLOCK; 1846 goto out; 1847 } 1848 error = ttysleep(tp, &lbolt, 1849 TTOPRI|PCATCH, 1850 "ttybf1", 0); 1851 if (error) 1852 goto out; 1853 goto loop; 1854 } 1855 cp++; 1856 cc--; 1857 if (ISSET(tp->t_lflag, FLUSHO) || 1858 tp->t_outq.c_cc > hiwat) 1859 goto ovhiwat; 1860 continue; 1861 } 1862 } 1863 /* 1864 * A bunch of normal characters have been found. 1865 * Transfer them en masse to the output queue and 1866 * continue processing at the top of the loop. 1867 * If there are any further characters in this 1868 * <= OBUFSIZ chunk, the first should be a character 1869 * requiring special handling by ttyoutput. 1870 */ 1871 tp->t_rocount = 0; 1872 i = b_to_q(cp, ce, &tp->t_outq); 1873 ce -= i; 1874 tp->t_column += ce; 1875 cp += ce, cc -= ce, tk_nout += ce; 1876 tp->t_outcc += ce; 1877 if (i > 0) { 1878 /* No Clists, wait a bit. */ 1879 ttstart(tp); 1880 if (flag & IO_NDELAY) { 1881 error = EWOULDBLOCK; 1882 goto out; 1883 } 1884 error = ttysleep(tp, &lbolt, TTOPRI | PCATCH, 1885 "ttybf2", 0); 1886 if (error) 1887 goto out; 1888 goto loop; 1889 } 1890 if (ISSET(tp->t_lflag, FLUSHO) || 1891 tp->t_outq.c_cc > hiwat) 1892 break; 1893 } 1894 ttstart(tp); 1895 } 1896 out: 1897 /* 1898 * If cc is nonzero, we leave the uio structure inconsistent, as the 1899 * offset and iov pointers have moved forward, but it doesn't matter 1900 * (the call will either return short or restart with a new uio). 1901 */ 1902 uio->uio_resid += cc; 1903 return (error); 1904 1905 ovhiwat: 1906 ttstart(tp); 1907 s = spltty(); 1908 /* 1909 * This can only occur if FLUSHO is set in t_lflag, 1910 * or if ttstart/oproc is synchronous (or very fast). 1911 */ 1912 if (tp->t_outq.c_cc <= hiwat) { 1913 splx(s); 1914 goto loop; 1915 } 1916 if (flag & IO_NDELAY) { 1917 splx(s); 1918 uio->uio_resid += cc; 1919 return (uio->uio_resid == cnt ? EWOULDBLOCK : 0); 1920 } 1921 SET(tp->t_state, TS_SO_OLOWAT); 1922 error = ttysleep(tp, TSA_OLOWAT(tp), TTOPRI | PCATCH, "ttywri", 1923 tp->t_timeout); 1924 splx(s); 1925 if (error == EWOULDBLOCK) 1926 error = EIO; 1927 if (error) 1928 goto out; 1929 goto loop; 1930 } 1931 1932 /* 1933 * Rubout one character from the rawq of tp 1934 * as cleanly as possible. 1935 */ 1936 static void 1937 ttyrub(c, tp) 1938 register int c; 1939 register struct tty *tp; 1940 { 1941 register char *cp; 1942 register int savecol; 1943 int tabc, s; 1944 1945 if (!ISSET(tp->t_lflag, ECHO) || ISSET(tp->t_lflag, EXTPROC)) 1946 return; 1947 CLR(tp->t_lflag, FLUSHO); 1948 if (ISSET(tp->t_lflag, ECHOE)) { 1949 if (tp->t_rocount == 0) { 1950 /* 1951 * Screwed by ttwrite; retype 1952 */ 1953 ttyretype(tp); 1954 return; 1955 } 1956 if (c == ('\t' | TTY_QUOTE) || c == ('\n' | TTY_QUOTE)) 1957 ttyrubo(tp, 2); 1958 else { 1959 CLR(c, ~TTY_CHARMASK); 1960 switch (CCLASS(c)) { 1961 case ORDINARY: 1962 ttyrubo(tp, 1); 1963 break; 1964 case BACKSPACE: 1965 case CONTROL: 1966 case NEWLINE: 1967 case RETURN: 1968 case VTAB: 1969 if (ISSET(tp->t_lflag, ECHOCTL)) 1970 ttyrubo(tp, 2); 1971 break; 1972 case TAB: 1973 if (tp->t_rocount < tp->t_rawq.c_cc) { 1974 ttyretype(tp); 1975 return; 1976 } 1977 s = spltty(); 1978 savecol = tp->t_column; 1979 SET(tp->t_state, TS_CNTTB); 1980 SET(tp->t_lflag, FLUSHO); 1981 tp->t_column = tp->t_rocol; 1982 cp = tp->t_rawq.c_cf; 1983 if (cp) 1984 tabc = *cp; /* XXX FIX NEXTC */ 1985 for (; cp; cp = nextc(&tp->t_rawq, cp, &tabc)) 1986 ttyecho(tabc, tp); 1987 CLR(tp->t_lflag, FLUSHO); 1988 CLR(tp->t_state, TS_CNTTB); 1989 splx(s); 1990 1991 /* savecol will now be length of the tab. */ 1992 savecol -= tp->t_column; 1993 tp->t_column += savecol; 1994 if (savecol > 8) 1995 savecol = 8; /* overflow screw */ 1996 while (--savecol >= 0) 1997 (void)ttyoutput('\b', tp); 1998 break; 1999 default: /* XXX */ 2000 #define PANICSTR "ttyrub: would panic c = %d, val = %d\n" 2001 (void)printf(PANICSTR, c, CCLASS(c)); 2002 #ifdef notdef 2003 panic(PANICSTR, c, CCLASS(c)); 2004 #endif 2005 } 2006 } 2007 } else if (ISSET(tp->t_lflag, ECHOPRT)) { 2008 if (!ISSET(tp->t_state, TS_ERASE)) { 2009 SET(tp->t_state, TS_ERASE); 2010 (void)ttyoutput('\\', tp); 2011 } 2012 ttyecho(c, tp); 2013 } else 2014 ttyecho(tp->t_cc[VERASE], tp); 2015 --tp->t_rocount; 2016 } 2017 2018 /* 2019 * Back over cnt characters, erasing them. 2020 */ 2021 static void 2022 ttyrubo(tp, cnt) 2023 register struct tty *tp; 2024 int cnt; 2025 { 2026 2027 while (cnt-- > 0) { 2028 (void)ttyoutput('\b', tp); 2029 (void)ttyoutput(' ', tp); 2030 (void)ttyoutput('\b', tp); 2031 } 2032 } 2033 2034 /* 2035 * ttyretype -- 2036 * Reprint the rawq line. Note, it is assumed that c_cc has already 2037 * been checked. 2038 */ 2039 static void 2040 ttyretype(tp) 2041 register struct tty *tp; 2042 { 2043 register char *cp; 2044 int s, c; 2045 2046 /* Echo the reprint character. */ 2047 if (tp->t_cc[VREPRINT] != _POSIX_VDISABLE) 2048 ttyecho(tp->t_cc[VREPRINT], tp); 2049 2050 (void)ttyoutput('\n', tp); 2051 2052 /* 2053 * XXX 2054 * FIX: NEXTC IS BROKEN - DOESN'T CHECK QUOTE 2055 * BIT OF FIRST CHAR. 2056 */ 2057 s = spltty(); 2058 for (cp = tp->t_canq.c_cf, c = (cp != NULL ? *cp : 0); 2059 cp != NULL; cp = nextc(&tp->t_canq, cp, &c)) 2060 ttyecho(c, tp); 2061 for (cp = tp->t_rawq.c_cf, c = (cp != NULL ? *cp : 0); 2062 cp != NULL; cp = nextc(&tp->t_rawq, cp, &c)) 2063 ttyecho(c, tp); 2064 CLR(tp->t_state, TS_ERASE); 2065 splx(s); 2066 2067 tp->t_rocount = tp->t_rawq.c_cc; 2068 tp->t_rocol = 0; 2069 } 2070 2071 /* 2072 * Echo a typed character to the terminal. 2073 */ 2074 static void 2075 ttyecho(c, tp) 2076 register int c; 2077 register struct tty *tp; 2078 { 2079 2080 if (!ISSET(tp->t_state, TS_CNTTB)) 2081 CLR(tp->t_lflag, FLUSHO); 2082 if ((!ISSET(tp->t_lflag, ECHO) && 2083 (c != '\n' || !ISSET(tp->t_lflag, ECHONL))) || 2084 ISSET(tp->t_lflag, EXTPROC)) 2085 return; 2086 if (ISSET(tp->t_lflag, ECHOCTL) && 2087 ((ISSET(c, TTY_CHARMASK) <= 037 && c != '\t' && c != '\n') || 2088 ISSET(c, TTY_CHARMASK) == 0177)) { 2089 (void)ttyoutput('^', tp); 2090 CLR(c, ~TTY_CHARMASK); 2091 if (c == 0177) 2092 c = '?'; 2093 else 2094 c += 'A' - 1; 2095 } 2096 (void)ttyoutput(c, tp); 2097 } 2098 2099 /* 2100 * Wake up any readers on a tty. 2101 */ 2102 void 2103 ttwakeup(tp) 2104 register struct tty *tp; 2105 { 2106 2107 if (tp->t_rsel.si_pid != 0) 2108 selwakeup(&tp->t_rsel); 2109 if (ISSET(tp->t_state, TS_ASYNC) && tp->t_sigio != NULL) 2110 pgsigio(tp->t_sigio, SIGIO, (tp->t_session != NULL)); 2111 wakeup(TSA_HUP_OR_INPUT(tp)); 2112 } 2113 2114 /* 2115 * Wake up any writers on a tty. 2116 */ 2117 void 2118 ttwwakeup(tp) 2119 register struct tty *tp; 2120 { 2121 2122 if (tp->t_wsel.si_pid != 0 && tp->t_outq.c_cc <= tp->t_olowat) 2123 selwakeup(&tp->t_wsel); 2124 if (ISSET(tp->t_state, TS_ASYNC) && tp->t_sigio != NULL) 2125 pgsigio(tp->t_sigio, SIGIO, (tp->t_session != NULL)); 2126 if (ISSET(tp->t_state, TS_BUSY | TS_SO_OCOMPLETE) == 2127 TS_SO_OCOMPLETE && tp->t_outq.c_cc == 0) { 2128 CLR(tp->t_state, TS_SO_OCOMPLETE); 2129 wakeup(TSA_OCOMPLETE(tp)); 2130 } 2131 if (ISSET(tp->t_state, TS_SO_OLOWAT) && 2132 tp->t_outq.c_cc <= tp->t_olowat) { 2133 CLR(tp->t_state, TS_SO_OLOWAT); 2134 wakeup(TSA_OLOWAT(tp)); 2135 } 2136 } 2137 2138 /* 2139 * Look up a code for a specified speed in a conversion table; 2140 * used by drivers to map software speed values to hardware parameters. 2141 */ 2142 int 2143 ttspeedtab(speed, table) 2144 int speed; 2145 register struct speedtab *table; 2146 { 2147 2148 for ( ; table->sp_speed != -1; table++) 2149 if (table->sp_speed == speed) 2150 return (table->sp_code); 2151 return (-1); 2152 } 2153 2154 /* 2155 * Set input and output watermarks and buffer sizes. For input, the 2156 * high watermark is about one second's worth of input above empty, the 2157 * low watermark is slightly below high water, and the buffer size is a 2158 * driver-dependent amount above high water. For output, the watermarks 2159 * are near the ends of the buffer, with about 1 second's worth of input 2160 * between them. All this only applies to the standard line discipline. 2161 */ 2162 void 2163 ttsetwater(tp) 2164 struct tty *tp; 2165 { 2166 register int cps, ttmaxhiwat, x; 2167 2168 /* Input. */ 2169 clist_alloc_cblocks(&tp->t_canq, TTYHOG, 512); 2170 switch (tp->t_ispeedwat) { 2171 case (speed_t)-1: 2172 cps = tp->t_ispeed / 10; 2173 break; 2174 case 0: 2175 /* 2176 * This case is for old drivers that don't know about 2177 * t_ispeedwat. Arrange for them to get the old buffer 2178 * sizes and watermarks. 2179 */ 2180 cps = TTYHOG - 2 * 256; 2181 tp->t_ififosize = 2 * 256; 2182 break; 2183 default: 2184 cps = tp->t_ispeedwat / 10; 2185 break; 2186 } 2187 tp->t_ihiwat = cps; 2188 tp->t_ilowat = 7 * cps / 8; 2189 x = cps + tp->t_ififosize; 2190 clist_alloc_cblocks(&tp->t_rawq, x, x); 2191 2192 /* Output. */ 2193 switch (tp->t_ospeedwat) { 2194 case (speed_t)-1: 2195 cps = tp->t_ospeed / 10; 2196 ttmaxhiwat = 2 * TTMAXHIWAT; 2197 break; 2198 case 0: 2199 cps = tp->t_ospeed / 10; 2200 ttmaxhiwat = TTMAXHIWAT; 2201 break; 2202 default: 2203 cps = tp->t_ospeedwat / 10; 2204 ttmaxhiwat = 8 * TTMAXHIWAT; 2205 break; 2206 } 2207 #define CLAMP(x, h, l) ((x) > h ? h : ((x) < l) ? l : (x)) 2208 tp->t_olowat = x = CLAMP(cps / 2, TTMAXLOWAT, TTMINLOWAT); 2209 x += cps; 2210 x = CLAMP(x, ttmaxhiwat, TTMINHIWAT); /* XXX clamps are too magic */ 2211 tp->t_ohiwat = roundup(x, CBSIZE); /* XXX for compat */ 2212 x = imax(tp->t_ohiwat, TTMAXHIWAT); /* XXX for compat/safety */ 2213 x += OBUFSIZ + 100; 2214 clist_alloc_cblocks(&tp->t_outq, x, x); 2215 #undef CLAMP 2216 } 2217 2218 /* 2219 * Report on state of foreground process group. 2220 */ 2221 void 2222 ttyinfo(tp) 2223 register struct tty *tp; 2224 { 2225 register struct proc *p, *pick; 2226 struct timeval utime, stime; 2227 int tmp; 2228 2229 if (ttycheckoutq(tp,0) == 0) 2230 return; 2231 2232 /* Print load average. */ 2233 tmp = (averunnable.ldavg[0] * 100 + FSCALE / 2) >> FSHIFT; 2234 ttyprintf(tp, "load: %d.%02d ", tmp / 100, tmp % 100); 2235 2236 if (tp->t_session == NULL) 2237 ttyprintf(tp, "not a controlling terminal\n"); 2238 else if (tp->t_pgrp == NULL) 2239 ttyprintf(tp, "no foreground process group\n"); 2240 else if ((p = LIST_FIRST(&tp->t_pgrp->pg_members)) == 0) 2241 ttyprintf(tp, "empty foreground process group\n"); 2242 else { 2243 /* Pick interesting process. */ 2244 for (pick = NULL; p != 0; p = LIST_NEXT(p, p_pglist)) 2245 if (proc_compare(pick, p)) 2246 pick = p; 2247 2248 ttyprintf(tp, " cmd: %s %d [%s] ", pick->p_comm, pick->p_pid, 2249 pick->p_stat == SRUN ? "running" : 2250 pick->p_wmesg ? pick->p_wmesg : "iowait"); 2251 2252 if (pick->p_flag & P_INMEM) { 2253 calcru(pick, &utime, &stime, NULL); 2254 2255 /* Print user time. */ 2256 ttyprintf(tp, "%ld.%02ldu ", 2257 utime.tv_sec, utime.tv_usec / 10000); 2258 2259 /* Print system time. */ 2260 ttyprintf(tp, "%ld.%02lds ", 2261 stime.tv_sec, stime.tv_usec / 10000); 2262 } else 2263 ttyprintf(tp, "?.??u ?.??s "); 2264 2265 /* Print percentage cpu, resident set size. */ 2266 tmp = (pick->p_pctcpu * 10000 + FSCALE / 2) >> FSHIFT; 2267 ttyprintf(tp, "%d%% %ldk\n", 2268 tmp / 100, 2269 pick->p_stat == SIDL || pick->p_stat == SWAIT || 2270 pick->p_stat == SZOMB ? 0 : 2271 (long)pgtok(vmspace_resident_count(pick->p_vmspace))); 2272 } 2273 tp->t_rocount = 0; /* so pending input will be retyped if BS */ 2274 } 2275 2276 /* 2277 * Returns 1 if p2 is "better" than p1 2278 * 2279 * The algorithm for picking the "interesting" process is thus: 2280 * 2281 * 1) Only foreground processes are eligible - implied. 2282 * 2) Runnable processes are favored over anything else. The runner 2283 * with the highest cpu utilization is picked (p_estcpu). Ties are 2284 * broken by picking the highest pid. 2285 * 3) The sleeper with the shortest sleep time is next. With ties, 2286 * we pick out just "short-term" sleepers (P_SINTR == 0). 2287 * 4) Further ties are broken by picking the highest pid. 2288 */ 2289 #define ISRUN(p) (((p)->p_stat == SRUN) || ((p)->p_stat == SIDL)) 2290 #define TESTAB(a, b) ((a)<<1 | (b)) 2291 #define ONLYA 2 2292 #define ONLYB 1 2293 #define BOTH 3 2294 2295 static int 2296 proc_compare(p1, p2) 2297 register struct proc *p1, *p2; 2298 { 2299 2300 if (p1 == NULL) 2301 return (1); 2302 /* 2303 * see if at least one of them is runnable 2304 */ 2305 switch (TESTAB(ISRUN(p1), ISRUN(p2))) { 2306 case ONLYA: 2307 return (0); 2308 case ONLYB: 2309 return (1); 2310 case BOTH: 2311 /* 2312 * tie - favor one with highest recent cpu utilization 2313 */ 2314 if (p2->p_estcpu > p1->p_estcpu) 2315 return (1); 2316 if (p1->p_estcpu > p2->p_estcpu) 2317 return (0); 2318 return (p2->p_pid > p1->p_pid); /* tie - return highest pid */ 2319 } 2320 /* 2321 * weed out zombies 2322 */ 2323 switch (TESTAB(p1->p_stat == SZOMB, p2->p_stat == SZOMB)) { 2324 case ONLYA: 2325 return (1); 2326 case ONLYB: 2327 return (0); 2328 case BOTH: 2329 return (p2->p_pid > p1->p_pid); /* tie - return highest pid */ 2330 } 2331 /* 2332 * pick the one with the smallest sleep time 2333 */ 2334 if (p2->p_slptime > p1->p_slptime) 2335 return (0); 2336 if (p1->p_slptime > p2->p_slptime) 2337 return (1); 2338 /* 2339 * favor one sleeping in a non-interruptible sleep 2340 */ 2341 if (p1->p_flag & P_SINTR && (p2->p_flag & P_SINTR) == 0) 2342 return (1); 2343 if (p2->p_flag & P_SINTR && (p1->p_flag & P_SINTR) == 0) 2344 return (0); 2345 return (p2->p_pid > p1->p_pid); /* tie - return highest pid */ 2346 } 2347 2348 /* 2349 * Output char to tty; console putchar style. 2350 */ 2351 int 2352 tputchar(c, tp) 2353 int c; 2354 struct tty *tp; 2355 { 2356 register int s; 2357 2358 s = spltty(); 2359 if (!ISSET(tp->t_state, TS_CONNECTED)) { 2360 splx(s); 2361 return (-1); 2362 } 2363 if (c == '\n') 2364 (void)ttyoutput('\r', tp); 2365 (void)ttyoutput(c, tp); 2366 ttstart(tp); 2367 splx(s); 2368 return (0); 2369 } 2370 2371 /* 2372 * Sleep on chan, returning ERESTART if tty changed while we napped and 2373 * returning any errors (e.g. EINTR/EWOULDBLOCK) reported by tsleep. If 2374 * the tty is revoked, restarting a pending call will redo validation done 2375 * at the start of the call. 2376 */ 2377 int 2378 ttysleep(tp, chan, pri, wmesg, timo) 2379 struct tty *tp; 2380 void *chan; 2381 int pri, timo; 2382 char *wmesg; 2383 { 2384 int error; 2385 int gen; 2386 2387 gen = tp->t_gen; 2388 error = tsleep(chan, pri, wmesg, timo); 2389 if (error) 2390 return (error); 2391 return (tp->t_gen == gen ? 0 : ERESTART); 2392 } 2393 2394 /* 2395 * Allocate a tty struct. Clists in the struct will be allocated by 2396 * ttyopen(). 2397 */ 2398 struct tty * 2399 ttymalloc(tp) 2400 struct tty *tp; 2401 { 2402 2403 if (tp) 2404 return(tp); 2405 tp = malloc(sizeof *tp, M_TTYS, M_WAITOK); 2406 bzero(tp, sizeof *tp); 2407 ttyregister(tp); 2408 return (tp); 2409 } 2410 2411 #if 0 /* XXX not yet usable: session leader holds a ref (see kern_exit.c). */ 2412 /* 2413 * Free a tty struct. Clists in the struct should have been freed by 2414 * ttyclose(). 2415 */ 2416 void 2417 ttyfree(tp) 2418 struct tty *tp; 2419 { 2420 free(tp, M_TTYS); 2421 } 2422 #endif /* 0 */ 2423 2424 void 2425 ttyregister(tp) 2426 struct tty *tp; 2427 { 2428 tp->t_timeout = -1; 2429 SLIST_INSERT_HEAD(&tty_list, tp, t_list); 2430 } 2431 2432 static int 2433 sysctl_kern_ttys(SYSCTL_HANDLER_ARGS) 2434 { 2435 int error; 2436 struct tty *tp, t; 2437 SLIST_FOREACH(tp, &tty_list, t_list) { 2438 t = *tp; 2439 if (t.t_dev) 2440 t.t_dev = (dev_t)dev2udev(t.t_dev); 2441 error = SYSCTL_OUT(req, (caddr_t)&t, sizeof(t)); 2442 if (error) 2443 return (error); 2444 } 2445 return (0); 2446 } 2447 2448 SYSCTL_PROC(_kern, OID_AUTO, ttys, CTLTYPE_OPAQUE|CTLFLAG_RD, 2449 0, 0, sysctl_kern_ttys, "S,tty", "All struct ttys"); 2450 2451 void 2452 nottystop(tp, rw) 2453 struct tty *tp; 2454 int rw; 2455 { 2456 2457 return; 2458 } 2459 2460 int 2461 ttyread(dev, uio, flag) 2462 dev_t dev; 2463 struct uio *uio; 2464 int flag; 2465 { 2466 struct tty *tp; 2467 2468 tp = dev->si_tty; 2469 if (tp == NULL) 2470 return (ENODEV); 2471 return ((*linesw[tp->t_line].l_read)(tp, uio, flag)); 2472 } 2473 2474 int 2475 ttywrite(dev, uio, flag) 2476 dev_t dev; 2477 struct uio *uio; 2478 int flag; 2479 { 2480 struct tty *tp; 2481 2482 tp = dev->si_tty; 2483 if (tp == NULL) 2484 return (ENODEV); 2485 return ((*linesw[tp->t_line].l_write)(tp, uio, flag)); 2486 } 2487