End-of-Transmission character

From Wikipedia, the free encyclopedia

In telecommunication, an End-of-Transmission character (EOT) is a transmission control character. Its intended use is to indicate the conclusion of a transmission that may have included one or more texts and any associated message headings.[1]

An EOT is often used to initiate other functions, such as releasing circuits, disconnecting terminals, or placing receive terminals in a standby condition.[1] Its most common use today is to cause a Unix terminal driver to signal end of file and thus exit programs that are awaiting input.

In ASCII and Unicode, the character is encoded at U+0004 <control-0004>. It can be referred to as Ctrl+D, ^D in caret notation. Unicode provides the character U+2404 SYMBOL FOR END OF TRANSMISSION for when EOT needs to be displayed graphically.[2] In addition, U+2301 ELECTRIC ARROW can also be used as a graphic representation of EOT; it is defined in Unicode as "symbol for End of Transmission".[3]

Meaning in Unix[edit]

The EOT character in Unix is different from the Control-Z in DOS. The DOS Control-Z byte is actually sent and/or placed in files to indicate where the text ends. In contrast, the Control-D causes the Unix terminal driver to signal the EOF condition, which is not a character, while the byte has no special meaning if actually read or written from a file or terminal.

In Unix, the end-of-file character (by default EOT) causes the terminal driver to make available all characters in its input buffer immediately; normally the driver would collect characters until it sees an end-of-line character. If the input buffer is empty (because no characters have been typed since the last end-of-line or end-of-file), a program reading from the terminal reads a count of zero bytes. In Unix, such a condition is understood as having reached the end of the file.

This can be demonstrated with the cat program on Unix-like operating systems such as Linux: Run the cat command with no arguments, so it accepts its input from the keyboard and prints output to the screen. Type a few characters without pressing ↵ Enter, then type Ctrl+D. The characters typed to that point are sent to cat, which then writes them to the screen. If Ctrl+D is typed without typing any characters first, the input stream is terminated and the program ends. An actual EOT is obtained by typing Ctrl+V then Ctrl+D.

If the terminal driver is in "raw" mode, it no longer interprets control characters, and the EOT character is sent unchanged to the program, which is free to interpret it any way it likes. A program may then decide to handle the EOT byte as an indication that it should end the text; this would then be similar to how Ctrl+Z is handled by DOS programs.

Usage in mainframe computer system communications protocols[edit]

The EOT character is used in legacy communications protocols by mainframe computer manufacturers such as IBM, Burroughs Corporation, and the BUNCH. Terminal transmission control protocols such as IBM 3270 Poll/Select, or Burroughs TD830 Contention Mode protocol use the EOT character to terminate a communications sequence between two cooperating stations (such as a host multiplexer or Input/Output terminal).

A single Poll (ask the station for data) or Select (send data to the station) operation will include two round-trip send-reply operations between the polling station and the station being polled, the final operation being transmission of a single EOT character to the initiating station.

See also[edit]

References[edit]

  1. ^ a b "end-of-transmission character (EOT)". Federal Standard 1037C. 1996. Archived from the original on 2020-11-23. Retrieved 2009-03-15.
  2. ^ "Control Pictures" (PDF). Archived (PDF) from the original on 2019-01-18. Retrieved 2013-04-06.
  3. ^ "Miscellaneous Technical" (PDF). Archived (PDF) from the original on 2019-12-30. Retrieved 2013-04-07.