blob: 8897c924a836005141b5ca3285aa85f52b597fec [file] [log] [blame]
.\" This man page was written by Jeremy Phelps <>.
.\" Notes added - aeb
.\" Redistribute and revise at will.
.TH PTS 4 2016-03-15 "Linux" "Linux Programmer's Manual"
ptmx, pts \- pseudoterminal devices
The file
.I /dev/ptmx
(the pseudoterminal multiplexor device)
is a character file with major number 5 and
minor number 2, usually with mode 0666 and ownership root:root.
It is used to create a pseudoterminal device pair.
When a process opens
.IR /dev/ptmx ,
it gets a file
descriptor for a new pseudoterminal device
and a corresponding terminal device is created in the
.I /dev/pts
Each file descriptor obtained by opening
.IR /dev/ptmx
is an independent pseudoterminal device with its own associated terminal device,
whose path can
be found by passing the file descriptor to
.BR ptsname (3).
Before opening the corresponding terminal device,
you must pass the pseudoterminal device's file
descriptor to
.BR grantpt (3)
.BR unlockpt (3).
Once both the pseudoterminal device and the terminal device are open,
the terminal device provides
processes with an interface that is identical to that of a real terminal.
Data written to the terminal device is presented on
the pseudoterminal device as input.
Data written to the pseudoterminal device is presented
to the terminal device as input.
In practice, pseudoterminals are used for implementing terminal emulators
such as
.BR xterm (1),
in which data read from the pseudoterminal device is interpreted by the
application in the same way
a real terminal would interpret the data, and for implementing remote-login
programs such as
.BR sshd (8),
in which data read from the pseudoterminal device is sent across the network
to a client program that is connected to a terminal or terminal emulator.
Pseudoterminals can also be used to send input to programs that normally
refuse to read input from pipes (such as
.BR su (1),
.BR passwd (1)).
.IR /dev/ptmx ,
.I /dev/pts/*
The Linux support for the above (known as UNIX 98 pseudoterminal naming)
is done using the
.I devpts
filesystem, which should be mounted on
.IR /dev/pts .
.BR getpt (3),
.BR grantpt (3),
.BR ptsname (3),
.BR unlockpt (3),
.BR pty (7)