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