1.\" Copyright (c) 1991, 1992, 1993 2.\" The Regents of the University of California. All rights reserved. 3.\" 4.\" Redistribution and use in source and binary forms, with or without 5.\" modification, are permitted provided that the following conditions 6.\" are met: 7.\" 1. Redistributions of source code must retain the above copyright 8.\" notice, this list of conditions and the following disclaimer. 9.\" 2. Redistributions in binary form must reproduce the above copyright 10.\" notice, this list of conditions and the following disclaimer in the 11.\" documentation and/or other materials provided with the distribution. 12.\" 3. Neither the name of the University nor the names of its contributors 13.\" may be used to endorse or promote products derived from this software 14.\" without specific prior written permission. 15.\" 16.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 17.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 18.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 19.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 20.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 21.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 22.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 23.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 24.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 25.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26.\" SUCH DAMAGE. 27.\" 28.\" @(#)termios.4 8.4 (Berkeley) 4/19/94 29.\" $FreeBSD$ 30.\" 31.Dd December 26, 2009 32.Dt TERMIOS 4 33.Os 34.Sh NAME 35.Nm termios 36.Nd general terminal line discipline 37.Sh SYNOPSIS 38.In termios.h 39.Sh DESCRIPTION 40This describes a general terminal line discipline that is 41supported on tty asynchronous communication ports. 42.Ss Opening a Terminal Device File 43When a terminal file is opened, it normally causes the process to wait 44until a connection is established. 45For most hardware, the presence 46of a connection is indicated by the assertion of the hardware 47.Dv CARRIER 48line. 49If the termios structure associated with the terminal file has the 50.Dv CLOCAL 51flag set in the cflag, or if the 52.Dv O_NONBLOCK 53flag is set 54in the 55.Xr open 2 56call, then the open will succeed even without 57a connection being present. 58In practice, applications 59seldom open these files; they are opened by special programs, such 60as 61.Xr getty 8 62or 63.Xr rlogind 8 , 64and become 65an application's standard input, output, and error files. 66.Ss Job Control in a Nutshell 67Every process is associated with a particular process group and session. 68The grouping is hierarchical: every member of a particular process group is a 69member of the same session. 70This structuring is used in managing groups 71of related processes for purposes of 72.\" .Gw "job control" ; 73.Em "job control" ; 74that is, the 75ability from the keyboard (or from program control) to simultaneously 76stop or restart 77a complex command (a command composed of one or more related 78processes). 79The grouping into process groups allows delivering 80of signals that stop or start the group as a whole, along with 81arbitrating which process group has access to the single controlling 82terminal. 83The grouping at a higher layer into sessions is to restrict 84the job control related signals and system calls to within processes 85resulting from a particular instance of a 86.Dq login . 87Typically, a session 88is created when a user logs in, and the login terminal is setup 89to be the controlling terminal; all processes spawned from that 90login shell are in the same session, and inherit the controlling 91terminal. 92.Pp 93A job control shell 94operating interactively (that is, reading commands from a terminal) 95normally groups related processes together by placing them into the 96same process group. 97A set of processes in the same process group 98is collectively referred to as a 99.Dq job . 100When the foreground process 101group of the terminal is the same as the process group of a particular 102job, that job is said to be in the 103.Dq foreground . 104When the process group of the terminal is different from the process group of 105a job (but is still the controlling terminal), that job is said 106to be in the 107.Dq background . 108Normally the 109shell reads a command and starts the job that implements that 110command. 111If the command is to be started in the foreground (typical), it 112sets the process group of the terminal to the process group 113of the started job, waits for the job to complete, and then 114sets the process group of the terminal back to its own process 115group (it puts itself into the foreground). 116If the job is to 117be started in the background (as denoted by the shell operator "&"), 118it never changes the process group of the terminal and does not 119wait for the job to complete (that is, it immediately attempts to read the next 120command). 121If the job is started in the foreground, the user may 122type a key (usually 123.Ql \&^Z ) 124which generates the terminal stop signal 125.Pq Dv SIGTSTP 126and has the effect of stopping the entire job. 127The shell will notice that the job stopped, and will resume running after 128placing itself in the foreground. 129The shell also has commands for placing stopped jobs in the background, 130and for placing stopped or background jobs into the foreground. 131.Ss Orphaned Process Groups 132An orphaned process group is a process group that has no process 133whose parent is in a different process group, yet is in the same 134session. 135Conceptually it means a process group that does not have 136a parent that could do anything if it were to be stopped. 137For example, 138the initial login shell is typically in an orphaned process group. 139Orphaned process groups are immune to keyboard generated stop 140signals and job control signals resulting from reads or writes to the 141controlling terminal. 142.Ss The Controlling Terminal 143A terminal may belong to a process as its controlling terminal. 144Each 145process of a session that has a controlling terminal has the same 146controlling terminal. 147A terminal may be the controlling terminal for at 148most one session. 149The controlling terminal for a session is allocated by 150the session leader by issuing the 151.Dv TIOCSCTTY 152ioctl. 153A controlling terminal 154is never acquired by merely opening a terminal device file. 155When a controlling terminal becomes 156associated with a session, its foreground process group is set to 157the process group of the session leader. 158.Pp 159The controlling terminal is inherited by a child process during a 160.Xr fork 2 161function call. 162A process relinquishes its controlling terminal when it 163creates a new session with the 164.Xr setsid 2 165function; other processes 166remaining in the old session that had this terminal as their controlling 167terminal continue to have it. 168A process does not relinquish its 169controlling terminal simply by closing all of its file descriptors 170associated with the controlling terminal if other processes continue to 171have it open. 172.Pp 173When a controlling process terminates, the controlling terminal is 174disassociated from the current session, allowing it to be acquired by a 175new session leader. 176Subsequent access to the terminal by other processes 177in the earlier session will be denied, with attempts to access the 178terminal treated as if modem disconnect had been sensed. 179.Ss Terminal Access Control 180If a process is in the foreground process group of its controlling 181terminal, read operations are allowed. 182Any attempts by a process 183in a background process group to read from its controlling terminal 184causes a 185.Dv SIGTTIN 186signal to be sent to 187the process's group 188unless one of the 189following special cases apply: if the reading process is ignoring or 190blocking the 191.Dv SIGTTIN 192signal, or if the process group of the reading 193process is orphaned, the 194.Xr read 2 195returns -1 with 196.Va errno 197set to 198.Er EIO 199and no 200signal is sent. 201The default action of the 202.Dv SIGTTIN 203signal is to stop the 204process to which it is sent. 205.Pp 206If a process is in the foreground process group of its controlling 207terminal, write operations are allowed. 208Attempts by a process in a background process group to write to its 209controlling terminal will cause the process group to be sent a 210.Dv SIGTTOU 211signal unless one of the following special cases apply: if 212.Dv TOSTOP 213is not 214set, or if 215.Dv TOSTOP 216is set and the process is ignoring or blocking the 217.Dv SIGTTOU 218signal, the process is allowed to write to the terminal and the 219.Dv SIGTTOU 220signal is not sent. 221If 222.Dv TOSTOP 223is set, and the process group of 224the writing process is orphaned, and the writing process is not ignoring 225or blocking 226.Dv SIGTTOU , 227the 228.Xr write 2 229returns -1 with 230errno set to 231.Er EIO 232and no signal is sent. 233.Pp 234Certain calls that set terminal parameters are treated in the same 235fashion as write, except that 236.Dv TOSTOP 237is ignored; that is, the effect is 238identical to that of terminal writes when 239.Dv TOSTOP 240is set. 241.Ss Input Processing and Reading Data 242A terminal device associated with a terminal device file may operate in 243full-duplex mode, so that data may arrive even while output is occurring. 244Each terminal device file has associated with it an input queue, into 245which incoming data is stored by the system before being read by a 246process. 247The system imposes a limit, 248.Pf \&{ Dv MAX_INPUT Ns \&} , 249on the number of 250bytes that may be stored in the input queue. 251The behavior of the system 252when this limit is exceeded depends on the setting of the 253.Dv IMAXBEL 254flag in the termios 255.Fa c_iflag . 256If this flag is set, the terminal 257is sent an 258.Tn ASCII 259.Dv BEL 260character each time a character is received 261while the input queue is full. 262Otherwise, the input queue is flushed upon receiving the character. 263.Pp 264Two general kinds of input processing are available, determined by 265whether the terminal device file is in canonical mode or noncanonical 266mode. 267Additionally, 268input characters are processed according to the 269.Fa c_iflag 270and 271.Fa c_lflag 272fields. 273Such processing can include echoing, which 274in general means transmitting input characters immediately back to the 275terminal when they are received from the terminal. 276This is useful for terminals that can operate in full-duplex mode. 277.Pp 278The manner in which data is provided to a process reading from a terminal 279device file is dependent on whether the terminal device file is in 280canonical or noncanonical mode. 281.Pp 282Another dependency is whether the 283.Dv O_NONBLOCK 284flag is set by 285.Xr open 2 286or 287.Xr fcntl 2 . 288If the 289.Dv O_NONBLOCK 290flag is clear, then the read request is 291blocked until data is available or a signal has been received. 292If the 293.Dv O_NONBLOCK 294flag is set, then the read request is completed, without 295blocking, in one of three ways: 296.Bl -enum -offset indent 297.It 298If there is enough data available to satisfy the entire request, 299and the read completes successfully the number of 300bytes read is returned. 301.It 302If there is not enough data available to satisfy the entire 303request, and the read completes successfully, having read as 304much data as possible, the number of bytes read is returned. 305.It 306If there is no data available, the read returns -1, with 307errno set to 308.Er EAGAIN . 309.El 310.Pp 311When data is available depends on whether the input processing mode is 312canonical or noncanonical. 313.Ss Canonical Mode Input Processing 314In canonical mode input processing, terminal input is processed in units 315of lines. 316A line is delimited by a newline 317.Ql \&\en 318character, an end-of-file 319.Pq Dv EOF 320character, or an end-of-line 321.Pq Dv EOL 322character. 323See the 324.Sx "Special Characters" 325section for 326more information on 327.Dv EOF 328and 329.Dv EOL . 330This means that a read request will 331not return until an entire line has been typed, or a signal has been 332received. 333Also, no matter how many bytes are requested in the read call, 334at most one line is returned. 335It is not, however, necessary to 336read a whole line at once; any number of bytes, even one, may be 337requested in a read without losing information. 338.Pp 339.Pf \&{ Dv MAX_CANON Ns \&} 340is a limit on the 341number of bytes in a line. 342The behavior of the system when this limit is 343exceeded is the same as when the input queue limit 344.Pf \&{ Dv MAX_INPUT Ns \&} , 345is exceeded. 346.Pp 347Erase and kill processing occur when either of two special characters, 348the 349.Dv ERASE 350and 351.Dv KILL 352characters (see the 353.Sx "Special Characters" 354section), is received. 355This processing affects data in the input queue that has not yet been 356delimited by a newline 357.Dv NL , 358.Dv EOF , 359or 360.Dv EOL 361character. 362This un-delimited 363data makes up the current line. 364The 365.Dv ERASE 366character deletes the last 367character in the current line, if there is any. 368The 369.Dv KILL 370character 371deletes all data in the current line, if there is any. 372The 373.Dv ERASE 374and 375.Dv KILL 376characters have no effect if there is no data in the current line. 377The 378.Dv ERASE 379and 380.Dv KILL 381characters themselves are not placed in the input 382queue. 383.Ss Noncanonical Mode Input Processing 384In noncanonical mode input processing, input bytes are not assembled into 385lines, and erase and kill processing does not occur. 386The values of the 387.Dv VMIN 388and 389.Dv VTIME 390members of the 391.Fa c_cc 392array are used to determine how to 393process the bytes received. 394.Pp 395.Dv MIN 396represents the minimum number of bytes that should be received when 397the 398.Xr read 2 399function successfully returns. 400.Dv TIME 401is a timer of 0.1 second 402granularity that is used to time out bursty and short term data 403transmissions. 404If 405.Dv MIN 406is greater than 407.Dv \&{ Dv MAX_INPUT Ns \&} , 408the response to the 409request is undefined. 410The four possible values for 411.Dv MIN 412and 413.Dv TIME 414and 415their interactions are described below. 416.Ss "Case A: MIN > 0, TIME > 0" 417In this case 418.Dv TIME 419serves as an inter-byte timer and is activated after 420the first byte is received. 421Since it is an inter-byte timer, it is reset 422after a byte is received. 423The interaction between 424.Dv MIN 425and 426.Dv TIME 427is as 428follows: as soon as one byte is received, the inter-byte timer is 429started. 430If 431.Dv MIN 432bytes are received before the inter-byte timer expires 433(remember that the timer is reset upon receipt of each byte), the read is 434satisfied. 435If the timer expires before 436.Dv MIN 437bytes are received, the 438characters received to that point are returned to the user. 439Note that if 440.Dv TIME 441expires at least one byte is returned because the timer would 442not have been enabled unless a byte was received. 443In this case 444.Pf \&( Dv MIN 445> 0, 446.Dv TIME 447> 0) the read blocks until the 448.Dv MIN 449and 450.Dv TIME 451mechanisms are 452activated by the receipt of the first byte, or a signal is received. 453If data is in the buffer at the time of the 454.Fn read , 455the result is as 456if data had been received immediately after the 457.Fn read . 458.Ss "Case B: MIN > 0, TIME = 0" 459In this case, since the value of 460.Dv TIME 461is zero, the timer plays no role 462and only 463.Dv MIN 464is significant. 465A pending read is not satisfied until 466.Dv MIN 467bytes are received (i.e., the pending read blocks until 468.Dv MIN 469bytes 470are received), or a signal is received. 471A program that uses this case to read record-based terminal 472.Dv I/O 473may block indefinitely in the read 474operation. 475.Ss "Case C: MIN = 0, TIME > 0" 476In this case, since 477.Dv MIN 478= 0, 479.Dv TIME 480no longer represents an inter-byte 481timer. 482It now serves as a read timer that is activated as soon as the 483read function is processed. 484A read is satisfied as soon as a single 485byte is received or the read timer expires. 486Note that in this case if the timer expires, no bytes are returned. 487If the timer does not 488expire, the only way the read can be satisfied is if a byte is received. 489In this case the read will not block indefinitely waiting for a byte; if 490no byte is received within 491.Dv TIME Ns *0.1 492seconds after the read is initiated, 493the read returns a value of zero, having read no data. 494If data is 495in the buffer at the time of the read, the timer is started as if 496data had been received immediately after the read. 497.Ss Case D: MIN = 0, TIME = 0 498The minimum of either the number of bytes requested or the number of 499bytes currently available is returned without waiting for more 500bytes to be input. 501If no characters are available, read returns a 502value of zero, having read no data. 503.Ss Writing Data and Output Processing 504When a process writes one or more bytes to a terminal device file, they 505are processed according to the 506.Fa c_oflag 507field (see the 508.Sx "Output Modes" 509section). 510The 511implementation may provide a buffering mechanism; as such, when a call to 512.Fn write 513completes, all of the bytes written have been scheduled for 514transmission to the device, but the transmission will not necessarily 515have been completed. 516.\" See also .Sx "6.4.2" for the effects of 517.\" .Dv O_NONBLOCK 518.\" on write. 519.Ss Special Characters 520Certain characters have special functions on input or output or both. 521These functions are summarized as follows: 522.Bl -tag -width indent 523.It Dv INTR 524Special character on input and is recognized if the 525.Dv ISIG 526flag (see the 527.Sx "Local Modes" 528section) is enabled. 529Generates a 530.Dv SIGINT 531signal which is sent to all processes in the foreground 532process group for which the terminal is the controlling 533terminal. 534If 535.Dv ISIG 536is set, the 537.Dv INTR 538character is 539discarded when processed. 540.It Dv QUIT 541Special character on input and is recognized if the 542.Dv ISIG 543flag is enabled. 544Generates a 545.Dv SIGQUIT 546signal which is 547sent to all processes in the foreground process group 548for which the terminal is the controlling terminal. 549If 550.Dv ISIG 551is set, the 552.Dv QUIT 553character is discarded when 554processed. 555.It Dv ERASE 556Special character on input and is recognized if the 557.Dv ICANON 558flag is set. 559Erases the last character in the 560current line; see 561.Sx "Canonical Mode Input Processing" . 562It does not erase beyond 563the start of a line, as delimited by an 564.Dv NL , 565.Dv EOF , 566or 567.Dv EOL 568character. 569If 570.Dv ICANON 571is set, the 572.Dv ERASE 573character is 574discarded when processed. 575.It Dv KILL 576Special character on input and is recognized if the 577.Dv ICANON 578flag is set. 579Deletes the entire line, as 580delimited by a 581.Dv NL , 582.Dv EOF , 583or 584.Dv EOL 585character. 586If 587.Dv ICANON 588is set, the 589.Dv KILL 590character is discarded when processed. 591.It Dv EOF 592Special character on input and is recognized if the 593.Dv ICANON 594flag is set. 595When received, all the bytes 596waiting to be read are immediately passed to the 597process, without waiting for a newline, and the 598.Dv EOF 599is discarded. 600Thus, if there are no bytes waiting (that is, the 601.Dv EOF 602occurred at the beginning of a line), a byte 603count of zero is returned from the 604.Fn read , 605representing an end-of-file indication. 606If 607.Dv ICANON 608is 609set, the 610.Dv EOF 611character is discarded when processed. 612.It Dv NL 613Special character on input and is recognized if the 614.Dv ICANON 615flag is set. 616It is the line delimiter 617.Ql \&\en . 618.It Dv EOL 619Special character on input and is recognized if the 620.Dv ICANON 621flag is set. 622Is an additional line delimiter, like 623.Dv NL . 624.It Dv SUSP 625If the 626.Dv ISIG 627flag is enabled, receipt of the 628.Dv SUSP 629character causes a 630.Dv SIGTSTP 631signal to be sent to all processes in the 632foreground process group for which the terminal is the 633controlling terminal, and the 634.Dv SUSP 635character is 636discarded when processed. 637.It Dv STOP 638Special character on both input and output and is 639recognized if the 640.Dv IXON 641(output control) or 642.Dv IXOFF 643(input 644control) flag is set. 645Can be used to temporarily suspend output. 646It is useful with fast terminals to 647prevent output from disappearing before it can be read. 648If 649.Dv IXON 650is set, the 651.Dv STOP 652character is discarded when 653processed. 654.It Dv START 655Special character on both input and output and is 656recognized if the 657.Dv IXON 658(output control) or 659.Dv IXOFF 660(input 661control) flag is set. 662Can be used to resume output that has been suspended by a 663.Dv STOP 664character. 665If 666.Dv IXON 667is set, the 668.Dv START 669character is discarded when processed. 670.It Dv CR 671Special character on input and is recognized if the 672.Dv ICANON 673flag is set; it is the 674.Ql \&\er , 675as denoted in the 676.Tn \&C 677Standard {2}. 678When 679.Dv ICANON 680and 681.Dv ICRNL 682are set and 683.Dv IGNCR 684is not set, this character is translated into a 685.Dv NL , 686and 687has the same effect as a 688.Dv NL 689character. 690.El 691.Pp 692The following special characters are extensions defined by this 693system and are not a part of 694.St -p1003.1 695termios. 696.Bl -tag -width indent 697.It Dv EOL2 698Secondary 699.Dv EOL 700character. 701Same function as 702.Dv EOL . 703.It Dv WERASE 704Special character on input and is recognized if the 705.Dv ICANON 706flag is set. 707Erases the last word in the current line according to one of two algorithms. 708If the 709.Dv ALTWERASE 710flag is not set, first any preceding whitespace is 711erased, and then the maximal sequence of non-whitespace 712characters. 713If 714.Dv ALTWERASE 715is set, first any preceding 716whitespace is erased, and then the maximal sequence 717of alphabetic/underscores or non alphabetic/underscores. 718As a special case in this second algorithm, the first previous 719non-whitespace character is skipped in determining 720whether the preceding word is a sequence of 721alphabetic/underscores. 722This sounds confusing but turns out to be quite practical. 723.It Dv REPRINT 724Special character on input and is recognized if the 725.Dv ICANON 726flag is set. 727Causes the current input edit line to be retyped. 728.It Dv DSUSP 729Has similar actions to the 730.Dv SUSP 731character, except that 732the 733.Dv SIGTSTP 734signal is delivered when one of the processes 735in the foreground process group issues a 736.Fn read 737to the 738controlling terminal. 739.It Dv LNEXT 740Special character on input and is recognized if the 741.Dv IEXTEN 742flag is set. 743Receipt of this character causes the next character to be taken literally. 744.It Dv DISCARD 745Special character on input and is recognized if the 746.Dv IEXTEN 747flag is set. 748Receipt of this character toggles the flushing of terminal output. 749.It Dv STATUS 750Special character on input and is recognized if the 751.Dv ICANON 752flag is set. 753Receipt of this character causes a 754.Dv SIGINFO 755signal to be sent to the foreground process group of the 756terminal. 757Also, if the 758.Dv NOKERNINFO 759flag is not set, it 760causes the kernel to write a status message to the terminal 761that displays the current load average, the name of the 762command in the foreground, its process ID, the symbolic 763wait channel, the number of user and system seconds used, 764the percentage of cpu the process is getting, and the resident 765set size of the process. 766.El 767.Pp 768The 769.Dv NL 770and 771.Dv CR 772characters cannot be changed. 773The values for all the remaining characters can be set and are 774described later in the document under 775Special Control Characters. 776.Pp 777Special 778character functions associated with changeable special control characters 779can be disabled individually by setting their value to 780.Dv {_POSIX_VDISABLE} ; 781see 782.Sx "Special Control Characters" . 783.Pp 784If two or more special characters have the same value, the function 785performed when that character is received is undefined. 786.Ss Modem Disconnect 787If a modem disconnect is detected by the terminal interface for a 788controlling terminal, and if 789.Dv CLOCAL 790is not set in the 791.Fa c_cflag 792field for 793the terminal, the 794.Dv SIGHUP 795signal is sent to the controlling 796process associated with the terminal. 797Unless other arrangements have 798been made, this causes the controlling process to terminate. 799Any subsequent call to the 800.Fn read 801function returns the value zero, 802indicating end of file. 803Thus, processes that read a terminal 804file and test for end-of-file can terminate appropriately after a 805disconnect. 806.\" If the 807.\" .Er EIO 808.\" condition specified in 6.1.1.4 that applies 809.\" when the implementation supports job control also exists, it is 810.\" unspecified whether the 811.\" .Dv EOF 812.\" condition or the 813.\" .Pf [ Dv EIO 814.\" ] is returned. 815Any 816subsequent 817.Fn write 818to the terminal device returns -1, with 819.Va errno 820set to 821.Er EIO , 822until the device is closed. 823.Sh General Terminal Interface 824.Ss Closing a Terminal Device File 825The last process to close a terminal device file causes any output 826to be sent to the device and any input to be discarded. 827Then, if 828.Dv HUPCL 829is set in the control modes, and the communications port supports a 830disconnect function, the terminal device performs a disconnect. 831.Ss Parameters That Can Be Set 832Routines that need to control certain terminal 833.Tn I/O 834characteristics 835do so by using the termios structure as defined in the header 836.In termios.h . 837This structure contains minimally four scalar elements of bit flags 838and one array of special characters. 839The scalar flag elements are named: 840.Fa c_iflag , 841.Fa c_oflag , 842.Fa c_cflag , 843and 844.Fa c_lflag . 845The character array is named 846.Fa c_cc , 847and its maximum index is 848.Dv NCCS . 849.Ss Input Modes 850Values of the 851.Fa c_iflag 852field describe the basic 853terminal input control, and are composed of 854following masks: 855.Pp 856.Bl -tag -width IMAXBEL -offset indent -compact 857.It Dv IGNBRK 858/* ignore BREAK condition */ 859.It Dv BRKINT 860/* map BREAK to SIGINTR */ 861.It Dv IGNPAR 862/* ignore (discard) parity errors */ 863.It Dv PARMRK 864/* mark parity and framing errors */ 865.It Dv INPCK 866/* enable checking of parity errors */ 867.It Dv ISTRIP 868/* strip 8th bit off chars */ 869.It Dv INLCR 870/* map NL into CR */ 871.It Dv IGNCR 872/* ignore CR */ 873.It Dv ICRNL 874/* map CR to NL (ala CRMOD) */ 875.It Dv IXON 876/* enable output flow control */ 877.It Dv IXOFF 878/* enable input flow control */ 879.It Dv IXANY 880/* any char will restart after stop */ 881.It Dv IMAXBEL 882/* ring bell on input queue full */ 883.El 884.Pp 885In the context of asynchronous serial data transmission, a break 886condition is defined as a sequence of zero-valued bits that continues for 887more than the time to send one byte. 888The entire sequence of zero-valued 889bits is interpreted as a single break condition, even if it continues for 890a time equivalent to more than one byte. 891In contexts other than 892asynchronous serial data transmission the definition of a break condition 893is implementation defined. 894.Pp 895If 896.Dv IGNBRK 897is set, a break condition detected on input is ignored, that 898is, not put on the input queue and therefore not read by any process. 899If 900.Dv IGNBRK 901is not set and 902.Dv BRKINT 903is set, the break condition flushes the 904input and output queues and if the terminal is the controlling terminal 905of a foreground process group, the break condition generates a 906single 907.Dv SIGINT 908signal to that foreground process group. 909If neither 910.Dv IGNBRK 911nor 912.Dv BRKINT 913is set, a break condition is read as a single 914.Ql \&\e0 , 915or if 916.Dv PARMRK 917is set, as 918.Ql \&\e377 , 919.Ql \&\e0 , 920.Ql \&\e0 . 921.Pp 922If 923.Dv IGNPAR 924is set, a byte with a framing or parity error (other than 925break) is ignored. 926.Pp 927If 928.Dv PARMRK 929is set, and 930.Dv IGNPAR 931is not set, a byte with a framing or parity 932error (other than break) is given to the application as the 933three-character sequence 934.Ql \&\e377 , 935.Ql \&\e0 , 936X, where 937.Ql \&\e377 , 938.Ql \&\e0 939is a two-character 940flag preceding each sequence and X is the data of the character received 941in error. 942To avoid ambiguity in this case, if 943.Dv ISTRIP 944is not set, a valid 945character of 946.Ql \&\e377 947is given to the application as 948.Ql \&\e377 , 949.Ql \&\e377 . 950If 951neither 952.Dv PARMRK 953nor 954.Dv IGNPAR 955is set, a framing or parity error (other than 956break) is given to the application as a single character 957.Ql \&\e0 . 958.Pp 959If 960.Dv INPCK 961is set, input parity checking is enabled. 962If 963.Dv INPCK 964is not set, 965input parity checking is disabled, allowing output parity generation 966without input parity errors. 967Note that whether input parity checking is 968enabled or disabled is independent of whether parity detection is enabled 969or disabled (see 970.Sx "Control Modes" ) . 971If parity detection is enabled but input 972parity checking is disabled, the hardware to which the terminal is 973connected recognizes the parity bit, but the terminal special file 974does not check whether this bit is set correctly or not. 975.Pp 976If 977.Dv ISTRIP 978is set, valid input bytes are first stripped to seven bits, 979otherwise all eight bits are processed. 980.Pp 981If 982.Dv INLCR 983is set, a received 984.Dv NL 985character is translated into a 986.Dv CR 987character. 988If 989.Dv IGNCR 990is set, a received 991.Dv CR 992character is ignored (not 993read). 994If 995.Dv IGNCR 996is not set and 997.Dv ICRNL 998is set, a received 999.Dv CR 1000character is 1001translated into a 1002.Dv NL 1003character. 1004.Pp 1005If 1006.Dv IXON 1007is set, start/stop output control is enabled. 1008A received 1009.Dv STOP 1010character suspends output and a received 1011.Dv START 1012character 1013restarts output. 1014If 1015.Dv IXANY 1016is also set, then any character may 1017restart output. 1018When 1019.Dv IXON 1020is set, 1021.Dv START 1022and 1023.Dv STOP 1024characters are not 1025read, but merely perform flow control functions. 1026When 1027.Dv IXON 1028is not set, 1029the 1030.Dv START 1031and 1032.Dv STOP 1033characters are read. 1034.Pp 1035If 1036.Dv IXOFF 1037is set, start/stop input control is enabled. 1038The system shall transmit one or more 1039.Dv STOP 1040characters, which are intended to cause the 1041terminal device to stop transmitting data, as needed to prevent the input 1042queue from overflowing and causing the undefined behavior described in 1043.Sx "Input Processing and Reading Data" , 1044and shall transmit one or more 1045.Dv START 1046characters, which are 1047intended to cause the terminal device to resume transmitting data, as 1048soon as the device can continue transmitting data without risk of 1049overflowing the input queue. 1050The precise conditions under which 1051.Dv STOP 1052and 1053.Dv START 1054characters are transmitted are implementation defined. 1055.Pp 1056If 1057.Dv IMAXBEL 1058is set and the input queue is full, subsequent input shall cause an 1059.Tn ASCII 1060.Dv BEL 1061character to be transmitted to 1062the output queue. 1063.Pp 1064The initial input control value after 1065.Fn open 1066is implementation defined. 1067.Ss Output Modes 1068Values of the 1069.Fa c_oflag 1070field describe the basic terminal output control, 1071and are composed of the following masks: 1072.Pp 1073.Bl -tag -width ONOEOT -offset indent -compact 1074.It Dv OPOST 1075/* enable following output processing */ 1076.It Dv ONLCR 1077/* map NL to CR-NL (ala 1078.Dv CRMOD ) 1079*/ 1080.It Dv OCRNL 1081/* map CR to NL */ 1082.It Dv TABDLY 1083/* tab delay mask */ 1084.It Dv TAB0 1085/* no tab delay and expansion */ 1086.It Dv TAB3 1087/* expand tabs to spaces */ 1088.It Dv ONOEOT 1089/* discard 1090.Dv EOT Ns 's 1091.Ql \&^D 1092on output) */ 1093.It Dv ONOCR 1094/* do not transmit CRs on column 0 */ 1095.It Dv ONLRET 1096/* on the terminal NL performs the CR function */ 1097.El 1098.Pp 1099If 1100.Dv OPOST 1101is set, the remaining flag masks are interpreted as follows; 1102otherwise characters are transmitted without change. 1103.Pp 1104If 1105.Dv ONLCR 1106is set, newlines are translated to carriage return, linefeeds. 1107.Pp 1108If 1109.Dv OCRNL 1110is set, carriage returns are translated to newlines. 1111.Pp 1112The 1113.Dv TABDLY 1114bits specify the tab delay. 1115The 1116.Fa c_oflag 1117is masked with 1118.Dv TABDLY 1119and compared with the 1120values 1121.Dv TAB0 1122or 1123.Dv TAB3 . 1124If 1125.Dv TAB3 1126is set, tabs are expanded to the appropriate number of 1127spaces (assuming 8 column tab stops). 1128.Pp 1129If 1130.Dv ONOEOT 1131is set, 1132.Tn ASCII 1133.Dv EOT Ns 's 1134are discarded on output. 1135.Pp 1136If 1137.Dv ONOCR 1138is set, no CR character is transmitted when at column 0 (first position). 1139.Pp 1140If 1141.Dv ONLRET 1142is set, the NL character is assumed to do the carriage-return function; 1143the column pointer will be set to 0. 1144.Ss Control Modes 1145Values of the 1146.Fa c_cflag 1147field describe the basic 1148terminal hardware control, and are composed of the 1149following masks. 1150Not all values 1151specified are supported by all hardware. 1152.Pp 1153.Bl -tag -width CRTSXIFLOW -offset indent -compact 1154.It Dv CSIZE 1155/* character size mask */ 1156.It Dv CS5 1157/* 5 bits (pseudo) */ 1158.It Dv CS6 1159/* 6 bits */ 1160.It Dv CS7 1161/* 7 bits */ 1162.It Dv CS8 1163/* 8 bits */ 1164.It Dv CSTOPB 1165/* send 2 stop bits */ 1166.It Dv CREAD 1167/* enable receiver */ 1168.It Dv PARENB 1169/* parity enable */ 1170.It Dv PARODD 1171/* odd parity, else even */ 1172.It Dv HUPCL 1173/* hang up on last close */ 1174.It Dv CLOCAL 1175/* ignore modem status lines */ 1176.It Dv CCTS_OFLOW 1177/* 1178.Dv CTS 1179flow control of output */ 1180.It Dv CRTSCTS 1181/* same as 1182.Dv CCTS_OFLOW 1183*/ 1184.It Dv CRTS_IFLOW 1185/* RTS flow control of input */ 1186.It Dv MDMBUF 1187/* flow control output via Carrier */ 1188.It Dv CNO_RTSDTR 1189/* Do not assert RTS or DTR automatically */ 1190.El 1191.Pp 1192The 1193.Dv CSIZE 1194bits specify the byte size in bits for both transmission and 1195reception. 1196The 1197.Fa c_cflag 1198is masked with 1199.Dv CSIZE 1200and compared with the 1201values 1202.Dv CS5 , 1203.Dv CS6 , 1204.Dv CS7 , 1205or 1206.Dv CS8 . 1207This size does not include the parity bit, if any. 1208If 1209.Dv CSTOPB 1210is set, two stop bits are used, otherwise one stop bit. 1211For example, at 110 baud, two stop bits are normally used. 1212.Pp 1213If 1214.Dv CREAD 1215is set, the receiver is enabled. 1216Otherwise, no character is received. 1217Not all hardware supports this bit. 1218In fact, this flag is pretty silly and if it were not part of the 1219.Nm 1220specification 1221it would be omitted. 1222.Pp 1223If 1224.Dv PARENB 1225is set, parity generation and detection are enabled and a parity 1226bit is added to each character. 1227If parity is enabled, 1228.Dv PARODD 1229specifies 1230odd parity if set, otherwise even parity is used. 1231.Pp 1232If 1233.Dv HUPCL 1234is set, the modem control lines for the port are lowered 1235when the last process with the port open closes the port or the process 1236terminates. 1237The modem connection is broken. 1238.Pp 1239If 1240.Dv CLOCAL 1241is set, a connection does not depend on the state of the modem 1242status lines. 1243If 1244.Dv CLOCAL 1245is clear, the modem status lines are 1246monitored. 1247.Pp 1248Under normal circumstances, a call to the 1249.Fn open 1250function waits for 1251the modem connection to complete. 1252However, if the 1253.Dv O_NONBLOCK 1254flag is set 1255or if 1256.Dv CLOCAL 1257has been set, the 1258.Fn open 1259function returns 1260immediately without waiting for the connection. 1261.Pp 1262The 1263.Dv CCTS_OFLOW 1264.Pf ( Dv CRTSCTS ) 1265flag is currently unused. 1266.Pp 1267If 1268.Dv MDMBUF 1269is set then output flow control is controlled by the state 1270of Carrier Detect. 1271.Pp 1272If 1273.Dv CNO_RTSDTR 1274is set then the RTS and DTR lines will not be asserted when the device 1275is opened. 1276As a result, this flag is only useful on initial-state devices. 1277.Pp 1278If the object for which the control modes are set is not an asynchronous 1279serial connection, some of the modes may be ignored; for example, if an 1280attempt is made to set the baud rate on a network connection to a 1281terminal on another host, the baud rate may or may not be set on the 1282connection between that terminal and the machine it is directly connected 1283to. 1284.Ss Local Modes 1285Values of the 1286.Fa c_lflag 1287field describe the control of 1288various functions, and are composed of the following 1289masks. 1290.Pp 1291.Bl -tag -width NOKERNINFO -offset indent -compact 1292.It Dv ECHOKE 1293/* visual erase for line kill */ 1294.It Dv ECHOE 1295/* visually erase chars */ 1296.It Dv ECHO 1297/* enable echoing */ 1298.It Dv ECHONL 1299/* echo 1300.Dv NL 1301even if 1302.Dv ECHO 1303is off */ 1304.It Dv ECHOPRT 1305/* visual erase mode for hardcopy */ 1306.It Dv ECHOCTL 1307/* echo control chars as ^(Char) */ 1308.It Dv ISIG 1309/* enable signals 1310.Dv INTR , 1311.Dv QUIT , 1312.Dv [D]SUSP 1313*/ 1314.It Dv ICANON 1315/* canonicalize input lines */ 1316.It Dv ALTWERASE 1317/* use alternate 1318.Dv WERASE 1319algorithm */ 1320.It Dv IEXTEN 1321/* enable 1322.Dv DISCARD 1323and 1324.Dv LNEXT 1325*/ 1326.It Dv EXTPROC 1327/* external processing */ 1328.It Dv TOSTOP 1329/* stop background jobs from output */ 1330.It Dv FLUSHO 1331/* output being flushed (state) */ 1332.It Dv NOKERNINFO 1333/* no kernel output from 1334.Dv VSTATUS 1335*/ 1336.It Dv PENDIN 1337/* XXX retype pending input (state) */ 1338.It Dv NOFLSH 1339/* don't flush after interrupt */ 1340.El 1341.Pp 1342If 1343.Dv ECHO 1344is set, input characters are echoed back to the terminal. 1345If 1346.Dv ECHO 1347is not set, input characters are not echoed. 1348.Pp 1349If 1350.Dv ECHOE 1351and 1352.Dv ICANON 1353are set, the 1354.Dv ERASE 1355character causes the terminal 1356to erase the last character in the current line from the display, if 1357possible. 1358If there is no character to erase, an implementation may echo 1359an indication that this was the case or do nothing. 1360.Pp 1361If 1362.Dv ECHOK 1363and 1364.Dv ICANON 1365are set, the 1366.Dv KILL 1367character causes 1368the current line to be discarded and the system echoes the 1369.Ql \&\en 1370character after the 1371.Dv KILL 1372character. 1373.Pp 1374If 1375.Dv ECHOKE 1376and 1377.Dv ICANON 1378are set, the 1379.Dv KILL 1380character causes 1381the current line to be discarded and the system causes 1382the terminal 1383to erase the line from the display. 1384.Pp 1385If 1386.Dv ECHOPRT 1387and 1388.Dv ICANON 1389are set, the system assumes 1390that the display is a printing device and prints a 1391backslash and the erased characters when processing 1392.Dv ERASE 1393characters, followed by a forward slash. 1394.Pp 1395If 1396.Dv ECHOCTL 1397is set, the system echoes control characters 1398in a visible fashion using a caret followed by the control character. 1399.Pp 1400If 1401.Dv ALTWERASE 1402is set, the system uses an alternative algorithm 1403for determining what constitutes a word when processing 1404.Dv WERASE 1405characters (see 1406.Dv WERASE ) . 1407.Pp 1408If 1409.Dv ECHONL 1410and 1411.Dv ICANON 1412are set, the 1413.Ql \&\en 1414character echoes even if 1415.Dv ECHO 1416is not set. 1417.Pp 1418If 1419.Dv ICANON 1420is set, canonical processing is enabled. 1421This enables the 1422erase and kill edit functions, and the assembly of input characters into 1423lines delimited by 1424.Dv NL , 1425.Dv EOF , 1426and 1427.Dv EOL , 1428as described in 1429.Sx "Canonical Mode Input Processing" . 1430.Pp 1431If 1432.Dv ICANON 1433is not set, read requests are satisfied directly from the input 1434queue. 1435A read is not satisfied until at least 1436.Dv MIN 1437bytes have been 1438received or the timeout value 1439.Dv TIME 1440expired between bytes. 1441The time value 1442represents tenths of seconds. 1443See 1444.Sx "Noncanonical Mode Input Processing" 1445for more details. 1446.Pp 1447If 1448.Dv ISIG 1449is set, each input character is checked against the special 1450control characters 1451.Dv INTR , 1452.Dv QUIT , 1453and 1454.Dv SUSP 1455(job control only). 1456If an input 1457character matches one of these control characters, the function 1458associated with that character is performed. 1459If 1460.Dv ISIG 1461is not set, no 1462checking is done. 1463Thus these special input functions are possible only 1464if 1465.Dv ISIG 1466is set. 1467.Pp 1468If 1469.Dv IEXTEN 1470is set, implementation-defined functions are recognized 1471from the input data. 1472How 1473.Dv IEXTEN 1474being set 1475interacts with 1476.Dv ICANON , 1477.Dv ISIG , 1478.Dv IXON , 1479or 1480.Dv IXOFF 1481is implementation defined. 1482If 1483.Dv IEXTEN 1484is not set, then 1485implementation-defined functions are not recognized, and the 1486corresponding input characters are not processed as described for 1487.Dv ICANON , 1488.Dv ISIG , 1489.Dv IXON , 1490and 1491.Dv IXOFF . 1492.Pp 1493If 1494.Dv NOFLSH 1495is set, the normal flush of the input and output queues 1496associated with the 1497.Dv INTR , 1498.Dv QUIT , 1499and 1500.Dv SUSP 1501characters 1502are not be done. 1503.Pp 1504If 1505.Dv TOSTOP 1506is set, the signal 1507.Dv SIGTTOU 1508is sent to the process group of a process that tries to write to 1509its controlling terminal if it is not in the foreground process group for 1510that terminal. 1511This signal, by default, stops the members of the process group. 1512Otherwise, the output generated by that process is output to the 1513current output stream. 1514Processes that are blocking or ignoring 1515.Dv SIGTTOU 1516signals are excepted and allowed to produce output and the 1517.Dv SIGTTOU 1518signal 1519is not sent. 1520.Pp 1521If 1522.Dv NOKERNINFO 1523is set, the kernel does not produce a status message 1524when processing 1525.Dv STATUS 1526characters (see 1527.Dv STATUS ) . 1528.Ss Special Control Characters 1529The special control characters values are defined by the array 1530.Fa c_cc . 1531This table lists the array index, the corresponding special character, 1532and the system default value. 1533For an accurate list of 1534the system defaults, consult the header file 1535.In sys/ttydefaults.h . 1536.Pp 1537.Bl -column "Index Name" "Special Character" -offset indent -compact 1538.It Em "Index Name Special Character Default Value" 1539.It Dv VEOF Ta EOF Ta \&^D 1540.It Dv VEOL Ta EOL Ta _POSIX_VDISABLE 1541.It Dv VEOL2 Ta EOL2 Ta _POSIX_VDISABLE 1542.It Dv VERASE Ta ERASE Ta \&^? Ql \&\e177 1543.It Dv VWERASE Ta WERASE Ta \&^W 1544.It Dv VKILL Ta KILL Ta \&^U 1545.It Dv VREPRINT Ta REPRINT Ta \&^R 1546.It Dv VINTR Ta INTR Ta \&^C 1547.It Dv VQUIT Ta QUIT Ta \&^\e\e Ql \&\e34 1548.It Dv VSUSP Ta SUSP Ta \&^Z 1549.It Dv VDSUSP Ta DSUSP Ta \&^Y 1550.It Dv VSTART Ta START Ta \&^Q 1551.It Dv VSTOP Ta STOP Ta \&^S 1552.It Dv VLNEXT Ta LNEXT Ta \&^V 1553.It Dv VDISCARD Ta DISCARD Ta \&^O 1554.It Dv VMIN Ta --- Ta \&1 1555.It Dv VTIME Ta --- Ta \&0 1556.It Dv VSTATUS Ta STATUS Ta \&^T 1557.El 1558.Pp 1559If the 1560value of one of the changeable special control characters (see 1561.Sx "Special Characters" ) 1562is 1563.Dv {_POSIX_VDISABLE} , 1564that function is disabled; that is, no input 1565data is recognized as the disabled special character. 1566If 1567.Dv ICANON 1568is 1569not set, the value of 1570.Dv {_POSIX_VDISABLE} 1571has no special meaning for the 1572.Dv VMIN 1573and 1574.Dv VTIME 1575entries of the 1576.Fa c_cc 1577array. 1578.Pp 1579The initial values of the flags and control characters 1580after 1581.Fn open 1582is set according to 1583the values in the header 1584.In sys/ttydefaults.h . 1585.Sh SEE ALSO 1586.Xr stty 1 , 1587.Xr tcgetsid 3 , 1588.Xr tcsendbreak 3 , 1589.Xr tcsetattr 3 , 1590.Xr tcsetsid 3 , 1591.Xr tty 4 1592