| PTY(4) | Device Drivers Manual | PTY(4) |
pty, ptm —
pseudo terminal driver
pseudo-device pty
[count]
The pty driver provides support for a
device-pair termed a
pseudo
terminal. A pseudo terminal is a pair of character devices, a
master
device and a
slave
device. The slave device provides to a process an interface identical to
that described in tty(4). However, whereas all other
devices which provide the interface described in tty(4)
have a hardware device of some sort behind them, the slave device has,
instead, another process manipulating it through the master half of the
pseudo terminal. That is, anything written on the master device is given to
the slave device as input and anything written on the slave device is
presented as input on the master device.
In configuring, if an optional count is given in the specification, space for that number of pseudo terminal pairs is preallocated. If the count is missing or is less than 2, a default count of 8 is used. This is not a hard limit--space for additional pseudo terminal pairs is allocated on demand up to the limit of 992.
The following ioctl(2) calls apply only to
pseudo terminals and may only be applied to the pty
master:
TIOCEXT
int *onWhile external processing is enabled, input line editing, character echo, and mapping of control characters to signals are disabled regardless of the terminal's termios(4) settings.
TIOCSTOP
void^S’).TIOCSTART
voidTIOCSTOP or by typing
‘^S’).TIOCPKT
int *onWhile packet mode is enabled, each subsequent
read(2) from the pty master
will either return data written to the pty slave
preceded by a zero byte (symbolically defined as
TIOCPKT_DATA), or a single byte reflecting
control status information. In the latter case, the byte is an
inclusive-or of zero or more of the bits:
TIOCPKT_FLUSHREADTIOCPKT_FLUSHWRITETIOCPKT_STOP^S’.TIOCPKT_STARTTIOCPKT_DOSTOP^S’ and
t_startc
is ‘^Q’.TIOCPKT_NOSTOP^S/^Q’.TIOCPKT_IOCTLAdditionally, when the
TIOCPKT_IOCTL bit is set, the remainder of
the data read from the pty master is a copy
of the new termios(4) structure.
While this mode is in use, the presence of control status information to be read from the master side may be detected by a select(2) for exceptional conditions.
TIOCUCNTL
int *onTIOCPKT. The
TIOCUCNTL and TIOCPKT
modes are mutually exclusive. This mode is enabled from the master side of
a pseudo terminal. Each subsequent read(2) from the
master side will return data written on the slave part of the pseudo
terminal preceded by a zero byte, or a single byte reflecting a user
control operation on the slave side. A user control command consists of a
special ioctl(2) operation with no data; the command is
given as UIOCCMD(n), where n
is a number in the range 1-255. The operation value
n will be received as a single byte on the next
read(2) from the master side. The
ioctl(2) UIOCCMD(0) is a no-op
that may be used to probe for the existence of this facility.
While this mode is in use, any of the
TIOCSBRK and TIOCCBRK
ioctl requests issued on the slave part of the pseudo terminal will be
translated to a TIOCUCNTL_SBRK or
TIOCUCNTL_CBRK user command on the master
side.
As with TIOCPKT mode, command
operations may be detected with a select(2) for
exceptional conditions.
TIOCREMOTE
int *onTIOCPKT. This mode causes input to the pseudo
terminal to be flow controlled and not input edited (regardless of the
terminal mode). Each write to the controlling terminal produces a record
boundary for the process reading the terminal. In normal usage, a write of
data is like the data typed as a line on the terminal; a write of 0 bytes
is like typing an end-of-file character.
TIOCREMOTE can be used when doing remote line
editing in a window manager, or whenever flow controlled input is
required.The standard way to allocate pty devices
is through openpty(3), a function which internally uses a
PTMGET ioctl(2) call on the
/dev/ptm device. The PTMGET
command allocates a free pseudo terminal, changes its ownership to the
caller, revokes the access privileges for all previous users, opens the file
descriptors for the master and slave devices and returns them to the caller
in struct ptmget.
struct ptmget {
int cfd;
int sfd;
char cn[16];
char sn[16];
};
The cfd and sfd fields are the file descriptors for the controlling and slave terminals. The cn and sn fields are the file names of the controlling and slave devices.
The pty driver appeared in
4.2BSD. The /dev/ptm device
was added in OpenBSD 3.5.
The ptm device will only work on systems
where the /dev directory has been properly populated
with pty device nodes following the naming
convention used in OpenBSD. Since
ptm impersonates the super user for some operations
it needs to perform to complete the allocation of a pseudo terminal, the
/dev directory must also be writeable by the super
user.
| October 13, 2022 | Debian |