Jump to content

Pseudoterminal: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
ENV25 (talk | contribs)
m Applications: Clarification (Terminal --> Terminal (macOS))
Blush30720 (talk | contribs)
Variants: - changed a word, "racy," as it also means something else.
 
(32 intermediate revisions by 16 users not shown)
Line 1: Line 1:
{{Short description|Pair of pseudo-device endpoints}}
[[File:Termios-script-diagram.svg|thumb|Pseudoterminals as they are used by <code>[[script (Unix)|script]]</code>]]
[[File:Termios-script-diagram.svg|thumb|Pseudoterminals as they are used by <code>[[script (Unix)|script]]</code> unix command that records user's input for replaying it later.]]


In some [[operating system]]s, including [[Unix-like]] systems, a '''pseudoterminal''', '''pseudotty''', or '''PTY''' is a pair of [[pseudo-device]] endpoints (files) which establish asynchronous, [[Duplex (telecommunications)|bidirectional]] communication ([[IPC socket|IPC]]) channel (with two ports) between two or more processes.<ref name=":0">{{Cite web|date=2016-02-12|title=Pseudoterminal files|url=https://www.ibm.com/docs/en/zos/2.2.0?topic=files-pseudoterminal|access-date=2021-09-30|website=www.ibm.com|language=en-us}}</ref><ref>{{Cite web|title=Chapter 64: Pseudoterminals - The Linux Programming Interface [Book]|url=https://www.oreilly.com/library/view/the-linux-programming/9781593272203/xhtml/ch64.xhtml|access-date=2021-09-30|website=www.oreilly.com|language=en}}</ref><ref name=":1">{{Cite book|last=Kerrisk|first=Michael|url=https://www.worldcat.org/oclc/728672600|title=The Linux programming interface : a Linux and UNIX system programming handbook|date=2010|publisher=No Starch Press|isbn=978-1-59327-291-3|location=San Francisco|oclc=728672600}}</ref>
In some [[operating system]]s, including [[Unix]], a '''pseudoterminal''', '''pseudotty''', or '''PTY''' is a pair of [[pseudo-device]]s, one of which, the ''slave'', emulates a hardware [[text terminal]] device, the other of which, the ''master'', provides the means by which a terminal emulator [[computer process|process]] controls the slave.

One pseudo-device in the pair, the ''master'', provides means by which a [[terminal emulator]] or remote login server (e.g. a [[Telnet]], [[Berkeley r-commands|rlogin]], or [[Secure Shell]] server)<ref name=":1" /> [[computer process|process]] controls the slave. The other pseudo-device, the ''slave'', emulates a hardware [[serial port]] device,<ref name=":0" /> and is used by terminal-oriented programs such as shells (e.g. [[Bash (Unix shell)|bash]]) as a processes to read/write data back from/to ''master'' endpoint.<ref name=":0" /> PTYs are similar to bidirectional pipes.<ref name=":1" />{{rp|page=1388}}

[[Devpts]] is a [[Linux kernel]] virtual file system containing pseudoterminal devices.

Linux implementation is based on [[UNIX System V|System V]]-style terminals (commonly referred as UNIX 98 pseudoterminals)<ref>{{Cite web|title=pty(7) - Linux manual page|url=https://man7.org/linux/man-pages/man7/pty.7.html|access-date=2021-09-30|website=man7.org}}</ref> and provides [[POSIX]] and the [[Single Unix Specification]] API in the form of a {{tt|posix_openpt()}} function since 1998.<ref>{{man|3|posix_openpt|SUS}}</ref>


The PTY feature is part of [[POSIX]] and the [[Single Unix Specification]] in the form of a {{tt|posix_openpt()}} function since 1998.<ref>{{man|3|posix_openpt|SUS}}</ref>
==History==
==History==
Pseudoterminals were present in the [[Digital Equipment Corporation|DEC]] [[PDP-6]] Timesharing Monitor at least as early as 1967, and were used to implement batch processing.<ref>{{cite web|url=https://groups.google.com/forum/#!msg/alt.sys.pdp10/UVLzSi60mCE/z3tcv35pll0J |title=Google Groups |website=groups.google.com}}</ref>{{Unreliable source?|date=June 2016}} They are described in the documentation for the succeeding [[TOPS-10]] on the [[PDP-10]].<ref>[http://bitsavers.org/pdf/dec/pdp10/Monitor/DEC-T9-MTZD-D_Time-Sharing_Monitors_Pgmr_Ref_Man_Mar71.pdf ''PDP-10 Timesharing Monitors Programmer's Reference Manual''] section 5.10</ref> Other DEC operating systems also had PTYs, including [[RSTS/E]] for the [[PDP-11]], as did the third-party [[TENEX (operating system)|TENEX]] operating system for the PDP-10.
Pseudoterminals were present in the [[Digital Equipment Corporation|DEC]] [[PDP-6]] Timesharing Monitor at least as early as 1967, and were used to implement batch processing. They are described in the documentation for the succeeding [[TOPS-10]] on the [[PDP-10]].<ref>[http://bitsavers.org/pdf/dec/pdp10/Monitor/DEC-T9-MTZD-D_Time-Sharing_Monitors_Pgmr_Ref_Man_Mar71.pdf ''PDP-10 Timesharing Monitors Programmer's Reference Manual''] section 5.10</ref> Other DEC operating systems also had PTYs, including [[RSTS/E]] for the [[PDP-11]], as did the third-party [[TENEX (operating system)|TENEX]] operating system for the PDP-10.


Implementations of Unix pseudo terminals date back to the modifications that RAND and BBN made to a 6th Edition in the late 1970s to support remote access over a network.<ref>[https://minnie.tuhs.org/cgi-bin/utree.pl?file=SRI-NOSC/dmr/pty.c ``PTY Driver for SRI-NOSC Net UNIX''] lines 15-31</ref>
Unix pseudoterminals originated in 1983 during the development of [[Version 8 Unix|Eighth Edition Unix]] and were based on a similar feature in TENEX.<ref>{{cite journal | last = Ritchie | first = D. M. | title = [[STREAMS|A stream input-output system]] | citeseerx = 10.1.1.48.3730 | journal = AT&T Bell Laboratories Technical Journal | volume = 63 | issue = 8 | pages = 1897–1910}}</ref> They were part of the 4.2 release of [[BSD]], with a rather cumbersome {{code|openpty()}} interface defined for use.<ref>{{man|3|openpty|FreeBSD}}</ref>
Modern Unix pseudoterminals originated in 1983 during the development of [[Version 8 Unix|Eighth Edition Unix]] and were based on a similar feature in TENEX.<ref>{{cite journal | last = Ritchie | first = D. M. | title = [[STREAMS|A stream input-output system]] | citeseerx = 10.1.1.48.3730 | journal = AT&T Bell Laboratories Technical Journal | volume = 63 | issue = 8 | pages = 1897–1910| doi = 10.1002/j.1538-7305.1984.tb00071.x | s2cid = 33497669 }}</ref> They were part of the 4.2 release of [[BSD]], with a rather cumbersome {{code|openpty()}} interface defined for use.<ref>{{man|3|openpty|FreeBSD}}</ref>


AT&T's [[System V]] included support for pseudoterminals as a driver in their [[STREAMS]] device model, along with the pseudoterminal multiplexer ({{tt|/dev/ptmx}}). This later evolved to become the Unix98 style of PTYs.
AT&T's [[System V]] included support for pseudoterminals as a driver in their [[STREAMS]] device model, along with the pseudoterminal multiplexer ({{tt|/dev/ptmx}}). This later evolved to become the Unix98 style of PTYs.


== Books ==
''[[The Linux Programming Interface]]'' from 2010 contains an entire chapter (chapter 64 "Pseudoterminals" p1375–1399.) explaining pseudoterminals. Then there is another one, Chapter 62 "Terminals", dedicated to terminals.
''[[The Linux Programming Interface]]'' from 2010 contains an entire chapter (chapter 64 "Pseudoterminals" p1375–1399.) explaining pseudoterminals. Then there is another one, Chapter 62 "Terminals", dedicated to terminals.


Line 21: Line 29:
* to read text output from the master pseudo-device and show it to the user.
* to read text output from the master pseudo-device and show it to the user.


The terminal emulator process must also handle terminal control commands, e.g., for resizing the screen. Widely used terminal emulator programs include ''[[xterm]]'', [[GNOME Terminal]], [[Konsole]], and ''[[Terminal (macOS)]]''. Remote login handlers such as [[Secure Shell|ssh]] and [[telnet]] servers play the same role but communicate with a remote user instead of a local one. Also consider programs such as [[expect]].
The terminal emulator process must also handle terminal control commands, e.g., for resizing the screen. Widely used terminal emulator programs include {{mono|[[xterm]]}}, [[GNOME Terminal]], [[Konsole]], and [[Terminal (macOS)|Terminal]].
Remote login servers such as [[Secure Shell]] and [[Telnet]] servers play the same role but communicate with a remote user instead of a local one.


[[GNU Screen|Screen]] and [[Tmux]] are used to add a session context to a pseudoterminal, making for a much more robust and versatile solution. For example, each provides terminal persistence, allowing a user to disconnect from one computer and then connect later from another computer.
[[GNU Screen|Screen]] and [[Tmux]] are used to add a session context to a pseudoterminal, making for a much more robust and versatile solution. For example, each provides terminal persistence, allowing a user to disconnect from one computer and then connect later from another computer.



==Variants==
==Variants==
In the [[BSD]] PTY system, the slave device file, which generally has a name of the form <code>/dev/tty[p-za-e][0-9a-f]</code>, supports all [[system call]]s applicable to text terminal devices. Thus it supports [[login session]]s. The master device file, which generally has a name of the form <code>/dev/pty[p-za-e][0-9a-f]</code>, is the endpoint for communication with the terminal emulator. With this {{code|[p-za-e]}} naming scheme, there can be at most 256 tty pairs. Also, finding the first free pty master can be [[Race condition|racy]] unless a locking scheme is adopted. For that reason, recent BSD operating systems, such as [[FreeBSD]], implement Unix98 PTYs.<ref>{{man|4|pty|FreeBSD}}</ref>
In the [[BSD]] PTY system, the slave device file, which generally has a name of the form <code>/dev/tty[p-za-e][0-9a-f]</code>, supports all [[system call]]s applicable to text terminal devices. Thus it supports [[login session]]s. The master device file, which generally has a name of the form <code>/dev/pty[p-za-e][0-9a-f]</code>, is the endpoint for communication with the terminal emulator. With this {{code|[p-za-e]}} naming scheme, there can be at most 256 tty pairs. Also, finding the first free pty master can introduce a [[Race condition|race condition]] unless a locking scheme is adopted. For that reason, recent BSD operating systems, such as [[FreeBSD]], implement Unix98 PTYs.<ref>{{man|4|pty|FreeBSD}}</ref>


BSD PTYs have been rendered obsolete by [[Unix98]] ptys whose naming system does not limit the number of pseudo-terminals and access to which occurs without danger of race conditions. <code>/dev/ptmx</code> is the "pseudo-terminal master multiplexer". Opening it returns a file descriptor of a master node and causes an associated slave node <code>/dev/pts/''N''</code> to be created.<ref>{{man|4|pts|Linux}}</ref>
BSD PTYs have been rendered obsolete by [[Unix98]] ptys whose naming system does not limit the number of pseudo-terminals and access to which occurs without danger of race conditions. <code>/dev/ptmx</code> is the "pseudo-terminal master multiplexer". Opening it returns a file descriptor of a master node and causes an associated slave node <code>/dev/pts/''N''</code> to be created.<ref>{{man|4|pts|Linux}}</ref>

== See also ==

* [[List of Unix commands]]


==References==
==References==

Latest revision as of 20:57, 7 January 2025

Pseudoterminals as they are used by script unix command that records user's input for replaying it later.

In some operating systems, including Unix-like systems, a pseudoterminal, pseudotty, or PTY is a pair of pseudo-device endpoints (files) which establish asynchronous, bidirectional communication (IPC) channel (with two ports) between two or more processes.[1][2][3]

One pseudo-device in the pair, the master, provides means by which a terminal emulator or remote login server (e.g. a Telnet, rlogin, or Secure Shell server)[3] process controls the slave. The other pseudo-device, the slave, emulates a hardware serial port device,[1] and is used by terminal-oriented programs such as shells (e.g. bash) as a processes to read/write data back from/to master endpoint.[1] PTYs are similar to bidirectional pipes.[3]: 1388 

Devpts is a Linux kernel virtual file system containing pseudoterminal devices.

Linux implementation is based on System V-style terminals (commonly referred as UNIX 98 pseudoterminals)[4] and provides POSIX and the Single Unix Specification API in the form of a posix_openpt() function since 1998.[5]

History

[edit]

Pseudoterminals were present in the DEC PDP-6 Timesharing Monitor at least as early as 1967, and were used to implement batch processing. They are described in the documentation for the succeeding TOPS-10 on the PDP-10.[6] Other DEC operating systems also had PTYs, including RSTS/E for the PDP-11, as did the third-party TENEX operating system for the PDP-10.

Implementations of Unix pseudo terminals date back to the modifications that RAND and BBN made to a 6th Edition in the late 1970s to support remote access over a network.[7] Modern Unix pseudoterminals originated in 1983 during the development of Eighth Edition Unix and were based on a similar feature in TENEX.[8] They were part of the 4.2 release of BSD, with a rather cumbersome openpty() interface defined for use.[9]

AT&T's System V included support for pseudoterminals as a driver in their STREAMS device model, along with the pseudoterminal multiplexer (/dev/ptmx). This later evolved to become the Unix98 style of PTYs.

Books

[edit]

The Linux Programming Interface from 2010 contains an entire chapter (chapter 64 "Pseudoterminals" p1375–1399.) explaining pseudoterminals. Then there is another one, Chapter 62 "Terminals", dedicated to terminals.

The Windows Console was extended to have a PTY interface called ConPTY in 2018.[10]

Applications

[edit]

The role of the terminal emulator process is:

  • to interact with the user,
  • to feed text input to the master pseudo-device for use by the shell (such as bash), which is connected to the slave pseudo-device,
  • to read text output from the master pseudo-device and show it to the user.

The terminal emulator process must also handle terminal control commands, e.g., for resizing the screen. Widely used terminal emulator programs include xterm, GNOME Terminal, Konsole, and Terminal.

Remote login servers such as Secure Shell and Telnet servers play the same role but communicate with a remote user instead of a local one.

Screen and Tmux are used to add a session context to a pseudoterminal, making for a much more robust and versatile solution. For example, each provides terminal persistence, allowing a user to disconnect from one computer and then connect later from another computer.

Variants

[edit]

In the BSD PTY system, the slave device file, which generally has a name of the form /dev/tty[p-za-e][0-9a-f], supports all system calls applicable to text terminal devices. Thus it supports login sessions. The master device file, which generally has a name of the form /dev/pty[p-za-e][0-9a-f], is the endpoint for communication with the terminal emulator. With this [p-za-e] naming scheme, there can be at most 256 tty pairs. Also, finding the first free pty master can introduce a race condition unless a locking scheme is adopted. For that reason, recent BSD operating systems, such as FreeBSD, implement Unix98 PTYs.[11]

BSD PTYs have been rendered obsolete by Unix98 ptys whose naming system does not limit the number of pseudo-terminals and access to which occurs without danger of race conditions. /dev/ptmx is the "pseudo-terminal master multiplexer". Opening it returns a file descriptor of a master node and causes an associated slave node /dev/pts/N to be created.[12]

See also

[edit]

References

[edit]
  1. ^ a b c "Pseudoterminal files". www.ibm.com. 2016-02-12. Retrieved 2021-09-30.
  2. ^ "Chapter 64: Pseudoterminals - The Linux Programming Interface [Book]". www.oreilly.com. Retrieved 2021-09-30.
  3. ^ a b c Kerrisk, Michael (2010). The Linux programming interface : a Linux and UNIX system programming handbook. San Francisco: No Starch Press. ISBN 978-1-59327-291-3. OCLC 728672600.
  4. ^ "pty(7) - Linux manual page". man7.org. Retrieved 2021-09-30.
  5. ^ posix_openpt – System Interfaces Reference, The Single UNIX Specification, Version 4 from The Open Group
  6. ^ PDP-10 Timesharing Monitors Programmer's Reference Manual section 5.10
  7. ^ ``PTY Driver for SRI-NOSC Net UNIX lines 15-31
  8. ^ Ritchie, D. M. "A stream input-output system". AT&T Bell Laboratories Technical Journal. 63 (8): 1897–1910. CiteSeerX 10.1.1.48.3730. doi:10.1002/j.1538-7305.1984.tb00071.x. S2CID 33497669.
  9. ^ openpty(3) – FreeBSD Library Functions Manual
  10. ^ "Introducing the Windows Pseudo Console (ConPTY)". Windows Command Line DevBolgs. 3 August 2018.
  11. ^ pty(4) – FreeBSD Kernel Interfaces Manual
  12. ^ pts(4) – Linux Programmer's Manual – Special Files
[edit]