1 // SPDX-License-Identifier: GPL-2.0 2 /* 3 * Copyright (C) 1991, 1992, 1993, 1994 Linus Torvalds 4 * 5 * Modified by Fred N. van Kempen, 01/29/93, to add line disciplines 6 * which can be dynamically activated and de-activated by the line 7 * discipline handling modules (like SLIP). 8 */ 9 10 #include <linux/bits.h> 11 #include <linux/types.h> 12 #include <linux/termios.h> 13 #include <linux/errno.h> 14 #include <linux/sched/signal.h> 15 #include <linux/kernel.h> 16 #include <linux/major.h> 17 #include <linux/tty.h> 18 #include <linux/fcntl.h> 19 #include <linux/string.h> 20 #include <linux/mm.h> 21 #include <linux/module.h> 22 #include <linux/bitops.h> 23 #include <linux/mutex.h> 24 #include <linux/compat.h> 25 #include <linux/termios_internal.h> 26 #include "tty.h" 27 28 #include <asm/io.h> 29 #include <linux/uaccess.h> 30 31 #undef DEBUG 32 33 /* 34 * Internal flag options for termios setting behavior 35 */ 36 #define TERMIOS_FLUSH BIT(0) 37 #define TERMIOS_WAIT BIT(1) 38 #define TERMIOS_TERMIO BIT(2) 39 #define TERMIOS_OLD BIT(3) 40 41 42 /** 43 * tty_chars_in_buffer - characters pending 44 * @tty: terminal 45 * 46 * Return the number of bytes of data in the device private 47 * output queue. If no private method is supplied there is assumed 48 * to be no queue on the device. 49 */ 50 51 unsigned int tty_chars_in_buffer(struct tty_struct *tty) 52 { 53 if (tty->ops->chars_in_buffer) 54 return tty->ops->chars_in_buffer(tty); 55 return 0; 56 } 57 EXPORT_SYMBOL(tty_chars_in_buffer); 58 59 /** 60 * tty_write_room - write queue space 61 * @tty: terminal 62 * 63 * Return the number of bytes that can be queued to this device 64 * at the present time. The result should be treated as a guarantee 65 * and the driver cannot offer a value it later shrinks by more than 66 * the number of bytes written. If no method is provided 2K is always 67 * returned and data may be lost as there will be no flow control. 68 */ 69 70 unsigned int tty_write_room(struct tty_struct *tty) 71 { 72 if (tty->ops->write_room) 73 return tty->ops->write_room(tty); 74 return 2048; 75 } 76 EXPORT_SYMBOL(tty_write_room); 77 78 /** 79 * tty_driver_flush_buffer - discard internal buffer 80 * @tty: terminal 81 * 82 * Discard the internal output buffer for this device. If no method 83 * is provided then either the buffer cannot be hardware flushed or 84 * there is no buffer driver side. 85 */ 86 void tty_driver_flush_buffer(struct tty_struct *tty) 87 { 88 if (tty->ops->flush_buffer) 89 tty->ops->flush_buffer(tty); 90 } 91 EXPORT_SYMBOL(tty_driver_flush_buffer); 92 93 /** 94 * tty_unthrottle - flow control 95 * @tty: terminal 96 * 97 * Indicate that a tty may continue transmitting data down the stack. 98 * Takes the termios rwsem to protect against parallel throttle/unthrottle 99 * and also to ensure the driver can consistently reference its own 100 * termios data at this point when implementing software flow control. 101 * 102 * Drivers should however remember that the stack can issue a throttle, 103 * then change flow control method, then unthrottle. 104 */ 105 106 void tty_unthrottle(struct tty_struct *tty) 107 { 108 down_write(&tty->termios_rwsem); 109 if (test_and_clear_bit(TTY_THROTTLED, &tty->flags) && 110 tty->ops->unthrottle) 111 tty->ops->unthrottle(tty); 112 tty->flow_change = 0; 113 up_write(&tty->termios_rwsem); 114 } 115 EXPORT_SYMBOL(tty_unthrottle); 116 117 /** 118 * tty_throttle_safe - flow control 119 * @tty: terminal 120 * 121 * Indicate that a tty should stop transmitting data down the stack. 122 * tty_throttle_safe will only attempt throttle if tty->flow_change is 123 * TTY_THROTTLE_SAFE. Prevents an accidental throttle due to race 124 * conditions when throttling is conditional on factors evaluated prior to 125 * throttling. 126 * 127 * Returns 0 if tty is throttled (or was already throttled) 128 */ 129 130 int tty_throttle_safe(struct tty_struct *tty) 131 { 132 int ret = 0; 133 134 mutex_lock(&tty->throttle_mutex); 135 if (!tty_throttled(tty)) { 136 if (tty->flow_change != TTY_THROTTLE_SAFE) 137 ret = 1; 138 else { 139 set_bit(TTY_THROTTLED, &tty->flags); 140 if (tty->ops->throttle) 141 tty->ops->throttle(tty); 142 } 143 } 144 mutex_unlock(&tty->throttle_mutex); 145 146 return ret; 147 } 148 149 /** 150 * tty_unthrottle_safe - flow control 151 * @tty: terminal 152 * 153 * Similar to tty_unthrottle() but will only attempt unthrottle 154 * if tty->flow_change is TTY_UNTHROTTLE_SAFE. Prevents an accidental 155 * unthrottle due to race conditions when unthrottling is conditional 156 * on factors evaluated prior to unthrottling. 157 * 158 * Returns 0 if tty is unthrottled (or was already unthrottled) 159 */ 160 161 int tty_unthrottle_safe(struct tty_struct *tty) 162 { 163 int ret = 0; 164 165 mutex_lock(&tty->throttle_mutex); 166 if (tty_throttled(tty)) { 167 if (tty->flow_change != TTY_UNTHROTTLE_SAFE) 168 ret = 1; 169 else { 170 clear_bit(TTY_THROTTLED, &tty->flags); 171 if (tty->ops->unthrottle) 172 tty->ops->unthrottle(tty); 173 } 174 } 175 mutex_unlock(&tty->throttle_mutex); 176 177 return ret; 178 } 179 180 /** 181 * tty_wait_until_sent - wait for I/O to finish 182 * @tty: tty we are waiting for 183 * @timeout: how long we will wait 184 * 185 * Wait for characters pending in a tty driver to hit the wire, or 186 * for a timeout to occur (eg due to flow control) 187 * 188 * Locking: none 189 */ 190 191 void tty_wait_until_sent(struct tty_struct *tty, long timeout) 192 { 193 if (!timeout) 194 timeout = MAX_SCHEDULE_TIMEOUT; 195 196 timeout = wait_event_interruptible_timeout(tty->write_wait, 197 !tty_chars_in_buffer(tty), timeout); 198 if (timeout <= 0) 199 return; 200 201 if (timeout == MAX_SCHEDULE_TIMEOUT) 202 timeout = 0; 203 204 if (tty->ops->wait_until_sent) 205 tty->ops->wait_until_sent(tty, timeout); 206 } 207 EXPORT_SYMBOL(tty_wait_until_sent); 208 209 210 /* 211 * Termios Helper Methods 212 */ 213 214 static void unset_locked_termios(struct tty_struct *tty, const struct ktermios *old) 215 { 216 struct ktermios *termios = &tty->termios; 217 struct ktermios *locked = &tty->termios_locked; 218 int i; 219 220 #define NOSET_MASK(x, y, z) (x = ((x) & ~(z)) | ((y) & (z))) 221 222 NOSET_MASK(termios->c_iflag, old->c_iflag, locked->c_iflag); 223 NOSET_MASK(termios->c_oflag, old->c_oflag, locked->c_oflag); 224 NOSET_MASK(termios->c_cflag, old->c_cflag, locked->c_cflag); 225 NOSET_MASK(termios->c_lflag, old->c_lflag, locked->c_lflag); 226 termios->c_line = locked->c_line ? old->c_line : termios->c_line; 227 for (i = 0; i < NCCS; i++) 228 termios->c_cc[i] = locked->c_cc[i] ? 229 old->c_cc[i] : termios->c_cc[i]; 230 /* FIXME: What should we do for i/ospeed */ 231 } 232 233 /** 234 * tty_termios_copy_hw - copy hardware settings 235 * @new: New termios 236 * @old: Old termios 237 * 238 * Propagate the hardware specific terminal setting bits from 239 * the old termios structure to the new one. This is used in cases 240 * where the hardware does not support reconfiguration or as a helper 241 * in some cases where only minimal reconfiguration is supported 242 */ 243 244 void tty_termios_copy_hw(struct ktermios *new, const struct ktermios *old) 245 { 246 /* The bits a dumb device handles in software. Smart devices need 247 to always provide a set_termios method */ 248 new->c_cflag &= HUPCL | CREAD | CLOCAL; 249 new->c_cflag |= old->c_cflag & ~(HUPCL | CREAD | CLOCAL); 250 new->c_ispeed = old->c_ispeed; 251 new->c_ospeed = old->c_ospeed; 252 } 253 EXPORT_SYMBOL(tty_termios_copy_hw); 254 255 /** 256 * tty_termios_hw_change - check for setting change 257 * @a: termios 258 * @b: termios to compare 259 * 260 * Check if any of the bits that affect a dumb device have changed 261 * between the two termios structures, or a speed change is needed. 262 */ 263 264 bool tty_termios_hw_change(const struct ktermios *a, const struct ktermios *b) 265 { 266 if (a->c_ispeed != b->c_ispeed || a->c_ospeed != b->c_ospeed) 267 return true; 268 if ((a->c_cflag ^ b->c_cflag) & ~(HUPCL | CREAD | CLOCAL)) 269 return true; 270 return false; 271 } 272 EXPORT_SYMBOL(tty_termios_hw_change); 273 274 /** 275 * tty_get_char_size - get size of a character 276 * @cflag: termios cflag value 277 * 278 * Get the size (in bits) of a character depending on @cflag's %CSIZE 279 * setting. 280 */ 281 unsigned char tty_get_char_size(unsigned int cflag) 282 { 283 switch (cflag & CSIZE) { 284 case CS5: 285 return 5; 286 case CS6: 287 return 6; 288 case CS7: 289 return 7; 290 case CS8: 291 default: 292 return 8; 293 } 294 } 295 EXPORT_SYMBOL_GPL(tty_get_char_size); 296 297 /** 298 * tty_get_frame_size - get size of a frame 299 * @cflag: termios cflag value 300 * 301 * Get the size (in bits) of a frame depending on @cflag's %CSIZE, %CSTOPB, 302 * and %PARENB setting. The result is a sum of character size, start and 303 * stop bits -- one bit each -- second stop bit (if set), and parity bit 304 * (if set). 305 */ 306 unsigned char tty_get_frame_size(unsigned int cflag) 307 { 308 unsigned char bits = 2 + tty_get_char_size(cflag); 309 310 if (cflag & CSTOPB) 311 bits++; 312 if (cflag & PARENB) 313 bits++; 314 if (cflag & ADDRB) 315 bits++; 316 317 return bits; 318 } 319 EXPORT_SYMBOL_GPL(tty_get_frame_size); 320 321 /** 322 * tty_set_termios - update termios values 323 * @tty: tty to update 324 * @new_termios: desired new value 325 * 326 * Perform updates to the termios values set on this terminal. 327 * A master pty's termios should never be set. 328 * 329 * Locking: termios_rwsem 330 */ 331 332 int tty_set_termios(struct tty_struct *tty, struct ktermios *new_termios) 333 { 334 struct ktermios old_termios; 335 struct tty_ldisc *ld; 336 337 WARN_ON(tty->driver->type == TTY_DRIVER_TYPE_PTY && 338 tty->driver->subtype == PTY_TYPE_MASTER); 339 /* 340 * Perform the actual termios internal changes under lock. 341 */ 342 343 344 /* FIXME: we need to decide on some locking/ordering semantics 345 for the set_termios notification eventually */ 346 down_write(&tty->termios_rwsem); 347 old_termios = tty->termios; 348 tty->termios = *new_termios; 349 unset_locked_termios(tty, &old_termios); 350 /* Reset any ADDRB changes, ADDRB is changed through ->rs485_config() */ 351 tty->termios.c_cflag ^= (tty->termios.c_cflag ^ old_termios.c_cflag) & ADDRB; 352 353 if (tty->ops->set_termios) 354 tty->ops->set_termios(tty, &old_termios); 355 else 356 tty_termios_copy_hw(&tty->termios, &old_termios); 357 358 ld = tty_ldisc_ref(tty); 359 if (ld != NULL) { 360 if (ld->ops->set_termios) 361 ld->ops->set_termios(tty, &old_termios); 362 tty_ldisc_deref(ld); 363 } 364 up_write(&tty->termios_rwsem); 365 return 0; 366 } 367 EXPORT_SYMBOL_GPL(tty_set_termios); 368 369 370 /* 371 * Translate a "termio" structure into a "termios". Ugh. 372 */ 373 __weak int user_termio_to_kernel_termios(struct ktermios *termios, 374 struct termio __user *termio) 375 { 376 struct termio v; 377 378 if (copy_from_user(&v, termio, sizeof(struct termio))) 379 return -EFAULT; 380 381 termios->c_iflag = (0xffff0000 & termios->c_iflag) | v.c_iflag; 382 termios->c_oflag = (0xffff0000 & termios->c_oflag) | v.c_oflag; 383 termios->c_cflag = (0xffff0000 & termios->c_cflag) | v.c_cflag; 384 termios->c_lflag = (0xffff0000 & termios->c_lflag) | v.c_lflag; 385 termios->c_line = (0xffff0000 & termios->c_lflag) | v.c_line; 386 memcpy(termios->c_cc, v.c_cc, NCC); 387 return 0; 388 } 389 390 /* 391 * Translate a "termios" structure into a "termio". Ugh. 392 */ 393 __weak int kernel_termios_to_user_termio(struct termio __user *termio, 394 struct ktermios *termios) 395 { 396 struct termio v; 397 memset(&v, 0, sizeof(struct termio)); 398 v.c_iflag = termios->c_iflag; 399 v.c_oflag = termios->c_oflag; 400 v.c_cflag = termios->c_cflag; 401 v.c_lflag = termios->c_lflag; 402 v.c_line = termios->c_line; 403 memcpy(v.c_cc, termios->c_cc, NCC); 404 return copy_to_user(termio, &v, sizeof(struct termio)); 405 } 406 407 #ifdef TCGETS2 408 __weak int user_termios_to_kernel_termios(struct ktermios *k, 409 struct termios2 __user *u) 410 { 411 return copy_from_user(k, u, sizeof(struct termios2)); 412 } 413 __weak int kernel_termios_to_user_termios(struct termios2 __user *u, 414 struct ktermios *k) 415 { 416 return copy_to_user(u, k, sizeof(struct termios2)); 417 } 418 __weak int user_termios_to_kernel_termios_1(struct ktermios *k, 419 struct termios __user *u) 420 { 421 return copy_from_user(k, u, sizeof(struct termios)); 422 } 423 __weak int kernel_termios_to_user_termios_1(struct termios __user *u, 424 struct ktermios *k) 425 { 426 return copy_to_user(u, k, sizeof(struct termios)); 427 } 428 429 #else 430 431 __weak int user_termios_to_kernel_termios(struct ktermios *k, 432 struct termios __user *u) 433 { 434 return copy_from_user(k, u, sizeof(struct termios)); 435 } 436 __weak int kernel_termios_to_user_termios(struct termios __user *u, 437 struct ktermios *k) 438 { 439 return copy_to_user(u, k, sizeof(struct termios)); 440 } 441 #endif /* TCGETS2 */ 442 443 /** 444 * set_termios - set termios values for a tty 445 * @tty: terminal device 446 * @arg: user data 447 * @opt: option information 448 * 449 * Helper function to prepare termios data and run necessary other 450 * functions before using tty_set_termios to do the actual changes. 451 * 452 * Locking: 453 * Called functions take ldisc and termios_rwsem locks 454 */ 455 456 static int set_termios(struct tty_struct *tty, void __user *arg, int opt) 457 { 458 struct ktermios tmp_termios; 459 struct tty_ldisc *ld; 460 int retval = tty_check_change(tty); 461 462 if (retval) 463 return retval; 464 465 down_read(&tty->termios_rwsem); 466 tmp_termios = tty->termios; 467 up_read(&tty->termios_rwsem); 468 469 if (opt & TERMIOS_TERMIO) { 470 if (user_termio_to_kernel_termios(&tmp_termios, 471 (struct termio __user *)arg)) 472 return -EFAULT; 473 #ifdef TCGETS2 474 } else if (opt & TERMIOS_OLD) { 475 if (user_termios_to_kernel_termios_1(&tmp_termios, 476 (struct termios __user *)arg)) 477 return -EFAULT; 478 } else { 479 if (user_termios_to_kernel_termios(&tmp_termios, 480 (struct termios2 __user *)arg)) 481 return -EFAULT; 482 } 483 #else 484 } else if (user_termios_to_kernel_termios(&tmp_termios, 485 (struct termios __user *)arg)) 486 return -EFAULT; 487 #endif 488 489 /* If old style Bfoo values are used then load c_ispeed/c_ospeed 490 * with the real speed so its unconditionally usable */ 491 tmp_termios.c_ispeed = tty_termios_input_baud_rate(&tmp_termios); 492 tmp_termios.c_ospeed = tty_termios_baud_rate(&tmp_termios); 493 494 if (opt & (TERMIOS_FLUSH|TERMIOS_WAIT)) { 495 retry_write_wait: 496 retval = wait_event_interruptible(tty->write_wait, !tty_chars_in_buffer(tty)); 497 if (retval < 0) 498 return retval; 499 500 if (tty_write_lock(tty, false) < 0) 501 goto retry_write_wait; 502 503 /* Racing writer? */ 504 if (tty_chars_in_buffer(tty)) { 505 tty_write_unlock(tty); 506 goto retry_write_wait; 507 } 508 509 ld = tty_ldisc_ref(tty); 510 if (ld != NULL) { 511 if ((opt & TERMIOS_FLUSH) && ld->ops->flush_buffer) 512 ld->ops->flush_buffer(tty); 513 tty_ldisc_deref(ld); 514 } 515 516 if ((opt & TERMIOS_WAIT) && tty->ops->wait_until_sent) { 517 tty->ops->wait_until_sent(tty, 0); 518 if (signal_pending(current)) { 519 tty_write_unlock(tty); 520 return -ERESTARTSYS; 521 } 522 } 523 524 tty_set_termios(tty, &tmp_termios); 525 526 tty_write_unlock(tty); 527 } else { 528 tty_set_termios(tty, &tmp_termios); 529 } 530 531 /* FIXME: Arguably if tmp_termios == tty->termios AND the 532 actual requested termios was not tmp_termios then we may 533 want to return an error as no user requested change has 534 succeeded */ 535 return 0; 536 } 537 538 static void copy_termios(struct tty_struct *tty, struct ktermios *kterm) 539 { 540 down_read(&tty->termios_rwsem); 541 *kterm = tty->termios; 542 up_read(&tty->termios_rwsem); 543 } 544 545 static void copy_termios_locked(struct tty_struct *tty, struct ktermios *kterm) 546 { 547 down_read(&tty->termios_rwsem); 548 *kterm = tty->termios_locked; 549 up_read(&tty->termios_rwsem); 550 } 551 552 static int get_termio(struct tty_struct *tty, struct termio __user *termio) 553 { 554 struct ktermios kterm; 555 copy_termios(tty, &kterm); 556 if (kernel_termios_to_user_termio(termio, &kterm)) 557 return -EFAULT; 558 return 0; 559 } 560 561 #ifdef TIOCGETP 562 /* 563 * These are deprecated, but there is limited support.. 564 * 565 * The "sg_flags" translation is a joke.. 566 */ 567 static int get_sgflags(struct tty_struct *tty) 568 { 569 int flags = 0; 570 571 if (!L_ICANON(tty)) { 572 if (L_ISIG(tty)) 573 flags |= 0x02; /* cbreak */ 574 else 575 flags |= 0x20; /* raw */ 576 } 577 if (L_ECHO(tty)) 578 flags |= 0x08; /* echo */ 579 if (O_OPOST(tty)) 580 if (O_ONLCR(tty)) 581 flags |= 0x10; /* crmod */ 582 return flags; 583 } 584 585 static int get_sgttyb(struct tty_struct *tty, struct sgttyb __user *sgttyb) 586 { 587 struct sgttyb tmp; 588 589 down_read(&tty->termios_rwsem); 590 tmp.sg_ispeed = tty->termios.c_ispeed; 591 tmp.sg_ospeed = tty->termios.c_ospeed; 592 tmp.sg_erase = tty->termios.c_cc[VERASE]; 593 tmp.sg_kill = tty->termios.c_cc[VKILL]; 594 tmp.sg_flags = get_sgflags(tty); 595 up_read(&tty->termios_rwsem); 596 597 return copy_to_user(sgttyb, &tmp, sizeof(tmp)) ? -EFAULT : 0; 598 } 599 600 static void set_sgflags(struct ktermios *termios, int flags) 601 { 602 termios->c_iflag = ICRNL | IXON; 603 termios->c_oflag = 0; 604 termios->c_lflag = ISIG | ICANON; 605 if (flags & 0x02) { /* cbreak */ 606 termios->c_iflag = 0; 607 termios->c_lflag &= ~ICANON; 608 } 609 if (flags & 0x08) { /* echo */ 610 termios->c_lflag |= ECHO | ECHOE | ECHOK | 611 ECHOCTL | ECHOKE | IEXTEN; 612 } 613 if (flags & 0x10) { /* crmod */ 614 termios->c_oflag |= OPOST | ONLCR; 615 } 616 if (flags & 0x20) { /* raw */ 617 termios->c_iflag = 0; 618 termios->c_lflag &= ~(ISIG | ICANON); 619 } 620 if (!(termios->c_lflag & ICANON)) { 621 termios->c_cc[VMIN] = 1; 622 termios->c_cc[VTIME] = 0; 623 } 624 } 625 626 /** 627 * set_sgttyb - set legacy terminal values 628 * @tty: tty structure 629 * @sgttyb: pointer to old style terminal structure 630 * 631 * Updates a terminal from the legacy BSD style terminal information 632 * structure. 633 * 634 * Locking: termios_rwsem 635 */ 636 637 static int set_sgttyb(struct tty_struct *tty, struct sgttyb __user *sgttyb) 638 { 639 int retval; 640 struct sgttyb tmp; 641 struct ktermios termios; 642 643 retval = tty_check_change(tty); 644 if (retval) 645 return retval; 646 647 if (copy_from_user(&tmp, sgttyb, sizeof(tmp))) 648 return -EFAULT; 649 650 down_write(&tty->termios_rwsem); 651 termios = tty->termios; 652 termios.c_cc[VERASE] = tmp.sg_erase; 653 termios.c_cc[VKILL] = tmp.sg_kill; 654 set_sgflags(&termios, tmp.sg_flags); 655 /* Try and encode into Bfoo format */ 656 tty_termios_encode_baud_rate(&termios, termios.c_ispeed, 657 termios.c_ospeed); 658 up_write(&tty->termios_rwsem); 659 tty_set_termios(tty, &termios); 660 return 0; 661 } 662 #endif 663 664 #ifdef TIOCGETC 665 static int get_tchars(struct tty_struct *tty, struct tchars __user *tchars) 666 { 667 struct tchars tmp; 668 669 down_read(&tty->termios_rwsem); 670 tmp.t_intrc = tty->termios.c_cc[VINTR]; 671 tmp.t_quitc = tty->termios.c_cc[VQUIT]; 672 tmp.t_startc = tty->termios.c_cc[VSTART]; 673 tmp.t_stopc = tty->termios.c_cc[VSTOP]; 674 tmp.t_eofc = tty->termios.c_cc[VEOF]; 675 tmp.t_brkc = tty->termios.c_cc[VEOL2]; /* what is brkc anyway? */ 676 up_read(&tty->termios_rwsem); 677 return copy_to_user(tchars, &tmp, sizeof(tmp)) ? -EFAULT : 0; 678 } 679 680 static int set_tchars(struct tty_struct *tty, struct tchars __user *tchars) 681 { 682 struct tchars tmp; 683 684 if (copy_from_user(&tmp, tchars, sizeof(tmp))) 685 return -EFAULT; 686 down_write(&tty->termios_rwsem); 687 tty->termios.c_cc[VINTR] = tmp.t_intrc; 688 tty->termios.c_cc[VQUIT] = tmp.t_quitc; 689 tty->termios.c_cc[VSTART] = tmp.t_startc; 690 tty->termios.c_cc[VSTOP] = tmp.t_stopc; 691 tty->termios.c_cc[VEOF] = tmp.t_eofc; 692 tty->termios.c_cc[VEOL2] = tmp.t_brkc; /* what is brkc anyway? */ 693 up_write(&tty->termios_rwsem); 694 return 0; 695 } 696 #endif 697 698 #ifdef TIOCGLTC 699 static int get_ltchars(struct tty_struct *tty, struct ltchars __user *ltchars) 700 { 701 struct ltchars tmp; 702 703 down_read(&tty->termios_rwsem); 704 tmp.t_suspc = tty->termios.c_cc[VSUSP]; 705 /* what is dsuspc anyway? */ 706 tmp.t_dsuspc = tty->termios.c_cc[VSUSP]; 707 tmp.t_rprntc = tty->termios.c_cc[VREPRINT]; 708 /* what is flushc anyway? */ 709 tmp.t_flushc = tty->termios.c_cc[VEOL2]; 710 tmp.t_werasc = tty->termios.c_cc[VWERASE]; 711 tmp.t_lnextc = tty->termios.c_cc[VLNEXT]; 712 up_read(&tty->termios_rwsem); 713 return copy_to_user(ltchars, &tmp, sizeof(tmp)) ? -EFAULT : 0; 714 } 715 716 static int set_ltchars(struct tty_struct *tty, struct ltchars __user *ltchars) 717 { 718 struct ltchars tmp; 719 720 if (copy_from_user(&tmp, ltchars, sizeof(tmp))) 721 return -EFAULT; 722 723 down_write(&tty->termios_rwsem); 724 tty->termios.c_cc[VSUSP] = tmp.t_suspc; 725 /* what is dsuspc anyway? */ 726 tty->termios.c_cc[VEOL2] = tmp.t_dsuspc; 727 tty->termios.c_cc[VREPRINT] = tmp.t_rprntc; 728 /* what is flushc anyway? */ 729 tty->termios.c_cc[VEOL2] = tmp.t_flushc; 730 tty->termios.c_cc[VWERASE] = tmp.t_werasc; 731 tty->termios.c_cc[VLNEXT] = tmp.t_lnextc; 732 up_write(&tty->termios_rwsem); 733 return 0; 734 } 735 #endif 736 737 /** 738 * tty_change_softcar - carrier change ioctl helper 739 * @tty: tty to update 740 * @enable: enable/disable CLOCAL 741 * 742 * Perform a change to the CLOCAL state and call into the driver 743 * layer to make it visible. All done with the termios rwsem 744 */ 745 746 static int tty_change_softcar(struct tty_struct *tty, bool enable) 747 { 748 int ret = 0; 749 struct ktermios old; 750 tcflag_t bit = enable ? CLOCAL : 0; 751 752 down_write(&tty->termios_rwsem); 753 old = tty->termios; 754 tty->termios.c_cflag &= ~CLOCAL; 755 tty->termios.c_cflag |= bit; 756 if (tty->ops->set_termios) 757 tty->ops->set_termios(tty, &old); 758 if (C_CLOCAL(tty) != bit) 759 ret = -EINVAL; 760 up_write(&tty->termios_rwsem); 761 return ret; 762 } 763 764 /** 765 * tty_mode_ioctl - mode related ioctls 766 * @tty: tty for the ioctl 767 * @cmd: command 768 * @arg: ioctl argument 769 * 770 * Perform non line discipline specific mode control ioctls. This 771 * is designed to be called by line disciplines to ensure they provide 772 * consistent mode setting. 773 */ 774 775 int tty_mode_ioctl(struct tty_struct *tty, unsigned int cmd, unsigned long arg) 776 { 777 struct tty_struct *real_tty; 778 void __user *p = (void __user *)arg; 779 int ret = 0; 780 struct ktermios kterm; 781 782 if (tty->driver->type == TTY_DRIVER_TYPE_PTY && 783 tty->driver->subtype == PTY_TYPE_MASTER) 784 real_tty = tty->link; 785 else 786 real_tty = tty; 787 788 switch (cmd) { 789 #ifdef TIOCGETP 790 case TIOCGETP: 791 return get_sgttyb(real_tty, (struct sgttyb __user *) arg); 792 case TIOCSETP: 793 case TIOCSETN: 794 return set_sgttyb(real_tty, (struct sgttyb __user *) arg); 795 #endif 796 #ifdef TIOCGETC 797 case TIOCGETC: 798 return get_tchars(real_tty, p); 799 case TIOCSETC: 800 return set_tchars(real_tty, p); 801 #endif 802 #ifdef TIOCGLTC 803 case TIOCGLTC: 804 return get_ltchars(real_tty, p); 805 case TIOCSLTC: 806 return set_ltchars(real_tty, p); 807 #endif 808 case TCSETSF: 809 return set_termios(real_tty, p, TERMIOS_FLUSH | TERMIOS_WAIT | TERMIOS_OLD); 810 case TCSETSW: 811 return set_termios(real_tty, p, TERMIOS_WAIT | TERMIOS_OLD); 812 case TCSETS: 813 return set_termios(real_tty, p, TERMIOS_OLD); 814 #ifndef TCGETS2 815 case TCGETS: 816 copy_termios(real_tty, &kterm); 817 if (kernel_termios_to_user_termios((struct termios __user *)arg, &kterm)) 818 ret = -EFAULT; 819 return ret; 820 #else 821 case TCGETS: 822 copy_termios(real_tty, &kterm); 823 if (kernel_termios_to_user_termios_1((struct termios __user *)arg, &kterm)) 824 ret = -EFAULT; 825 return ret; 826 case TCGETS2: 827 copy_termios(real_tty, &kterm); 828 if (kernel_termios_to_user_termios((struct termios2 __user *)arg, &kterm)) 829 ret = -EFAULT; 830 return ret; 831 case TCSETSF2: 832 return set_termios(real_tty, p, TERMIOS_FLUSH | TERMIOS_WAIT); 833 case TCSETSW2: 834 return set_termios(real_tty, p, TERMIOS_WAIT); 835 case TCSETS2: 836 return set_termios(real_tty, p, 0); 837 #endif 838 case TCGETA: 839 return get_termio(real_tty, p); 840 case TCSETAF: 841 return set_termios(real_tty, p, TERMIOS_FLUSH | TERMIOS_WAIT | TERMIOS_TERMIO); 842 case TCSETAW: 843 return set_termios(real_tty, p, TERMIOS_WAIT | TERMIOS_TERMIO); 844 case TCSETA: 845 return set_termios(real_tty, p, TERMIOS_TERMIO); 846 #ifndef TCGETS2 847 case TIOCGLCKTRMIOS: 848 copy_termios_locked(real_tty, &kterm); 849 if (kernel_termios_to_user_termios((struct termios __user *)arg, &kterm)) 850 ret = -EFAULT; 851 return ret; 852 case TIOCSLCKTRMIOS: 853 if (!capable(CAP_SYS_ADMIN)) 854 return -EPERM; 855 copy_termios_locked(real_tty, &kterm); 856 if (user_termios_to_kernel_termios(&kterm, 857 (struct termios __user *) arg)) 858 return -EFAULT; 859 down_write(&real_tty->termios_rwsem); 860 real_tty->termios_locked = kterm; 861 up_write(&real_tty->termios_rwsem); 862 return 0; 863 #else 864 case TIOCGLCKTRMIOS: 865 copy_termios_locked(real_tty, &kterm); 866 if (kernel_termios_to_user_termios_1((struct termios __user *)arg, &kterm)) 867 ret = -EFAULT; 868 return ret; 869 case TIOCSLCKTRMIOS: 870 if (!capable(CAP_SYS_ADMIN)) 871 return -EPERM; 872 copy_termios_locked(real_tty, &kterm); 873 if (user_termios_to_kernel_termios_1(&kterm, 874 (struct termios __user *) arg)) 875 return -EFAULT; 876 down_write(&real_tty->termios_rwsem); 877 real_tty->termios_locked = kterm; 878 up_write(&real_tty->termios_rwsem); 879 return ret; 880 #endif 881 #ifdef TCGETX 882 case TCGETX: 883 case TCSETX: 884 case TCSETXW: 885 case TCSETXF: 886 return -ENOTTY; 887 #endif 888 case TIOCGSOFTCAR: 889 copy_termios(real_tty, &kterm); 890 ret = put_user((kterm.c_cflag & CLOCAL) ? 1 : 0, 891 (int __user *)arg); 892 return ret; 893 case TIOCSSOFTCAR: 894 if (get_user(arg, (unsigned int __user *) arg)) 895 return -EFAULT; 896 return tty_change_softcar(real_tty, arg); 897 default: 898 return -ENOIOCTLCMD; 899 } 900 } 901 EXPORT_SYMBOL_GPL(tty_mode_ioctl); 902 903 904 /* Caller guarantees ldisc reference is held */ 905 static int __tty_perform_flush(struct tty_struct *tty, unsigned long arg) 906 { 907 struct tty_ldisc *ld = tty->ldisc; 908 909 switch (arg) { 910 case TCIFLUSH: 911 if (ld && ld->ops->flush_buffer) { 912 ld->ops->flush_buffer(tty); 913 tty_unthrottle(tty); 914 } 915 break; 916 case TCIOFLUSH: 917 if (ld && ld->ops->flush_buffer) { 918 ld->ops->flush_buffer(tty); 919 tty_unthrottle(tty); 920 } 921 fallthrough; 922 case TCOFLUSH: 923 tty_driver_flush_buffer(tty); 924 break; 925 default: 926 return -EINVAL; 927 } 928 return 0; 929 } 930 931 int tty_perform_flush(struct tty_struct *tty, unsigned long arg) 932 { 933 struct tty_ldisc *ld; 934 int retval = tty_check_change(tty); 935 if (retval) 936 return retval; 937 938 ld = tty_ldisc_ref_wait(tty); 939 retval = __tty_perform_flush(tty, arg); 940 if (ld) 941 tty_ldisc_deref(ld); 942 return retval; 943 } 944 EXPORT_SYMBOL_GPL(tty_perform_flush); 945 946 int n_tty_ioctl_helper(struct tty_struct *tty, unsigned int cmd, 947 unsigned long arg) 948 { 949 int retval; 950 951 switch (cmd) { 952 case TCXONC: 953 retval = tty_check_change(tty); 954 if (retval) 955 return retval; 956 switch (arg) { 957 case TCOOFF: 958 spin_lock_irq(&tty->flow.lock); 959 if (!tty->flow.tco_stopped) { 960 tty->flow.tco_stopped = true; 961 __stop_tty(tty); 962 } 963 spin_unlock_irq(&tty->flow.lock); 964 break; 965 case TCOON: 966 spin_lock_irq(&tty->flow.lock); 967 if (tty->flow.tco_stopped) { 968 tty->flow.tco_stopped = false; 969 __start_tty(tty); 970 } 971 spin_unlock_irq(&tty->flow.lock); 972 break; 973 case TCIOFF: 974 if (STOP_CHAR(tty) != __DISABLED_CHAR) 975 retval = tty_send_xchar(tty, STOP_CHAR(tty)); 976 break; 977 case TCION: 978 if (START_CHAR(tty) != __DISABLED_CHAR) 979 retval = tty_send_xchar(tty, START_CHAR(tty)); 980 break; 981 default: 982 return -EINVAL; 983 } 984 return retval; 985 case TCFLSH: 986 retval = tty_check_change(tty); 987 if (retval) 988 return retval; 989 return __tty_perform_flush(tty, arg); 990 default: 991 /* Try the mode commands */ 992 return tty_mode_ioctl(tty, cmd, arg); 993 } 994 } 995 EXPORT_SYMBOL(n_tty_ioctl_helper); 996