Jump to content

RS-232: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Added link to DB subminiature page to fully describe the connector.
m avoid bit/s wrap at slash
 
(686 intermediate revisions by more than 100 users not shown)
Line 1: Line 1:
{{Short description|Standard for serial communication}}
{{About|the RS-232 standard| RS-232 variants|serial port}}
{{About|the RS-232, standard|RS-232 variants, including the common 9-pin connector|serial port}}
[[File:DB25 Diagram.svg|thumb|A [[D-subminiature|DB]]-25 connector as described in the RS-232 standard]]


[[File:DB25 Diagram.svg|thumb|A [[DB-25]] connector as described in the RS-232 standard]]
In [[telecommunications]], '''RS-232''' is the traditional name for a series of standards for [[serial communication|serial]] binary [[Single-ended signaling|single-ended]] [[data transmission|data]] and [[signaling (telecommunications)|control]] signals connecting between a <span title="Usually a controlling terminal or a computer">''DTE''</span> ([[Data Terminal Equipment]]) and a <span title="Usually a modem or target device">''DCE''</span> ([[Data circuit-terminating equipment|Data Circuit-terminating Equipment]]). It is commonly used in [[computer]] [[serial port]]s. The standard defines the electrical characteristics and timing of signals, the meaning of signals, and the physical size and pin out of connectors. The current version of the standard is ''TIA-232-F Interface Between Data Terminal Equipment and Data Circuit-Terminating Equipment Employing Serial Binary Data Interchange,'' issued in 1997.
[[File:RS-232 POTS DTE DCE.svg|thumb|[[Data circuit-terminating equipment]] (DCE) and [[data terminal equipment]] (DTE) network]]


In [[telecommunications]], '''RS-232''' or [[Recommended Standard]] 232<ref name="Metering_Glossary"/> is a [[technical standard|standard]] originally introduced in 1960<ref name="CAM_1974"/> for [[serial communication]] transmission of data. It formally defines signals connecting between a ''DTE'' (''[[data terminal equipment]]'') such as a [[computer terminal]] or [[personal computer|PC]], and a ''DCE'' (''[[data circuit-terminating equipment]]'' or ''[[data communication equipment]]''), such as a [[modem]]. The standard defines the electrical characteristics and timing of signals, the meaning of signals, and the physical size and [[pinout]] of connectors. The current version of the standard is ''TIA-232-F Interface Between Data Terminal Equipment and Data Circuit-Terminating Equipment Employing Serial Binary Data Interchange'', issued in 1997.
An RS-232 port was once a standard feature of a [[personal computer]] for connections to [[modem]]s, [[Printer (computing)|printers]], [[Mouse (computing)|mice]], data storage, un-interruptible power supplies, and other peripheral devices. However, the limited transmission speed, relatively large voltage swing, and large standard connectors motivated development of the [[USB|universal serial bus]] which has displaced RS-232 from most of its peripheral interface roles. Many modern personal computers have no RS-232 ports and must use an external converter to connect to older peripherals. Some RS-232 devices are still found especially in industrial machines or scientific instruments.

The RS-232 standard had been commonly used with [[serial port]]s and [[Serial cable|serial cables]]. It is still widely used in industrial communication devices.

A serial port complying with the RS-232 standard was once a standard feature of many types of computers. [[Personal computer]]s used them for connections not only to modems, but also to [[printer (computing)|printers]], [[computer mice]], data storage, [[uninterruptible power supplies]], and other peripheral devices.

Compared with later interfaces such as [[RS-422]], [[RS-485]] and [[Ethernet]], RS-232 has lower transmission speed, shorter maximum cable length, larger voltage swing, larger standard connectors, no multipoint capability and limited multidrop capability. In modern personal computers, [[USB]] has displaced RS-232 from most of its peripheral interface roles. Thanks to their simplicity and past ubiquity, however, RS-232 interfaces are still used—particularly in industrial CNC machines, networking equipment and scientific instruments where a short-range, point-to-point, low-speed wired data connection is fully adequate.<ref>{{Cite web |date=2017-03-28 |title=Connecting the Beast? |url=https://thisoldmill.com/connecting-the-beast/ |access-date=2023-06-08 |website=This Old Mill |language=en}}</ref>


==Scope of the standard==
==Scope of the standard==
The [[Electronic Industries Alliance|Electronic Industries Association]] (EIA) standard RS-232-C<ref name="eia">{{cite book|title=EIA standard RS-232-C: Interface between Data Terminal Equipment and Data Communication Equipment Employing Serial Binary Data Interchange |year=1969|publisher=Electronic Industries Association. Engineering Dept|location=Washington|oclc=38637094}}</ref> as of 1969 defines:
The [[Electronic Industries Association]] (EIA) standard RS-232-C<ref name="eia">{{cite book |title=EIA standard RS-232-C: Interface between Data Terminal Equipment and Data Communication Equipment Employing Serial Binary Data Interchange |year=1969 |publisher=[[Electronic Industries Association]], Engineering Department |location=Washington, USA |oclc=38637094}}</ref> as of 1969 defines:
* Electrical signal characteristics such as voltage levels, [[data signaling rate|signaling rate]], timing and [[slew rate|slew-rate]] of signals, voltage withstand level, [[Short circuit|short-circuit]] behavior, and maximum load [[capacitance]].
*Electrical signal characteristics such as [[logic level]]s, [[baud rate]], timing, and [[slew rate]] of signals, voltage withstand level, [[short-circuit]] behavior, and maximum load [[capacitance]].
* Interface mechanical characteristics, pluggable connectors and pin identification.
*Interface mechanical characteristics, pluggable connectors and pin identification.
* Functions of each circuit in the interface connector.
*Functions of each circuit in the interface connector.
* Standard subsets of interface circuits for selected telecom applications.
*Standard subsets of interface circuits for selected telecom applications.

The standard does not define such elements as the [[character encoding]] (i.e. [[ASCII]], [[EBCDIC]], or others), the framing of characters (start or stop bits, etc.), transmission order of bits, or error detection protocols. The character format and transmission bit rate are set by the serial port hardware, typically a [[UART]], which may also contain circuits to convert the internal [[logic level]]s to RS-232 compatible signal levels. The standard does not define bit rates for transmission, except that it says it is intended for [[bit rate]]s lower than 20,000 bits per second.


=={{anchor|A|B|C|D|E|F}}History==
The standard does not define such elements as the [[character encoding]] or the framing of characters, or error detection protocols. The standard does not define bit rates for transmission, except that it says it is intended for [[bit rate]]s lower than 20,000 bits per second. Many modern devices support speeds of 115,200 bit/s and above. RS 232 makes no provision for power to peripheral devices.
RS-232 was first introduced in 1960<ref name="CAM_1974"/> by the [[Electronic Industries Association]] (EIA) as a ''Recommended Standard''.<ref>{{cite web |title=RS232 Tutorial on Data Interface and cables |url=http://www.arcelect.com/rs232.htm|publisher=ARC Electronics |access-date=2011-07-28 |year=2010}}</ref><ref name="Metering_Glossary">[http://www.landisgyr.eu/en/pub/services_support/metering_glossary.cfm?eventGlossary=glossary.Search&initial=E Metering Glossary] {{webarchive|url=https://web.archive.org/web/20121129015220/http://www.landisgyr.eu/en/pub/services_support/metering_glossary.cfm?eventGlossary=glossary.Search&initial=E |date=2012-11-29 }} Landis + Gyr Tutorial (see ''EIA'')</ref> The original DTEs were electromechanical [[teletypewriter]]s, and the original DCEs were (usually) modems. When [[electronic terminal]]s (smart and dumb) began to be used, they were often designed to be interchangeable with teletypewriters, and so supported RS-232.


Because the standard did not foresee the requirements of devices such as computers, printers, test instruments, [[POS terminal]]s, and so on, designers implementing an RS-232 compatible interface on their equipment often interpreted the standard idiosyncratically. The resulting common problems were non-standard pin assignment of circuits on connectors, and incorrect or missing control signals. The lack of adherence to the standards produced a thriving industry of [[breakout box]]es, patch boxes, test equipment, books, and other aids for the connection of disparate equipment. A common deviation from the standard was to drive the signals at a reduced voltage. Some manufacturers therefore built transmitters that supplied +5&nbsp;V and −5&nbsp;V and labeled them as "RS-232 compatible".{{Citation needed|date=April 2011}}
Details of character format and transmission bit rate are controlled by the [[serial port]] hardware, often a single [[integrated circuit]] called a [[UART]] that converts data from parallel to [[asynchronous start-stop]] serial form. Details of voltage levels, slew rate, and short-circuit behavior are typically controlled by a [[line driver]] that converts from the UART's [[logic level]]s to RS-232 compatible signal levels, and a receiver that converts from RS-232 compatible signal levels to the UART's logic levels.


Later personal computers (and other devices) started to make use of the standard so that they could connect to existing equipment. For many years, an RS-232-compatible port was a standard feature for [[serial communication]]s, such as modem connections, on many computers (with the computer acting as the DTE). It remained in widespread use into the late 1990s. In personal computer peripherals, it has largely been supplanted by other interface standards, such as USB. RS-232 is still used to connect older designs of peripherals, industrial equipment (such as [[programmable logic controller|PLC]]s), [[system console|console]] ports, and special purpose equipment.
==History==
RS-232 was first introduced in 1962.<ref>{{cite web|title=RS232 Tutorial on Data Interface and cables|url=http://www.arcelect.com/rs232.htm|publisher=ARC Electronics|accessdate=28 July 2011|year=2010}}</ref> The original DTEs were electromechanical [[teleprinter|teletypewriters]], and the original DCEs were (usually) [[modem]]s. When [[Computer terminal|electronic terminals]] (smart and dumb) began to be used, they were often designed to be interchangeable with teletypewriters, and so supported RS-232. The C revision of the standard was issued in 1969 in part to accommodate the electrical characteristics of these devices.{{Citation needed|date=April 2011}}


The standard has been renamed several times during its history as the sponsoring organization changed its name, and has been variously known as EIA RS-232, EIA 232, and, most recently as TIA 232. The standard continued to be revised and updated by the [[Electronic Industries Association]] and since 1988 by the [[Telecommunications Industry Association]] (TIA).<ref>{{cite web |title=TIA Facts at a Glance |url=http://www.tiaonline.org/about/ |work=About TIA |publisher=[[Telecommunications Industry Association]] |access-date=2011-07-28}}</ref> Revision C was issued in a document dated August 1969. Revision D was issued in 1986. The current revision is ''TIA-232-F Interface Between Data Terminal Equipment and Data Circuit-Terminating Equipment Employing Serial Binary Data Interchange'', issued in 1997. Changes since Revision C have been in timing and details intended to improve harmonization with the [[CCITT]] standard {{ill|ITU-T V.24{{!}}ITU-T/CCITT V.24|de|V.24}}, but equipment built to the current standard will interoperate with older versions.{{Citation needed|date=April 2011}}
Since application to devices such as computers, printers, test instruments, and so on was not considered by the standard, designers implementing an RS-232 compatible interface on their equipment often interpreted the requirements idiosyncratically. Common problems were non-standard pin assignment of circuits on connectors, and incorrect or missing control signals. The lack of adherence to the standards produced a thriving industry of breakout boxes, patch boxes, test equipment, books, and other aids for the connection of disparate equipment. A common deviation from the standard was to drive the signals at a reduced voltage. Some manufacturers therefore built transmitters that supplied +5&nbsp;V and -5&nbsp;V and labeled them as "RS-232 compatible".{{Citation needed|date=April 2011}}


Related [[ITU-T]] standards include V.24 (circuit identification) and {{ill|ITU-T V.28{{!}}ITU-T/CCITT V.28|de|V.28}} (signal voltage and timing characteristics).{{Citation needed|date=April 2011}}
Later [[personal computer]]s (and other devices) started to make use of the standard so that they could connect to existing equipment. For many years, an RS-232-compatible port was a standard feature for [[serial communication]]s, such as [[modem]] connections, on many computers. It remained in widespread use into the late 1990s. In personal computer peripherals, it has largely been supplanted by other interface standards, such as [[USB]]. RS-232 is still used to connect older designs of peripherals, industrial equipment (such as [[Programmable logic controller|PLC]]s), [[System console|console]] ports, and special purpose equipment, such as a cash drawer for a cash register.{{Citation needed|date=April 2011}}


In revision D of EIA-232, the D-subminiature connector was formally included as part of the standard (it was only referenced in the appendix of RS-232-C). The voltage range was extended to ±25&nbsp;volts, and the circuit capacitance limit was expressly stated as 2500&nbsp;pF. Revision E of EIA-232 introduced a new, smaller, standard D-shell 26-pin "Alt A" connector, and made other changes to improve compatibility with CCITT standards V.24, V.28 and ISO 2110.<ref>S. Mackay, E. Wright, D. Reynders, J. Park, ''Practical Industrial Data Networks: Design, Installation, and Troubleshooting'', Newnes, 2004 {{ISBN|07506 5807X}}, pages 41-42</ref>
The standard has been renamed several times during its history as the sponsoring organization changed its name, and has been variously known as EIA RS-232, EIA 232, and most recently as TIA 232. The standard continued to be revised and updated by the [[Electronic Industries Alliance]] and since 1988 by the [[Telecommunications Industry Association]] (TIA).<ref>{{cite web|title=TIA Facts at a Glance|url=http://www.tiaonline.org/about/|work=About TIA|publisher=Telecommunications Industry Association|accessdate=28 July 2011}}</ref> Revision C was issued in a document dated August 1969. Revision D was issued in 1986. The current revision is ''TIA-232-F Interface Between Data Terminal Equipment and Data Circuit-Terminating Equipment Employing Serial Binary Data Interchange'', issued in 1997. Changes since Revision C have been in timing and details intended to improve harmonization with the [[ITU-T|CCITT]] standard V.24, but equipment built to the current standard will interoperate with older versions.{{Citation needed|date=April 2011}}


Specification document revision history:
Related [[ITU-T]] standards include '''V.24''' (circuit identification) and '''V.28''' (signal voltage and timing characteristics).{{Citation needed|date=April 2011}}
*EIA RS-232 (May 1960) "Interface Between Data Terminal Equipment & Data"<ref name="CAM_1974"/>
*EIA RS-232-A (October 1963)<ref name="CAM_1974"/>
*EIA RS-232-B (October 1965)<ref name="CAM_1974"/>
*EIA RS-232-C (August 1969) "Interface Between Data Terminal Equipment and Data Communication Equipment Employing Serial Binary Data Interchange"<ref name="CAM_1974">{{citation |title=Standards for Computer Aided Manufacturing |author-first1=John M. |author-last1=Evans, Jr. |author-first2=Joseph T. |author-last2=O'Neill |author-first3=John L. |author-last3=Little |author-first4=James S. |author-last4=Albus |author-first5=Anthony J. |author-last5=Barbera |author-first6=Dennis W. |author-last6=Fife |author-first7=Elizabeth N. |author-last7=Fong |author-first8=David E. |author-last8=Gilsinn |author-first9=Frances E. |author-last9=Holberton |author-first10=Brian G. |author-last10=Lucas |author-first11=Gordon E. |author-last11=Lyon |author-first12=Beatrice A. S. |author-last12=Marron |author-first13=Albercht J. |author-last13=Neumann |author-first14=Mabel V. |author-last14=Vickers |author-first15=Justin C. |author-last15=Walker |location=Office of Developmental Automation and Control Technology, Institute for Computer Sciences and Technology, National Bureau of Standards, Washington, DC, USA |edition=Second Interim Report |date=October 1976 |publisher=Manufacturing Technology Division, Air Force Materials Laboratory, Wright-Patterson Air Force Base, Ohio 45433 |id=NBSIR 76-1094 |url=https://archive.org/stream/standardsforcom7610evan_0/standardsforcom7610evan_0_djvu.txt |access-date=2017-03-04}}</ref>
*EIA EIA-232-D (1986)
*TIA TIA/EIA-232-E (1991) "Interface Between Data Terminal Equipment and Data Communications Equipment Employing Serial Binary Data Interchange"
*TIA TIA/EIA-232-F (October 1997<!-- 1997-10-01 -->)
*ANSI/TIA-232-F-1997 (R2002)
*TIA TIA-232-F (R2012)


==Limitations of the standard==
==Limitations of the standard==
Because the application of RS-232 has extended far beyond the original purpose of interconnecting a terminal with a modem, successor standards have been developed to address the limitations. Issues with the RS-232 standard include:<ref>{{cite book|last=Horowitz|first=Paul|authorlink=Paul Horowitz|title=[[The Art of Electronics]]|year=1989|publisher=Cambridge University Press|location=Cambridge, England|edition=2nd|coauthors=and [[Winfield Hill]]|isbn=0-521-37095-7|pages=723–726}}</ref>
Because RS-232 is used beyond the original purpose of interconnecting a terminal with a modem, successor standards have been developed to address the limitations. Issues with the RS-232 standard include:<ref>{{cite book |author-last1=Horowitz |author-first1=Paul |author-link1=Paul Horowitz |title=The Art of Electronics |year=1989 |publisher=[[Cambridge University Press]] |location=Cambridge, England |edition=2nd |author-first2=Winfield |author-last2=Hill |author-link2=Winfield Hill |isbn=0-521-37095-7 |pages=[https://archive.org/details/artofelectronics00horo/page/723 723–726] |title-link=The Art of Electronics }}</ref>
* The large voltage swings and requirement for positive and negative supplies increases power consumption of the interface and complicates power supply design. The voltage swing requirement also limits the upper speed of a compatible interface.
* The large voltage swings and requirement for positive and negative supplies increases power consumption of the interface and complicates power supply design. The voltage swing requirement also limits the upper speed of a compatible interface.
* Single-ended signaling referred to a common signal ground limits the noise immunity and transmission distance.
* Single-ended signaling referred to a common signal ground limits the noise immunity and transmission distance.
* Multi-drop connection among more than two devices is not defined. While multi-drop "work-arounds" have been devised, they have limitations in speed and compatibility.
* Multi-drop connection among more than two devices is not defined. While multi-drop "work-arounds" have been devised, they have limitations in speed and compatibility.
* The standard does not address the possibility of connecting a DTE directly to a DTE, or a DCE to a DCE. [[Null modem]] cables can be used to achieve these connections, but these are not defined by the standard, and some such cables use different connections than others.
* Asymmetrical definitions of the two ends of the link make the assignment of the role of a newly developed device problematic; the designer must decide on either a DTE-like or DCE-like interface and which connector pin assignments to use.
* The definitions of the two ends of the link are asymmetric. This makes the assignment of the role of a newly developed device problematic; the designer must decide on either a DTE-like or DCE-like interface and which connector pin assignments to use.
* The [[handshaking]] and control lines of the interface are intended for the setup and takedown of a [[dial-up]] communication circuit; in particular, the use of handshake lines for [[flow control]] is not reliably implemented in many devices.
* The [[Handshake (computing)|Handshaking]] and control lines of the interface are intended for the setup and takedown of a [[dial-up]] communication circuit; in particular, the use of handshake lines for [[flow control (data)|flow control]] is not reliably implemented in many devices.
* No method is specified for sending power to a device. While a small amount of current can be extracted from the DTR and RTS lines, this is only suitable for low power devices such as [[Mouse (computing)|mice]].
* No method is specified for sending power to a device. While a small amount of current can be extracted from the DTR and RTS lines, this is only suitable for low-power devices such as [[mouse (computing)|mice]].
* The 25-way connector recommended in the standard is large compared to current practice.
* The 25-pin D-sub connector recommended in the standard is large compared to current practice.


==Role in modern personal computers==
==Role in modern personal computers==
{{Main|Serial port}}
[[Image:RS232 PCI-E.jpg|thumb|160px|right|[[PCI Express]] x1 card with one RS-232 port]]
[[File:RS232 PCI-E.jpg|thumb|[[PCI Express]] x1 card with one RS-232 port on a nine-pin connector]]
{{main|Serial port}}
In the book ''[[PC 97]] Hardware Design Guide'',<ref name="pc 97">{{cite book|title=PC 97 Hardware Design Guide|year=1997|publisher=Microsoft Press|location=Redmond, Wash|isbn=1-57231-381-1}}</ref> [[Microsoft]] deprecated support for the RS-232 compatible serial port of the original IBM PC design. Today, RS-232 has mostly been replaced in personal computers by [[USB]] for local communications. Compared with RS-232, USB is faster, uses lower voltages, and has connectors that are simpler to connect and use. However, USB is limited by standard to no more than 5 meters of cable, thus favoring RS-232 when longer distances are needed. Both standards have software support in popular operating systems. USB is designed to make it easy for device drivers to communicate with hardware. However, there is no direct analog to the [[Terminal Emulator|terminal programs]] used to let users communicate directly with serial ports. USB is more complex than the RS-232 standard because it includes a protocol for transferring data to devices. This requires more software to support the protocol used. RS-232 only standardizes the voltage of signals and the functions of the physical interface pins. Serial ports of personal computers are also sometimes used to directly control various hardware devices, such as [[relay]]s or lamps, since the control lines of the interface can be easily manipulated by software. This is not feasible with USB, which requires some form of receiver to decode the serial data.


In the book ''[[PC 97]] Hardware Design Guide'',<ref name="pc 97">{{cite book |title=PC 97 Hardware Design Guide |date=1997 |publisher=[[Microsoft Press]] |location=Redmond, Washington, USA |isbn=1-57231-381-1}}</ref> [[Microsoft]] deprecated support for the RS-232 compatible serial port of the original IBM PC design. Today, RS-232 has mostly been replaced in personal computers by [[USB]] for local communications. Advantages compared to RS-232 are that USB is faster, uses lower voltages, and has connectors that are simpler to connect and use. Disadvantages of USB compared to RS-232 are that USB is far less immune to [[electromagnetic interference]] (EMI) and that maximum cable length defined by standards is much shorter (15 meters for RS-232 versus 3&ndash;5 meters for USB, depending on the USB version and use of active cables). RS-232 cable lengths of 2000 meters are possible with appropriate line drivers.<ref>{{Cite web|url=https://www.tldp.org/HOWTO/Remote-Serial-Console-HOWTO/serial-distance.html|title=Lengths of serial cables|website=www.tldp.org|access-date=2020-01-01}}</ref><ref>{{Cite book|title=CompTIA A+ Guide to IT technical support|last=Andrews|first=Jean|publisher=Cengage Learning|others=Dark, Joy, West, Jill|year=2020|isbn=978-0-357-10829-1|edition=Tenth|location=Boston, MA, USA|pages=267|oclc=1090438548}}</ref>
As an alternative, USB [[docking port]]s are available which can provide connectors for a keyboard, mouse, one or more serial ports, and one or more [[parallel port]]s. Corresponding device drivers are required for each USB-connected device to allow programs to access these USB-connected devices as if they were the original directly connected peripherals. Devices that convert USB to RS-232 may not work with all software on all personal computers and may cause a reduction in bandwidth along with higher latency.


In fields such as laboratory automation or surveying, RS-232 devices continue to be used. Some types of [[programmable logic controller]]s, [[variable-frequency drive]]s, [[servo drive]]s, and [[computerized numerical control]] equipment are programmable via RS-232. Computer manufacturers have responded to this demand by re-introducing the [[DE-9M]] connector on their computers or by making adapters available.
Personal computers may use a serial port to interface to devices such as [[Uninterruptible power supply|uninterruptible power supplies]]. In some cases, serial data is not exchanged, but the control lines are used to signal conditions such as loss of power or low battery alarms.


RS-232 ports are also commonly used to communicate to [[headless system]]s such as [[server (computing)|server]]s, where no monitor or keyboard is installed, during boot when an [[operating system]] is not yet running and therefore no network connection is possible. A computer with an RS-232 serial port can communicate with the serial port of an [[embedded system]] (such as a [[router (computing)|router]]) as an alternative to monitoring over Ethernet.
Many fields (for example, laboratory automation, surveying) provide a continued demand for RS-232 I/O due to sustained use of very expensive but aging equipment. It is often far cheaper to continue to use RS-232 than it is to replace the equipment. Additionally, modern industrial automation equipment, such as [[Programmable logic controller|PLCs]], [[Variable-frequency drive|VFDs]], [[servo drive]]s, and [[Numerical control|CNC equipment]] are programmable via RS-232. Some manufacturers have responded to this demand: Toshiba re-introduced the [[D-subminiature|DE-9M]] connector on the [[Toshiba Tecra|Tecra]] laptop.


=={{anchor|Flow control}}Physical interface==
Serial ports with RS-232 are also commonly used to communicate to [[headless system]]s such as [[server (computing)|servers]], where no monitor or keyboard is installed, during boot when [[operating system]] is not running yet and therefore no network connection is possible. An RS-232 serial port can communicate to some [[embedded system]]s such as [[Router (computing)|routers]] as an alternative to network mode of monitoring.
In RS-232, user data is sent as a [[time-series]] of [[bit]]s. Both [[Synchronous serial communication|synchronous]] and [[Asynchronous serial communication|asynchronous]] transmissions are supported by the standard. In addition to the data circuits, the standard defines a number of control circuits used to manage the connection between the DTE and DCE. Each data or control circuit only operates in one direction, that is, signaling from a DTE to the attached DCE or the reverse. Because transmit data and receive data are separate circuits, the interface can operate in a [[full duplex]] manner, supporting concurrent data flow in both directions. The standard does not define character framing within the data stream or character encoding.


==={{anchor|DSR}}Voltage levels===
==Standard details==
[[File: Rs232 oscilloscope trace.svg|thumb|Diagrammatic oscilloscope trace of voltage levels for an [[ASCII]] "K" character (4Bh&nbsp;= 01001011b) with 1 start bit, 8 data bits (least significant bit first), 1 stop bit. This is typical for start-stop communications, but the standard does not dictate a character format or bit order.]]
In RS-232, user data is sent as a [[time-series]] of [[bit]]s. Both synchronous and asynchronous transmissions are supported by the standard. In addition to the data circuits, the standard defines a number of control circuits used to manage the connection between the DTE and DCE. Each data or control circuit only operates in one direction, that is, signaling from a DTE to the attached DCE or the reverse. Since transmit data and receive data are separate circuits, the interface can operate in a [[full duplex]] manner, supporting concurrent data flow in both directions. The standard does not define character framing within the data stream, or character encoding.
[[File: RS232-UART Oscilloscope Screenshot.png|thumb|RS-232 data line on the terminals of the receiver side (RxD) probed by an oscilloscope (for an [[ASCII]] "K" character (4Bh&nbsp;= 01001011b) with 1 start bit, 8 data bits, 1 stop bit, and no parity bits)]]


The RS-232 standard defines the voltage levels that correspond to logical one and logical zero levels for the data transmission and the control signal lines. Valid signals are either in the range of +3 to +15&nbsp;volts or the range −3 to −15 volts with respect to the "Common Ground" (GND) pin; consequently, the range between −3 and +3&nbsp;volts is not a valid RS-232 level. For data transmission lines (TxD, RxD, and their secondary channel equivalents), logic one is represented as a negative voltage and the signal condition is called "mark". Logic zero is signaled with a positive voltage and the signal condition is termed "space". Control signals have the opposite polarity: the asserted or active state is positive voltage and the de-asserted or inactive state is negative voltage. Examples of control lines include request to send (RTS), clear to send (CTS), [[data terminal ready]] (DTR), and data set ready (DSR).
===Voltage levels===
[[Image:Rs232 oscilloscope trace.svg|thumb|160px|right| Diagrammatic oscilloscope trace of voltage levels for an uppercase ASCII "K" character (0x4b) with 1 start bit, 8 data bits, 1 stop bit. This is typical for start-stop communications, but the standard does not dictate a character format or bit order.]]


{| class="wikitable"
[[File:RS232-UART Oscilloscope Screenshot.png|thumb|Upper Picture: RS232 signalling as seen when probed by an actual oscilloscope (Tektronix MSO4104B) for an uppercase ASCII "K" character (0x4b) with 1 start bit (always), 8 data bits, 1 stop bit and no parity bits (8N1) Lower Picture: Same signal was inputted into an RS232 to UART converter, the output is depicted.]]
|+ RS-232 logic and voltage levels

! Data circuits !! Control circuits !! Voltage
The RS-232 standard defines the voltage levels that correspond to logical one and logical zero levels for the data transmission and the control signal lines. Valid signals are plus or minus 3 to 15 volts; the ±3&nbsp;V range near zero volts is not a valid RS-232 level. The standard specifies a maximum open-circuit voltage of 25 volts: signal levels of ±5 V, ±10 V, ±12 V, and ±15 V are all commonly seen depending on the [[power supply|power supplies]] available within a device. RS-232 drivers and receivers must be able to withstand indefinite short circuit to ground or to any voltage level up to ±25 volts. The [[slew rate]], or how fast the signal changes between levels, is also controlled.
|-
| 0 (space) || Asserted || +3 to +15 V
|-
| 1 (mark) || Deasserted || −15 to −3 V
|}


The standard specifies a maximum [[open-circuit voltage]] of 25&nbsp;volts: signal levels of ±5&nbsp;V, ±10&nbsp;V, ±12&nbsp;V, and ±15&nbsp;V are all commonly seen depending on the voltages available to the [[line driver]] circuit. Many RS-232 driver chips have inbuilt [[charge pump]] circuitry to produce the required voltages from a 3 or 5&nbsp;volt supply. RS-232 drivers and receivers must be able to withstand indefinite short circuits to the ground or to any voltage level up to ±25&nbsp;volts. The [[slew rate]], or how fast the signal changes between levels, is also controlled.
For data transmission lines (TxD, RxD and their secondary channel equivalents) logic one is defined as a negative voltage, the signal condition is called marking, and has the functional significance. Logic zero is positive and the signal condition is termed spacing. Control signals are logically inverted with respect to what one sees on the data transmission lines. When one of these signals is active, the voltage on the line will be between +3 to +15 volts. The inactive state for these signals is the opposite voltage condition, between −3 and −15 volts. Examples of control lines include request to send (RTS), clear to send (CTS), [[data terminal ready]] (DTR), and data set ready (DSR).


Because the voltage levels are higher than logic levels typically used by integrated circuits, special intervening driver circuits are required to translate logic levels. These also protect the device's internal circuitry from short circuits or transients that may appear on the RS-232 interface, and provide sufficient current to comply with the slew rate requirements for data transmission.
Because the voltage levels are higher than logic levels typically used by integrated circuits, special intervening driver circuits are required to translate logic levels. These also protect the device's internal circuitry from short circuits or transients that may appear on the RS-232 interface, and provide sufficient current to comply with the slew rate requirements for data transmission.


Because both ends of the RS-232 circuit depend on the ground pin being zero volts, problems will occur when connecting machinery and computers where the voltage between the ground pin on one end, and the ground pin on the other is not zero. This may also cause a hazardous [[ground loop (electricity)|ground loop]]. Use of a common ground limits RS-232 to applications with relatively short cables. If the two devices are far enough apart or on separate power systems, the local ground connections at either end of the cable will have differing voltages; this difference will reduce the noise margin of the signals. Balanced, differential, serial connections such as [[USB]], [[RS-422]] and [[RS-485]] can tolerate larger ground voltage differences because of the differential signaling.<ref>{{cite web|last=Wilson|first=Michael R.|title=TIA/EIA-422-B Overview|url=http://www.national.com/an/AN/AN-1031.pdf|work=Application Note 1031|publisher=National Semiconductor|accessdate=28 July 2011|month=January|year=2000}}</ref>
Because both ends of the RS-232 circuit depend on the ground pin being zero volts, problems will occur when connecting machinery and computers where the voltage between the ground pin on one end, and the ground pin on the other is not zero. This may also cause a hazardous [[ground loop (electricity)|ground loop]]. Use of a common ground limits RS-232 to applications with relatively short cables. If the two devices are far enough apart or on separate power systems, the local ground connections at either end of the cable will have differing voltages; this difference will reduce the noise margin of the signals. Balanced, differential serial connections such as [[RS-422]] or [[RS-485]] can tolerate larger ground voltage differences because of the differential signaling.<ref>{{cite web |author-last=Wilson |author-first=Michael R. |title=TIA/EIA-422-B Overview |url=http://www.national.com/an/AN/AN-1031.pdf |work=Application Note 1031 |publisher=[[National Semiconductor]] |access-date=2011-07-28 |date=January 2000 |url-status=dead |archive-url=https://web.archive.org/web/20100106194629/http://www.national.com/an/AN/AN-1031.pdf |archive-date=2010-01-06}}</ref>


Unused interface signals terminated to ground will have an undefined logic state. Where it is necessary to permanently set a control signal to a defined state, it must be connected to a voltage source that asserts the logic 1 or logic 0 level. Some devices provide test voltages on their interface connectors for this purpose.
Unused interface signals terminated to the ground will have an undefined logic state. Where it is necessary to permanently set a control signal to a defined state, it must be connected to a voltage source that asserts the logic 1 or logic 0 levels, for example with a [[pull-up resistor]]. Some devices provide test voltages on their interface connectors for this purpose.


===Connectors===
===Connectors===<!-- This section is linked from [[Data terminal equipment]] -->
<!-- [[Data terminal equipment]] links here. -->
RS-232 devices may be classified as Data Terminal Equipment (DTE) or Data Communication Equipment (DCE); this defines at each device which wires will be sending and receiving each signal. The standard recommended but did not make mandatory the [[D-subminiature]] 25 pin connector. In general and according to the standard, terminals and computers have male connectors with DTE pin functions, and modems have female connectors with DCE pin functions. Other devices may have any combination of connector gender and pin definitions.
Many terminals were manufactured with female terminals but were sold with a cable with male connectors at each end; the terminal with its cable satisfied the recommendations in the standard.
RS-232 devices may be classified as Data Terminal Equipment (DTE) or Data Circuit-terminating Equipment (DCE); this defines at each device which wires will be sending and receiving each signal. According to the standard, male connectors have DTE pin functions, and female connectors have DCE pin functions. Other devices may have any combination of connector gender and pin definitions. Many terminals were manufactured with female connectors but were sold with a cable with male connectors at each end; the terminal with its cable satisfied the recommendations in the standard.


The standard recommends the [[D-subminiature]] 25-pin connector up to revision C, and makes it mandatory as of revision D. Most devices only implement a few of the twenty signals specified in the standard, so connectors and cables with fewer pins are sufficient for most connections, more compact, and less expensive. Personal computer manufacturers replaced the [[DB-25M]] connector with the smaller [[DE-9M]] connector. This connector, with a different pinout (see [[Serial port pinout]]s), is prevalent for personal computers and associated devices.
Presence of a 25 pin D-sub connector does not necessarily indicate an RS-232-C compliant interface. For example, on the original IBM PC, a male D-sub was an RS-232-C DTE port (with a non-standard [[current loop]] interface on reserved pins), but the female D-sub connector was used for a parallel [[Centronics]] printer port. Some [[personal computer]]s put non-standard voltages or signals on some pins of their serial ports.


Presence of a 25-pin D-sub connector does not necessarily indicate an RS-232-C compliant interface. For example, on the original IBM PC, a male D-sub was an RS-232-C DTE port (with a non-standard [[current loop]] interface on reserved pins), but the female D-sub connector on the same PC model was used for the [[parallel port#Centronics|parallel "Centronics" printer port]]. Some personal computers put non-standard voltages or signals on some pins of their serial ports.
The standard specifies 20 different signal connections. Since most devices use only a few signals, smaller connectors can often be used.


===Signals ===
===Cables===
{{main|Serial cable}}

The standard does not define a maximum cable length, but instead defines the maximum capacitance that a compliant drive circuit must tolerate. A widely used rule of thumb indicates that cables more than {{convert|15|m|abbr=on|-1}} long will have too much capacitance, unless special cables are used. By using low-capacitance cables, communication can be maintained over larger distances up to about {{convert|300|m|abbr=on|-2}}.<ref>{{cite web |url=http://aplawrence.com/Unixart/serial.art.html |title=Serial Wiring |date=1992 |work=A. P. Lawrence |author-last=Lawrence |author-first=Tony |access-date=2011-07-28}}</ref> For longer distances, other signal standards, such as [[RS-422]], are better suited for higher speeds.

Since the standard definitions are not always correctly applied, it is often necessary to consult documentation, test connections with a [[breakout box]], or use trial and error to find a cable that works when interconnecting two devices. Connecting a fully standard-compliant DCE device and DTE device would use a cable that connects identical pin numbers in each connector (a so-called "straight cable"). "[[Gender changer]]s" are available to solve gender mismatches between cables and connectors. Connecting devices with different types of connectors requires a cable that connects the corresponding pins according to the table below. Cables with 9 pins on one end and 25 on the other are common. Manufacturers of equipment with [[8P8C]] connectors usually provide a cable with either a DB-25 or DE-9 connector (or sometimes interchangeable connectors so they can work with multiple devices). Poor-quality cables can cause false signals by [[crosstalk]] between data and control lines (such as [[#RI|Ring Indicator]]).

If a given cable will not allow a data connection, especially if a [[gender changer]] is in use, a [[null modem]] cable may be necessary. Gender changers and null modem cables are not mentioned in the standard, so there is no officially sanctioned design for them.


==Data and control signals==
The following table lists commonly used RS-232 signals and pin assignments.<ref>{{cite web |url=http://www.hardwarebook.info/Serial_(PC_9) |title=Serial (PC 9)|work=Hardware Book|author=Ögren, Joakim|date=18 September 2008|accessdate=28 July 2011}}</ref> See [[Serial_port#Pinouts|serial port (pinouts)]] for non-standard variations including the popular [[DE-9]] connector.
[[File:DB-25 male.svg|thumb|Male pinout of a 25-pin serial port (D-subminiature, DB-25) commonly found on 1980s computers]]
{| class="wikitable" style="margin:auto; text-align:center;"
The following table lists commonly used RS-232 signals (called "circuits" in the specifications) and their pin assignments on the recommended DB-25 connectors<ref>{{cite web |url=https://pinoutguide.com/SerialPorts/RS232_pinout.shtml |title=Serial (PC 25) |work=Pinout Guide}}</ref> (see [[Serial port pinout]]s for other commonly used connectors not defined by the standard).
! colspan="3" | Signal !! colspan="2" | Origin !! rowspan="2" | [[D-subminiature|DB-25]] pin
{| class="wikitable sortable" style="margin:auto; text-align:center;"
! colspan="3" | Circuit !! colspan="2" | Direction !! rowspan="2" | [[DB-25]] pin
|-
|-
! Name !! width="400px" | Typical purpose !! Abbreviation !! DTE !! DCE
! Name !! width="400px" | Typical purpose !! Abbreviation !! DTE !! DCE
|-
|-
| align="left" | [[Data Terminal Ready]] || align="left" | Indicates presence of DTE to DCE. || DTR || || || 20
| align="left" | [[Data Terminal Ready]] || align="left" | DTE is ready to receive, initiate, or continue a call. || DTR || Out || In || 20
|-
|-
| align="left" | [[Data Carrier Detect]] || align="left" | DCE is connected to the telephone line. || DCD || || || 8
| align="left" | [[Data Carrier Detect]] || align="left" | DCE is receiving a carrier from a remote DCE. || DCD || In || Out || 8
|-
|-
| align="left" | Data Set Ready || align="left" | DCE is ready to receive commands or data. || DSR || || || 6
| align="left" | Data Set Ready || align="left" | DCE is ready to receive and send data. || DSR || In || Out || 6
|-
|-
| align="left" | Ring Indicator || align="left" | DCE has detected an incoming ring signal on the telephone line. || RI || || || 22
| align="left" | Ring Indicator || align="left" | DCE has detected an incoming ring signal on the telephone line. || RI || In || Out || 22
|-
|-
| align="left" | Request To Send || align="left" | DTE requests the DCE prepare to receive data. || RTS || || || 4
| align="left" | Request To Send || align="left" | DTE requests the DCE prepare to transmit data. || RTS || Out || In || 4
|-
|-
| align="left" | Clear To Send || align="left" | Indicates DCE is ready to accept data. || CTS || || || 5
| align="left" | Ready To Receive || align="left" | DTE is ready to receive data from DCE. If in use, RTS is assumed to be always asserted. || RTR || Out || In || 4
|-
|-
| align="left" | Transmitted Data || align="left" | Carries data from DTE to DCE. || TxD || || || 2
| align="left" | Clear To Send || align="left" | DCE is ready to accept data from the DTE. || CTS || In || Out || 5
|-
|-
| align="left" | Received Data || align="left" | Carries data from DCE to DTE. || RxD || || || 3
| align="left" | Transmitted Data || align="left" | Carries data from DTE to DCE. || TxD || Out || In || 2
|-
|-
| align="left" | Common Ground || || GND || colspan="2" | <small>common</small>|| 7
| align="left" | Received Data || align="left" | Carries data from DCE to DTE. || RxD || In || Out || 3
|-
|-
| align="left" | Protective Ground || || PG || colspan="2" | <small>common</small>|| 1
| align="left" | Common Ground || align="left" | Zero voltage reference for all of the above. || GND || colspan="2" | <small>Common</small>|| 7
|}

The signals are named from the standpoint of the DTE. [[Single-ended signalling|The ground signal is a common return]] for the other connections. The DB-25 connector includes a second "protective ground" on pin 1.

Data can be sent over a secondary channel (when implemented by the DTE and DCE devices), which is equivalent to the primary channel. Pin assignments are described in following table:
{| class="wikitable" style="margin:auto;"
! Signal !! Pin
|-
| Common Ground || 7 (same as primary)
|-
| Secondary Transmitted Data (STD) || 14
|-
| Secondary Received Data (SRD) || 16
|-
| Secondary Request To Send (SRTS) || 19
|-
|-
| align="left" | Protective Ground || align="left" | Connected to chassis ground. || PG || colspan="2" | <small>Common</small>|| 1
| Secondary Clear To Send (SCTS) || 13
|-
| Secondary Carrier Detect (SDCD) || 12
|}
|}


The signals are named from the standpoint of the DTE. [[Single-ended signaling|The ground pin is a common return]] for the other connections, and establishes the "zero" voltage to which voltages on the other pins are referenced. The DB-25 connector includes a second "protective ground" on pin 1; this is connected internally to equipment frame ground, and should not be connected in the cable or connector to signal ground.
''Ring Indicator''' (RI), is a signal sent from the modem to the terminal device. It indicates to the terminal device that the phone line is ringing. In many computer serial ports, a [[hardware interrupt]] is generated when the RI signal changes state. Having support for this hardware interrupt means that a program or operating system can be informed of a change in state of the RI pin, without requiring the software to constantly "poll" the state of the pin. RI is a one-way signal from the modem to the terminal (or more generally, the DCE to the DTE) that does not correspond to another signal that carries similar information the opposite way.

==={{anchor|RI}}Ring Indicator===
[[File:Modem US Robotics Courier Dual Standard.jpg|thumb|right|[[USRobotics]] Courier external modem had a [[DB-25]] connector that used the Ring Indicator signal to notify the host computer when the connected [[telephone line]] was ringing]]
''Ring Indicator'' (RI) is a signal sent from the DCE to the DTE device. It indicates to the terminal device that the phone line is ringing. In many computer serial ports, a [[hardware interrupt]] is generated when the RI signal changes state. Having support for this hardware interrupt means that a program or operating system can be informed of a change in state of the RI pin, without requiring the software to constantly "poll" the state of the pin. RI does not correspond to another signal that carries similar information the opposite way.


On an external modem the status of the Ring Indicator pin is often coupled to the "AA" (auto answer) light, which flashes if the RI signal has detected a ring. The asserted RI signal follows the ringing pattern closely, which can permit software to detect [[distinctive ring]] patterns.
On an external modem the status of the Ring Indicator pin is often coupled to the "AA" (auto answer) light, which flashes if the RI signal has detected a ring. The asserted RI signal follows the ringing pattern closely, which can permit software to detect [[distinctive ring]] patterns.


The Ring Indicator signal is used by some older [[uninterruptible power supply|uninterruptible power supplies]] (UPS's) to signal a power failure state to the computer.
The Ring Indicator signal is used by some older [[uninterruptible power supplies]] (UPSs) to signal a power failure state to the computer.


Certain personal computers can be configured for [[wake-on-ring]], allowing a computer that is suspended to answer a phone call.
Certain personal computers can be configured for [[wake-on-ring]], allowing a computer that is suspended to answer a phone call.


===Cables===
===RTS, CTS, and RTR===
{{further|Flow control (data)#Hardware flow control}}
{{main|Serial cable}}


The Request to Send (RTS) and Clear to Send (CTS) signals were originally defined for use with half-duplex (one direction at a time) modems such as the [[Bell 202]]. These modems disable their transmitters when not required and must transmit a synchronization preamble to the receiver when they are re-enabled. The DTE asserts RTS to indicate a desire to transmit to the DCE, and in response the DCE asserts CTS to grant permission, once synchronization with the DCE at the far end is achieved. Such modems are no longer in common use. There is no corresponding signal that the DTE could use to temporarily halt incoming data from the DCE. Thus RS-232's use of the RTS and CTS signals, per the older versions of the standard, is asymmetric.
The standard does not define a maximum cable length but instead defines the maximum capacitance that a compliant drive circuit must tolerate. A widely used rule of thumb indicates that cables more than {{convert|50|ft}} long will have too much capacitance, unless special cables are used. By using low-capacitance cables, full speed communication can be maintained over larger distances up to about {{convert|1,000|ft}}.<ref>{{cite web |url = http://aplawrence.com/Unixart/serial.art.html |title = Serial Wiring|year=1992|work=A.P. Lawrence |author =Lawrence, Tony|accessdate=28 July 2011}}</ref> For longer distances, other signal standards are better suited to maintain high speed.


This scheme is also employed in present-day RS-232 to [[RS-485]] converters. RS-485 is a multiple-access bus on which only one device can transmit at a time, a concept that is not provided for in RS-232. The RS-232 device asserts RTS to tell the converter to take control of the RS-485 bus so that the converter, and thus the RS-232 device, can send data onto the bus.
Since the standard definitions are not always correctly applied, it is often necessary to consult documentation, test connections with a [[breakout box]], or use trial and error to find a cable that works when interconnecting two devices. Connecting a fully standard-compliant DCE device and DTE device would use a cable that connects identical pin numbers in each connector (a so-called "straight cable"). "[[Gender changer]]s" are available to solve gender mismatches between cables and connectors. Connecting devices with different types of connectors requires a cable that connects the corresponding pins according to the table above. Cables with 9 pins on one end and 25 on the other are common. Manufacturers of equipment with [[8P8C]] connectors usually provide a cable with either a DB-25 or DE-9 connector (or sometimes interchangeable connectors so they can work with multiple devices). Poor-quality cables can cause false signals by [[crosstalk]] between data and control lines (such as [[Ring Indicator]]). If a given cable will not allow a data connection, especially if a [[Gender changer]] is in use, a [[Null modem]] may be necessary.


Modern communications environments use full-duplex (both directions simultaneously) modems. In that environment, DTEs have no reason to deassert RTS. However, due to the possibility of changing line quality, delays in processing of data, etc., there is a need for symmetric, bidirectional [[flow control (data)|flow control]].
==Conventions ==
For functional communication through a serial port interface, conventions of bit rate, character framing, communications protocol, character encoding, data compression, and error detection, not defined in RS 232, must be agreed to by both sending and receiving equipment. For example, consider the [[serial port]]s of the original [[IBM PC]]. This implementation used an [[8250 UART]] using [[asynchronous start-stop]] character formatting with 7 or 8 data bits per frame, usually [[ASCII]] character coding, and data rates programmable between 75 bits per second and 115,200 bits per second. Data rates above 20,000 bits per second are out of the scope of the standard, although higher data rates are sometimes used by commercially manufactured equipment. Since most RS-232 devices do not have [[automatic baud rate detection]], users must manually set the baud rate (and all other parameters) at both ends of the RS-232 connection.


A symmetric alternative providing flow control in both directions was developed and marketed in the late 1980s by various equipment manufacturers. It redefined the RTS signal to mean that the DTE is ready to receive data from the DCE. This scheme was eventually codified in version RS-232-E (actually TIA-232-E by that time) by defining a new signal, "RTR (Ready to Receive)", which is CCITT V.24 circuit 133. TIA-232-E and the corresponding international standards were updated to show that circuit 133, when implemented, shares the same pin as RTS (Request to Send), and that when 133 is in use, RTS is assumed by the DCE to be asserted at all times.<ref>{{cite newsgroup |title=Re: EIA-232 full duplex RTS/CTS flow control standard proposal |author-first=Casey |author-last=Leedom |date=1990-02-20 |newsgroup=comp.dcom.modems |message-id=49249@lll-winken.LLNL.GOV |url=http://groups.google.com/group/comp.dcom.modems/msg/39042605325cc765?dmode=source |access-date=2014-02-03}}</ref>
In the particular case of the IBM PC, as with most UART chips including the [[8250 UART]] used by the IBM PC, baud rates were programmable with arbitrary values. This allowed a PC to be connected to devices not using the rates typically used with [[modem]]s. Not all baud rates can be programmed, due to the clock frequency of the [[8250 UART]] in the PC, and the granularity of the baud rate setting. This includes the baud rate of [[MIDI]], 31,250 bits per second, which is generally not achievable by a standard IBM PC serial port.<ref>''InfoWorld'' 30 Mar 1992 page 80</ref> MIDI-to-RS-232 interfaces designed for the IBM PC include baud rate translation hardware to adjust the baud rate of the MIDI data to something that the IBM PC can support, for example 19,200 or 38,400 bits per second.


In this scheme, commonly called "RTS/CTS flow control" or "RTS/CTS handshaking" (though the technically correct name would be "RTR/CTS"), the DTE asserts RTS whenever it is ready to receive data from the DCE, and the DCE asserts CTS whenever it is ready to receive data from the DTE. Unlike the original use of RTS and CTS with half-duplex modems, these two signals operate independently from one another. This is an example of [[hardware flow control]]. However, "hardware flow control" in the description of the options available on an RS-232-equipped device does not always mean RTS/CTS handshaking.
===RTS/CTS handshaking===
{{Further2|[[Flow control#Hardware flow control|Hardware flow control]]}}
In older versions of the specification, RS-232's use of the RTS and CTS lines is asymmetric: The DTE asserts RTS to indicate a desire to transmit to the DCE, and the DCE asserts CTS in response to grant permission. This allows for half-duplex modems that disable their transmitters when not required, and must transmit a synchronization preamble to the receiver when they are re-enabled. This scheme is also employed on present-day RS-232 to [[RS-485]] converters, where the RS-232's RTS signal is used to ask the converter to take control of the RS-485 bus - a concept that does not otherwise exist in RS-232. There is no way for the DTE to indicate that it is unable to accept data from the DCE.


Equipment using this protocol must be prepared to buffer some extra data, since the remote system may have begun transmitting just before the local system de-asserts RTR.
A non-standard symmetric alternative, commonly called "RTS/CTS handshaking," was developed by various equipment manufacturers. In this scheme, CTS is no longer a response to RTS; instead, CTS indicates permission from the DCE for the DTE to send data to the DCE, and RTS indicates permission from the DTE for the DCE to send data to the DTE. RTS and CTS are controlled by the DTE and DCE respectively, each independent of the other. This was eventually codified in version RS-232-E (actually TIA-232-E by that time) by defining a new signal, "RTR (Ready to Receive)," which is CCITT V.24 circuit 133. TIA-232-E and the corresponding international standards were updated to show that circuit 133, when implemented, shares the same pin as RTS (Request to Send), and that when 133 is in use, RTS is assumed by the DCE to be ON at all times.<ref>{{cite newsgroup
| title = Re: EIA-232 full duplex RTS/CTS flow control standard proposal
| author = ca...@gauss.llnl.gov (Casey Leedom)
| date = 1990-02-20
| newsgroup = comp.dcom.modems
| id = <49249@lll-winken.LLNL.GOV>
| url = http://groups.google.com/group/comp.dcom.modems/msg/39042605325cc765?dmode=source
| accessdate = 2008-04-30}}</ref>

Thus, with this alternative usage, one can think of RTS asserted (positive voltage, logic 0) meaning that the DTE is indicating it is "ready to receive" from the DCE, rather than requesting permission from the DCE to send characters to the DCE.

Note that equipment using this protocol must be prepared to buffer some extra data, since a transmission may have begun just before the control line state change.

RTS/CTS handshaking is an example of [[Flow control#Hardware flow control|hardware flow control]].
However, "hardware flow control" in the description of the options available on an RS-232-equipped device does not always mean RTS/CTS handshaking.


===3-wire and 5-wire RS-232===
===3-wire and 5-wire RS-232===
A minimal "3-wire" RS-232 connection consisting only of transmit data, receive data, and ground, is commonly used when the full facilities of RS-232 are not required. Even a two-wire connection (data and ground) can be used if the data flow is one way (for example, a digital postal scale that periodically sends a weight reading, or a GPS receiver that periodically sends position, if no configuration via RS-232 is necessary). When only hardware flow control is required in addition to two-way data, the RTS and CTS lines are added in a 5-wire version.
A minimal "3-wire" RS-232 connection consisting only of transmit data, receive data, and ground, is commonly used when the full facilities of RS-232 are not required. Even a two-wire connection (data and ground) can be used if the data flow is one way (for example, a digital postal scale that periodically sends a weight reading, or a GPS receiver that periodically sends position, if no configuration via RS-232 is necessary). When only hardware flow control is required in addition to two-way data, the RTS and CTS lines are added in a 5-wire version.


==Seldom used features==
==Seldom-used features==
The EIA-232 standard specifies connections for several features that are not used in most implementations. Their use requires 25-pin connectors and cables.
The EIA-232 standard specifies connections for several features that are not used in most implementations. Their use requires 25-pin connectors and cables.


===Signal rate selection===
===Signal rate selection===
The DTE or DCE can specify use of a "high" or "low" signaling rate. The rates as well as which device will select the rate must be configured in both the DTE and DCE. The prearranged device selects the high rate by setting pin 23 to ON.
The DTE or DCE can specify use of a "high" or "low" signaling rate. The rates, as well as which device will select the rate, must be configured in both the DTE and DCE. The prearranged device selects the high rate by setting the Data Signal Rate Selector (DSRS, pin 23) signal to ON. Sometimes called Data Rate Select (DRS), this signal should not be confused with the more commonly used Data Set Ready (DSR, pin 6).


===Loopback testing===
===Loopback testing===
Many DCE devices have a [[loopback]] capability used for testing. When enabled, signals are echoed back to the sender rather than being sent on to the receiver. If supported, the DTE can signal the local DCE (the one it is connected to) to enter loopback mode by setting pin 18 to ON, or the remote DCE (the one the local DCE is connected to) to enter loopback mode by setting pin 21 to ON. The latter tests the communications link as well as both DCE's. When the DCE is in test mode it signals the DTE by setting pin 25 to ON.
Many DCE devices have a [[loopback]] capability used for testing. When enabled, signals are echoed back to the sender rather than being sent on to the receiver. If supported, the DTE can signal the local DCE (the one it is connected to) to enter loopback mode by setting Local Loop (LL, pin 18) to ON, or the remote DCE (the one the local DCE is connected to) to enter loopback mode by setting Remote Loop (RL, pin 21) to ON. The latter tests the communications link, as well as both DCEs. When the DCE is in test mode, it signals the DTE by setting Test Indicator (TI, pin 25) to ON.


A commonly used version of loopback testing does not involve any special capability of either end. A hardware loopback is simply a wire connecting complementary pins together in the same connector (see ''[[loopback]]'').
A commonly used version of loopback testing does not involve any special capability of either end. A hardware loopback is simply a wire connecting complementary pins together in the same connector (see ''[[loopback]]'').
Line 182: Line 185:


===Timing signals===
===Timing signals===
Some synchronous devices provide a [[clock signal]] to synchronize data transmission, especially at higher data rates. Two timing signals are provided by the DCE on pins 15 and 17. Pin 15 is the transmitter clock, or send timing (ST); the DTE puts the next bit on the data line (pin 2) when this clock transitions from OFF to ON (so it is stable during the ON to OFF transition when the DCE registers the bit). Pin 17 is the receiver clock, or receive timing (RT); the DTE reads the next bit from the data line (pin 3) when this clock transitions from ON to OFF.
Some synchronous devices provide a [[clock signal]] to synchronize data transmission, especially at higher data rates. Two timing signals are provided by the DCE. Pin 15 is the transmitter clock (TCK), or send timing (ST); the DTE puts the next bit on the transmit data line (pin 2) when this clock transitions from OFF to ON (so it is stable during the ON to OFF transition when the DCE registers the bit). Pin 17 is the receiver clock (RCK), or receive timing (RT); the DTE reads the next bit from the receive data line (pin 3) when this clock transitions from ON to OFF.


Alternatively, the DTE can provide a clock signal, called transmitter timing (TT), on pin 24 for transmitted data. Data is changed when the clock transitions from OFF to ON and read during the ON to OFF transition. TT can be used to overcome the issue where ST must traverse a cable of unknown length and delay, clock a bit out of the DTE after another unknown delay, and return it to the DCE over the same unknown cable delay. Since the relation between the transmitted bit and TT can be fixed in the DTE design, and since both signals traverse the same cable length, using TT eliminates the issue. TT may be generated by looping ST back with an appropriate phase change to align it with the transmitted data. ST loop back to TT lets the DTE use the DCE as the frequency reference, and correct the clock to data timing.
Alternatively, the DTE can provide a clock signal, called transmitter timing (TT, pin 24) for transmitted data. Data is changed when the clock transitions from OFF to ON, and read during the ON to OFF transition. TT can be used to overcome the problem of [[propagation delay]] in a long cable. ST must traverse a cable of unknown length and delay, clock a bit out of the DTE after another unknown delay, and return it to the DCE over the same unknown cable delay. When sending data at high speed, the data bit may not arrive in time for the ON to OFF transition of ST.
Since the relation between the transmitted bit and TT can be fixed in the DTE design, and since both signals traverse the same cable length, using TT eliminates the issue. TT may be generated by looping ST back with an appropriate phase change to align it with the transmitted data. ST loop back to TT lets the DTE use the DCE as the frequency reference, and correct the clock to data timing.


Synchronous clocking is required for such protocols as [[Synchronous Data Link Control|SDLC]], [[HDLC]], and [[X.25]].
Synchronous clocking is required for such protocols as [[Synchronous Data Link Control|SDLC]], [[HDLC]], and [[X.25]].


===Secondary channel===
===Secondary channel===
There is a secondary data channel, identical in capability to the first. Five signals (plus the common ground of the primary channel) comprise the secondary channel: Secondary Transmitted Data (STD), Secondary Received Data (SRD), Secondary Request To Send (SRTS), Secondary Clear To Send (SCTS), and Secondary Carrier Detect (SDCD).
A secondary data channel, identical in capability to the primary channel, can optionally be implemented by the DTE and DCE devices. Pin assignments are as follows:
{| class="wikitable" style="margin:auto;"
! Signal !! Pin
|-
| Common Ground || 7 (same as primary)
|-
| Secondary Transmitted Data (STD or S.TxD) || 14
|-
| Secondary Received Data (SRD or S.RxD) || 16
|-
| Secondary Request To Send (SRTS or S.RTS) || 19
|-
| Secondary Clear To Send (SCTS or S.CRS) || 13
|-
| Secondary Carrier Detect (SDCD or S.DCD) || 12
|}


==Related standards==
==Related standards==
Other serial signaling standards may not interoperate with standard-compliant RS-232 ports. For example, using the [[Digital signal#Logic voltage levels|TTL]] levels of near +5 and 0 V puts the mark level in the undefined area of the standard. Such levels are sometimes used with [[NMEA 0183]]-compliant [[Global Positioning System|GPS]] receivers and [[fishfinder|depth finders]].
Other serial signaling standards may not interoperate with standard-compliant RS-232 ports. For example, using the [[TTL serial|TTL level]]s of near +5&nbsp;V and 0&nbsp;V puts the mark level in the undefined area of the standard. Such levels are sometimes used with {{nowrap|[[NMEA 0183]]-compliant}} [[GPS]] receivers and [[fishfinder|depth finder]]s. A chip such as [[MAX232]] is required to convert the voltage levels.


A 20 mA [[current loop]] uses the absence of 20 mA current for high, and the presence of current in the loop for low; this signaling method is often used for long-distance and [[optical isolator|optically isolated]] links. Connection of a current-loop device to a compliant RS-232 port requires a level translator. Current-loop devices can supply voltages in excess of the withstand voltage limits of a compliant device. The original IBM PC [[serial port]] card implemented a 20 mA current-loop interface, which was never emulated by other suppliers of [[plug-compatible]] equipment.
A 20&nbsp;mA [[digital current loop interface|current loop]] uses the absence of 20&nbsp;mA current for high, and the presence of current in the loop for low; this signaling method is often used for long-distance and [[opto-isolator|optically isolated]] links. Connection of a current-loop device to a compliant RS-232 port requires a level translator. Current-loop devices can supply voltages in excess of the must-withstand voltage limits of a compliant device. The original IBM PC serial port card implemented a 20&nbsp;mA current-loop interface, which was never emulated by other suppliers of [[plug-compatible]] equipment.


Other serial interfaces similar to RS-232:
Other serial interfaces similar to RS-232:
*[[RS-422]] (a high-speed system similar to RS-232 but with [[differential signaling]])
*[[RS-422]] a high-speed system similar to RS-232 but with [[differential signaling]]
*[[RS-423]] (a high-speed system similar to RS-422 but with [[Unbalanced line|unbalanced signaling]])
*[[RS-423]] a high-speed system similar to RS-422 but with [[unbalanced signaling]]
*[[RS-449]] (a functional and mechanical interface that used RS-422 and RS-423 signals - it never caught on like RS-232 and was withdrawn by the EIA)
*[[RS-449]] a functional and mechanical interface that used RS-422 and RS-423 signals; never caught on like RS-232 and was withdrawn by the EIA
*[[RS-485]] (a descendant of RS-422 that can be used as a bus in multidrop configurations)
*[[RS-485]] a descendant of RS-422 that can be used as a bus in multidrop configurations
*[[MIL-STD-188]] (a system like RS-232 but with better impedance and rise time control)
*[[MIL-STD-188]] a system like RS-232 but with better impedance and rise time control. One very significant difference: RS-232 uses a positive voltage to indicate a 0 and a negative voltage to indicate a 1. MIL-STD-188 uses a negative voltage for 0 and a positive voltage for a 1.
*[[EIA-530]] (a high-speed system using RS-422 or RS-423 electrical properties in an EIA-232 pinout configuration, thus combining the best of both; supersedes RS-449)
*[[EIA-530]] a high-speed system using RS-422 or RS-423 electrical properties in an EIA-232 pinout configuration, thus combining the best of both; supersedes RS-449
*[[EIA/TIA-561]] – defines RS-232 pinouts for [[Modular connector#8P8C|eight-position, eight-contact (8P8C) modular connectors]] (which may be improperly called RJ45 connectors)
*[[EIA/TIA-561]] 8 Position Non-Synchronous Interface Between Data Terminal Equipment and Data Circuit Terminating Equipment Employing Serial Binary Data Interchange
*[[EIA/TIA-562]] Electrical Characteristics for an Unbalanced Digital Interface (low-voltage version of EIA/TIA-232)
*[[EIA/TIA-562]] low-voltage version of EIA/TIA-232
*TIA-574 (standardizes the 9-pin D-subminiature connector pinout for use with EIA-232 electrical signalling, as originated on the IBM PC/AT)
*TIA-574 standardizes the 9-pin D-subminiature connector pinout for use with EIA-232 electrical signalling, as originated on the IBM PC/AT
*[[EIA/TIA-694]] – similar to TIA/EIA-232-F but with support for higher data rates up to {{nowrap|512 kbit/s}}
*[[SpaceWire]] (high-speed serial system designed for use on board [[spacecraft]]).

The [[International Telecommunication Union]] publishes standard ITR-R V.24 (formerly CCITT standard V.24), "List of Definitions for Interchange Circuits between Data Terminal Equipment (DTE) and Data Circuit-Terminating Equipment (DCE)" with circuit definitions compatible to those in EIA RS 232. V.24 does not specify signal levels or timing. Electrical parameters for signals are specified in ITU-R-V.28.


==Development tools==
==Development tools==
When developing or troubleshooting systems using RS-232, close examination of hardware signals can be important to find problems. A [[serial line analyzer]] is a device similar to a [[logic analyzer]] but specialized for RS-232's voltage levels, connectors, and, where used, clock signals. The serial line analyzer can collect, store, and display the data and control signals, allowing developers to view them in detail. Some simply display the signals as waveforms; more elaborate versions include the ability to decode characters in [[ASCII]] or other common codes and to interpret common protocols used over RS-232 such as [[Synchronous Data Link Control|SDLC]], [[HDLC]], [[DDCMP]], and [[X.25]]. Serial line analyzers are available as standalone units, as software and interface cables for general-purpose logic analyzers, and as programs that run in common [[personal computer]]s.
When developing or troubleshooting systems using RS-232, close examination of hardware signals can be important to find problems. This can be done using simple devices with LEDs that indicate the logic levels of data and control signals. [[Y-Cable|"Y" cables]] may be used to allow using another serial port to monitor all traffic on one direction. A [[serial line analyzer]] is a device similar to a [[logic analyzer]] but specialized for RS-232's voltage levels, connectors, and, where used, clock signals; it collects, stores, and displays the data and control signals, allowing developers to view them in detail. Some simply display the signals as waveforms; more elaborate versions include the ability to decode characters in [[ASCII]] or other common codes and to interpret common protocols used over RS-232 such as [[Synchronous Data Link Control|SDLC]], [[HDLC]], [[DDCMP]], and [[X.25]]. Serial line analyzers are available as standalone units, as software and interface cables for general-purpose [[logic analyzer]]s and [[oscilloscope]]s, and as programs that run on common personal computers and devices.

==See also==
* [[Comparison of synchronous and asynchronous signalling]]


==References==
==References==
{{reflist}}
{{Reflist}}


==Further reading==
{{Commons category|RS-232}}
*{{cite book |title=Serial Port Complete: COM Ports, USB Virtual COM Ports, and Ports for Embedded Systems |edition=2nd |author-first=Jan |author-last=Axelson |publisher=Lakeview Research |date=2007 |isbn=978-1-931-44806-2}}
{{Wikibooks|Serial Programming:RS-232 Connections}}
*{{cite tech report |title=Interface Circuits for TIA/EIA-232-F: Design Notes |work=Mixed-Signal Products |id=SLLA037 |date=September 2002 |publisher=[[Texas Instruments]] |url=http://www.ti.com/lit/an/slla037a/slla037a.pdf |access-date=2017-03-05 |url-status=live |archive-url=https://web.archive.org/web/20170305040927/http://www.ti.com/lit/an/slla037a/slla037a.pdf |archive-date=2017-03-05}}
*{{cite book |title=Fundamentals of RS–232 Serial Communications |id=Application Note 83 |publisher=[[Dallas Semiconductor]] |date=1998-03-09<!-- or 1998-09-03? --> |url=http://ecee.colorado.edu/~mcclurel/dan83.pdf |access-date=2017-03-05 |url-status=live |archive-url=https://web.archive.org/web/20170305041309/http://ecee.colorado.edu/~mcclurel/dan83.pdf |archive-date=2017-03-05}}
* {{cite web |title=RS232C Standard |work=Knowledgebase |publisher=[[National Instruments]] |url=http://digital.ni.com/public.nsf/allkb/1C8F13D0806056F886256FAC00649176 |access-date=2017-03-05 |url-status=live |archive-url=https://web.archive.org/web/20170305224454/http://digital.ni.com/public.nsf/allkb/1C8F13D0806056F886256FAC00649176 |archive-date=2017-03-05}}
* {{cite book|title=ITU-T Recommendation V.24 - Data Communication over the telephone network - List of definitions for interchange circuits between data terminal equipment (DTE) and data circuit-terminating equipment (DCE) |publisher=[[International Telecommunication Union]] (ITU-T) |date=March 1993 |url=https://www.itu.int/rec/dologin_pub.asp?lang=e&id=T-REC-V.24-199303-S!!PDF-E&type=items |access-date=2017-03-05 |url-status=live |archive-url=https://web.archive.org/web/20150817230221/http://www.itu.int/rec/dologin_pub.asp?lang=e&id=T-REC-V.24-199303-S%21%21PDF-E&type=items |archive-date=2015-08-17 }}

==External links==
{{Commons category multi|RS-232|RS-232 Data packet}}
* {{Wikibooks-inline|Serial Programming:RS-232 Connections}}


{{DEFAULTSORT:Rs-232}}
{{DEFAULTSORT:Rs-232}}
Line 221: Line 254:
[[Category:Computer hardware standards]]
[[Category:Computer hardware standards]]
[[Category:Networking standards]]
[[Category:Networking standards]]
[[Category:EIA standards]]

[[Category:Computer-related introductions in 1960]]
[[ar:آر إس 232]]
[[ca:RS-232]]
[[cs:RS-232]]
[[da:RS-232]]
[[de:RS-232]]
[[et:RS-232]]
[[el:RS-232]]
[[es:RS-232]]
[[eo:RS-232]]
[[eu:RS-232]]
[[fr:RS-232]]
[[ko:RS-232]]
[[hr:RS-232]]
[[id:RS-232]]
[[it:EIA RS-232]]
[[he:RS-232]]
[[kk:Мәліметтерді жеткізуге даярлық]]
[[hu:RS-232]]
[[ms:RS-232]]
[[nl:RS-232]]
[[ja:RS-232]]
[[no:RS-232]]
[[nn:RS-232]]
[[pl:RS-232]]
[[pt:RS-232]]
[[ru:RS-232]]
[[fi:RS-232]]
[[sv:RS-232]]
[[tr:RS-232]]
[[uk:RS-232]]
[[zh:RS-232]]

Latest revision as of 15:04, 30 December 2024

A DB-25 connector as described in the RS-232 standard
Data circuit-terminating equipment (DCE) and data terminal equipment (DTE) network

In telecommunications, RS-232 or Recommended Standard 232[1] is a standard originally introduced in 1960[2] for serial communication transmission of data. It formally defines signals connecting between a DTE (data terminal equipment) such as a computer terminal or PC, and a DCE (data circuit-terminating equipment or data communication equipment), such as a modem. The standard defines the electrical characteristics and timing of signals, the meaning of signals, and the physical size and pinout of connectors. The current version of the standard is TIA-232-F Interface Between Data Terminal Equipment and Data Circuit-Terminating Equipment Employing Serial Binary Data Interchange, issued in 1997.

The RS-232 standard had been commonly used with serial ports and serial cables. It is still widely used in industrial communication devices.

A serial port complying with the RS-232 standard was once a standard feature of many types of computers. Personal computers used them for connections not only to modems, but also to printers, computer mice, data storage, uninterruptible power supplies, and other peripheral devices.

Compared with later interfaces such as RS-422, RS-485 and Ethernet, RS-232 has lower transmission speed, shorter maximum cable length, larger voltage swing, larger standard connectors, no multipoint capability and limited multidrop capability. In modern personal computers, USB has displaced RS-232 from most of its peripheral interface roles. Thanks to their simplicity and past ubiquity, however, RS-232 interfaces are still used—particularly in industrial CNC machines, networking equipment and scientific instruments where a short-range, point-to-point, low-speed wired data connection is fully adequate.[3]

Scope of the standard

[edit]

The Electronic Industries Association (EIA) standard RS-232-C[4] as of 1969 defines:

  • Electrical signal characteristics such as logic levels, baud rate, timing, and slew rate of signals, voltage withstand level, short-circuit behavior, and maximum load capacitance.
  • Interface mechanical characteristics, pluggable connectors and pin identification.
  • Functions of each circuit in the interface connector.
  • Standard subsets of interface circuits for selected telecom applications.

The standard does not define such elements as the character encoding (i.e. ASCII, EBCDIC, or others), the framing of characters (start or stop bits, etc.), transmission order of bits, or error detection protocols. The character format and transmission bit rate are set by the serial port hardware, typically a UART, which may also contain circuits to convert the internal logic levels to RS-232 compatible signal levels. The standard does not define bit rates for transmission, except that it says it is intended for bit rates lower than 20,000 bits per second.

History

[edit]

RS-232 was first introduced in 1960[2] by the Electronic Industries Association (EIA) as a Recommended Standard.[5][1] The original DTEs were electromechanical teletypewriters, and the original DCEs were (usually) modems. When electronic terminals (smart and dumb) began to be used, they were often designed to be interchangeable with teletypewriters, and so supported RS-232.

Because the standard did not foresee the requirements of devices such as computers, printers, test instruments, POS terminals, and so on, designers implementing an RS-232 compatible interface on their equipment often interpreted the standard idiosyncratically. The resulting common problems were non-standard pin assignment of circuits on connectors, and incorrect or missing control signals. The lack of adherence to the standards produced a thriving industry of breakout boxes, patch boxes, test equipment, books, and other aids for the connection of disparate equipment. A common deviation from the standard was to drive the signals at a reduced voltage. Some manufacturers therefore built transmitters that supplied +5 V and −5 V and labeled them as "RS-232 compatible".[citation needed]

Later personal computers (and other devices) started to make use of the standard so that they could connect to existing equipment. For many years, an RS-232-compatible port was a standard feature for serial communications, such as modem connections, on many computers (with the computer acting as the DTE). It remained in widespread use into the late 1990s. In personal computer peripherals, it has largely been supplanted by other interface standards, such as USB. RS-232 is still used to connect older designs of peripherals, industrial equipment (such as PLCs), console ports, and special purpose equipment.

The standard has been renamed several times during its history as the sponsoring organization changed its name, and has been variously known as EIA RS-232, EIA 232, and, most recently as TIA 232. The standard continued to be revised and updated by the Electronic Industries Association and since 1988 by the Telecommunications Industry Association (TIA).[6] Revision C was issued in a document dated August 1969. Revision D was issued in 1986. The current revision is TIA-232-F Interface Between Data Terminal Equipment and Data Circuit-Terminating Equipment Employing Serial Binary Data Interchange, issued in 1997. Changes since Revision C have been in timing and details intended to improve harmonization with the CCITT standard ITU-T/CCITT V.24 [de], but equipment built to the current standard will interoperate with older versions.[citation needed]

Related ITU-T standards include V.24 (circuit identification) and ITU-T/CCITT V.28 [de] (signal voltage and timing characteristics).[citation needed]

In revision D of EIA-232, the D-subminiature connector was formally included as part of the standard (it was only referenced in the appendix of RS-232-C). The voltage range was extended to ±25 volts, and the circuit capacitance limit was expressly stated as 2500 pF. Revision E of EIA-232 introduced a new, smaller, standard D-shell 26-pin "Alt A" connector, and made other changes to improve compatibility with CCITT standards V.24, V.28 and ISO 2110.[7]

Specification document revision history:

  • EIA RS-232 (May 1960) "Interface Between Data Terminal Equipment & Data"[2]
  • EIA RS-232-A (October 1963)[2]
  • EIA RS-232-B (October 1965)[2]
  • EIA RS-232-C (August 1969) "Interface Between Data Terminal Equipment and Data Communication Equipment Employing Serial Binary Data Interchange"[2]
  • EIA EIA-232-D (1986)
  • TIA TIA/EIA-232-E (1991) "Interface Between Data Terminal Equipment and Data Communications Equipment Employing Serial Binary Data Interchange"
  • TIA TIA/EIA-232-F (October 1997)
  • ANSI/TIA-232-F-1997 (R2002)
  • TIA TIA-232-F (R2012)

Limitations of the standard

[edit]

Because RS-232 is used beyond the original purpose of interconnecting a terminal with a modem, successor standards have been developed to address the limitations. Issues with the RS-232 standard include:[8]

  • The large voltage swings and requirement for positive and negative supplies increases power consumption of the interface and complicates power supply design. The voltage swing requirement also limits the upper speed of a compatible interface.
  • Single-ended signaling referred to a common signal ground limits the noise immunity and transmission distance.
  • Multi-drop connection among more than two devices is not defined. While multi-drop "work-arounds" have been devised, they have limitations in speed and compatibility.
  • The standard does not address the possibility of connecting a DTE directly to a DTE, or a DCE to a DCE. Null modem cables can be used to achieve these connections, but these are not defined by the standard, and some such cables use different connections than others.
  • The definitions of the two ends of the link are asymmetric. This makes the assignment of the role of a newly developed device problematic; the designer must decide on either a DTE-like or DCE-like interface and which connector pin assignments to use.
  • The Handshaking and control lines of the interface are intended for the setup and takedown of a dial-up communication circuit; in particular, the use of handshake lines for flow control is not reliably implemented in many devices.
  • No method is specified for sending power to a device. While a small amount of current can be extracted from the DTR and RTS lines, this is only suitable for low-power devices such as mice.
  • The 25-pin D-sub connector recommended in the standard is large compared to current practice.

Role in modern personal computers

[edit]
PCI Express x1 card with one RS-232 port on a nine-pin connector

In the book PC 97 Hardware Design Guide,[9] Microsoft deprecated support for the RS-232 compatible serial port of the original IBM PC design. Today, RS-232 has mostly been replaced in personal computers by USB for local communications. Advantages compared to RS-232 are that USB is faster, uses lower voltages, and has connectors that are simpler to connect and use. Disadvantages of USB compared to RS-232 are that USB is far less immune to electromagnetic interference (EMI) and that maximum cable length defined by standards is much shorter (15 meters for RS-232 versus 3–5 meters for USB, depending on the USB version and use of active cables). RS-232 cable lengths of 2000 meters are possible with appropriate line drivers.[10][11]

In fields such as laboratory automation or surveying, RS-232 devices continue to be used. Some types of programmable logic controllers, variable-frequency drives, servo drives, and computerized numerical control equipment are programmable via RS-232. Computer manufacturers have responded to this demand by re-introducing the DE-9M connector on their computers or by making adapters available.

RS-232 ports are also commonly used to communicate to headless systems such as servers, where no monitor or keyboard is installed, during boot when an operating system is not yet running and therefore no network connection is possible. A computer with an RS-232 serial port can communicate with the serial port of an embedded system (such as a router) as an alternative to monitoring over Ethernet.

Physical interface

[edit]

In RS-232, user data is sent as a time-series of bits. Both synchronous and asynchronous transmissions are supported by the standard. In addition to the data circuits, the standard defines a number of control circuits used to manage the connection between the DTE and DCE. Each data or control circuit only operates in one direction, that is, signaling from a DTE to the attached DCE or the reverse. Because transmit data and receive data are separate circuits, the interface can operate in a full duplex manner, supporting concurrent data flow in both directions. The standard does not define character framing within the data stream or character encoding.

Voltage levels

[edit]
Diagrammatic oscilloscope trace of voltage levels for an ASCII "K" character (4Bh = 01001011b) with 1 start bit, 8 data bits (least significant bit first), 1 stop bit. This is typical for start-stop communications, but the standard does not dictate a character format or bit order.
RS-232 data line on the terminals of the receiver side (RxD) probed by an oscilloscope (for an ASCII "K" character (4Bh = 01001011b) with 1 start bit, 8 data bits, 1 stop bit, and no parity bits)

The RS-232 standard defines the voltage levels that correspond to logical one and logical zero levels for the data transmission and the control signal lines. Valid signals are either in the range of +3 to +15 volts or the range −3 to −15 volts with respect to the "Common Ground" (GND) pin; consequently, the range between −3 and +3 volts is not a valid RS-232 level. For data transmission lines (TxD, RxD, and their secondary channel equivalents), logic one is represented as a negative voltage and the signal condition is called "mark". Logic zero is signaled with a positive voltage and the signal condition is termed "space". Control signals have the opposite polarity: the asserted or active state is positive voltage and the de-asserted or inactive state is negative voltage. Examples of control lines include request to send (RTS), clear to send (CTS), data terminal ready (DTR), and data set ready (DSR).

RS-232 logic and voltage levels
Data circuits Control circuits Voltage
0 (space) Asserted +3 to +15 V
1 (mark) Deasserted −15 to −3 V

The standard specifies a maximum open-circuit voltage of 25 volts: signal levels of ±5 V, ±10 V, ±12 V, and ±15 V are all commonly seen depending on the voltages available to the line driver circuit. Many RS-232 driver chips have inbuilt charge pump circuitry to produce the required voltages from a 3 or 5 volt supply. RS-232 drivers and receivers must be able to withstand indefinite short circuits to the ground or to any voltage level up to ±25 volts. The slew rate, or how fast the signal changes between levels, is also controlled.

Because the voltage levels are higher than logic levels typically used by integrated circuits, special intervening driver circuits are required to translate logic levels. These also protect the device's internal circuitry from short circuits or transients that may appear on the RS-232 interface, and provide sufficient current to comply with the slew rate requirements for data transmission.

Because both ends of the RS-232 circuit depend on the ground pin being zero volts, problems will occur when connecting machinery and computers where the voltage between the ground pin on one end, and the ground pin on the other is not zero. This may also cause a hazardous ground loop. Use of a common ground limits RS-232 to applications with relatively short cables. If the two devices are far enough apart or on separate power systems, the local ground connections at either end of the cable will have differing voltages; this difference will reduce the noise margin of the signals. Balanced, differential serial connections such as RS-422 or RS-485 can tolerate larger ground voltage differences because of the differential signaling.[12]

Unused interface signals terminated to the ground will have an undefined logic state. Where it is necessary to permanently set a control signal to a defined state, it must be connected to a voltage source that asserts the logic 1 or logic 0 levels, for example with a pull-up resistor. Some devices provide test voltages on their interface connectors for this purpose.

Connectors

[edit]

RS-232 devices may be classified as Data Terminal Equipment (DTE) or Data Circuit-terminating Equipment (DCE); this defines at each device which wires will be sending and receiving each signal. According to the standard, male connectors have DTE pin functions, and female connectors have DCE pin functions. Other devices may have any combination of connector gender and pin definitions. Many terminals were manufactured with female connectors but were sold with a cable with male connectors at each end; the terminal with its cable satisfied the recommendations in the standard.

The standard recommends the D-subminiature 25-pin connector up to revision C, and makes it mandatory as of revision D. Most devices only implement a few of the twenty signals specified in the standard, so connectors and cables with fewer pins are sufficient for most connections, more compact, and less expensive. Personal computer manufacturers replaced the DB-25M connector with the smaller DE-9M connector. This connector, with a different pinout (see Serial port pinouts), is prevalent for personal computers and associated devices.

Presence of a 25-pin D-sub connector does not necessarily indicate an RS-232-C compliant interface. For example, on the original IBM PC, a male D-sub was an RS-232-C DTE port (with a non-standard current loop interface on reserved pins), but the female D-sub connector on the same PC model was used for the parallel "Centronics" printer port. Some personal computers put non-standard voltages or signals on some pins of their serial ports.

Cables

[edit]

The standard does not define a maximum cable length, but instead defines the maximum capacitance that a compliant drive circuit must tolerate. A widely used rule of thumb indicates that cables more than 15 m (50 ft) long will have too much capacitance, unless special cables are used. By using low-capacitance cables, communication can be maintained over larger distances up to about 300 m (1,000 ft).[13] For longer distances, other signal standards, such as RS-422, are better suited for higher speeds.

Since the standard definitions are not always correctly applied, it is often necessary to consult documentation, test connections with a breakout box, or use trial and error to find a cable that works when interconnecting two devices. Connecting a fully standard-compliant DCE device and DTE device would use a cable that connects identical pin numbers in each connector (a so-called "straight cable"). "Gender changers" are available to solve gender mismatches between cables and connectors. Connecting devices with different types of connectors requires a cable that connects the corresponding pins according to the table below. Cables with 9 pins on one end and 25 on the other are common. Manufacturers of equipment with 8P8C connectors usually provide a cable with either a DB-25 or DE-9 connector (or sometimes interchangeable connectors so they can work with multiple devices). Poor-quality cables can cause false signals by crosstalk between data and control lines (such as Ring Indicator).

If a given cable will not allow a data connection, especially if a gender changer is in use, a null modem cable may be necessary. Gender changers and null modem cables are not mentioned in the standard, so there is no officially sanctioned design for them.

Data and control signals

[edit]
Male pinout of a 25-pin serial port (D-subminiature, DB-25) commonly found on 1980s computers

The following table lists commonly used RS-232 signals (called "circuits" in the specifications) and their pin assignments on the recommended DB-25 connectors[14] (see Serial port pinouts for other commonly used connectors not defined by the standard).

Circuit Direction DB-25 pin
Name Typical purpose Abbreviation DTE DCE
Data Terminal Ready DTE is ready to receive, initiate, or continue a call. DTR Out In 20
Data Carrier Detect DCE is receiving a carrier from a remote DCE. DCD In Out 8
Data Set Ready DCE is ready to receive and send data. DSR In Out 6
Ring Indicator DCE has detected an incoming ring signal on the telephone line. RI In Out 22
Request To Send DTE requests the DCE prepare to transmit data. RTS Out In 4
Ready To Receive DTE is ready to receive data from DCE. If in use, RTS is assumed to be always asserted. RTR Out In 4
Clear To Send DCE is ready to accept data from the DTE. CTS In Out 5
Transmitted Data Carries data from DTE to DCE. TxD Out In 2
Received Data Carries data from DCE to DTE. RxD In Out 3
Common Ground Zero voltage reference for all of the above. GND Common 7
Protective Ground Connected to chassis ground. PG Common 1

The signals are named from the standpoint of the DTE. The ground pin is a common return for the other connections, and establishes the "zero" voltage to which voltages on the other pins are referenced. The DB-25 connector includes a second "protective ground" on pin 1; this is connected internally to equipment frame ground, and should not be connected in the cable or connector to signal ground.

Ring Indicator

[edit]
USRobotics Courier external modem had a DB-25 connector that used the Ring Indicator signal to notify the host computer when the connected telephone line was ringing

Ring Indicator (RI) is a signal sent from the DCE to the DTE device. It indicates to the terminal device that the phone line is ringing. In many computer serial ports, a hardware interrupt is generated when the RI signal changes state. Having support for this hardware interrupt means that a program or operating system can be informed of a change in state of the RI pin, without requiring the software to constantly "poll" the state of the pin. RI does not correspond to another signal that carries similar information the opposite way.

On an external modem the status of the Ring Indicator pin is often coupled to the "AA" (auto answer) light, which flashes if the RI signal has detected a ring. The asserted RI signal follows the ringing pattern closely, which can permit software to detect distinctive ring patterns.

The Ring Indicator signal is used by some older uninterruptible power supplies (UPSs) to signal a power failure state to the computer.

Certain personal computers can be configured for wake-on-ring, allowing a computer that is suspended to answer a phone call.

RTS, CTS, and RTR

[edit]

The Request to Send (RTS) and Clear to Send (CTS) signals were originally defined for use with half-duplex (one direction at a time) modems such as the Bell 202. These modems disable their transmitters when not required and must transmit a synchronization preamble to the receiver when they are re-enabled. The DTE asserts RTS to indicate a desire to transmit to the DCE, and in response the DCE asserts CTS to grant permission, once synchronization with the DCE at the far end is achieved. Such modems are no longer in common use. There is no corresponding signal that the DTE could use to temporarily halt incoming data from the DCE. Thus RS-232's use of the RTS and CTS signals, per the older versions of the standard, is asymmetric.

This scheme is also employed in present-day RS-232 to RS-485 converters. RS-485 is a multiple-access bus on which only one device can transmit at a time, a concept that is not provided for in RS-232. The RS-232 device asserts RTS to tell the converter to take control of the RS-485 bus so that the converter, and thus the RS-232 device, can send data onto the bus.

Modern communications environments use full-duplex (both directions simultaneously) modems. In that environment, DTEs have no reason to deassert RTS. However, due to the possibility of changing line quality, delays in processing of data, etc., there is a need for symmetric, bidirectional flow control.

A symmetric alternative providing flow control in both directions was developed and marketed in the late 1980s by various equipment manufacturers. It redefined the RTS signal to mean that the DTE is ready to receive data from the DCE. This scheme was eventually codified in version RS-232-E (actually TIA-232-E by that time) by defining a new signal, "RTR (Ready to Receive)", which is CCITT V.24 circuit 133. TIA-232-E and the corresponding international standards were updated to show that circuit 133, when implemented, shares the same pin as RTS (Request to Send), and that when 133 is in use, RTS is assumed by the DCE to be asserted at all times.[15]

In this scheme, commonly called "RTS/CTS flow control" or "RTS/CTS handshaking" (though the technically correct name would be "RTR/CTS"), the DTE asserts RTS whenever it is ready to receive data from the DCE, and the DCE asserts CTS whenever it is ready to receive data from the DTE. Unlike the original use of RTS and CTS with half-duplex modems, these two signals operate independently from one another. This is an example of hardware flow control. However, "hardware flow control" in the description of the options available on an RS-232-equipped device does not always mean RTS/CTS handshaking.

Equipment using this protocol must be prepared to buffer some extra data, since the remote system may have begun transmitting just before the local system de-asserts RTR.

3-wire and 5-wire RS-232

[edit]

A minimal "3-wire" RS-232 connection consisting only of transmit data, receive data, and ground, is commonly used when the full facilities of RS-232 are not required. Even a two-wire connection (data and ground) can be used if the data flow is one way (for example, a digital postal scale that periodically sends a weight reading, or a GPS receiver that periodically sends position, if no configuration via RS-232 is necessary). When only hardware flow control is required in addition to two-way data, the RTS and CTS lines are added in a 5-wire version.

Seldom-used features

[edit]

The EIA-232 standard specifies connections for several features that are not used in most implementations. Their use requires 25-pin connectors and cables.

Signal rate selection

[edit]

The DTE or DCE can specify use of a "high" or "low" signaling rate. The rates, as well as which device will select the rate, must be configured in both the DTE and DCE. The prearranged device selects the high rate by setting the Data Signal Rate Selector (DSRS, pin 23) signal to ON. Sometimes called Data Rate Select (DRS), this signal should not be confused with the more commonly used Data Set Ready (DSR, pin 6).

Loopback testing

[edit]

Many DCE devices have a loopback capability used for testing. When enabled, signals are echoed back to the sender rather than being sent on to the receiver. If supported, the DTE can signal the local DCE (the one it is connected to) to enter loopback mode by setting Local Loop (LL, pin 18) to ON, or the remote DCE (the one the local DCE is connected to) to enter loopback mode by setting Remote Loop (RL, pin 21) to ON. The latter tests the communications link, as well as both DCEs. When the DCE is in test mode, it signals the DTE by setting Test Indicator (TI, pin 25) to ON.

A commonly used version of loopback testing does not involve any special capability of either end. A hardware loopback is simply a wire connecting complementary pins together in the same connector (see loopback).

Loopback testing is often performed with a specialized DTE called a bit error rate tester (or BERT).

Timing signals

[edit]

Some synchronous devices provide a clock signal to synchronize data transmission, especially at higher data rates. Two timing signals are provided by the DCE. Pin 15 is the transmitter clock (TCK), or send timing (ST); the DTE puts the next bit on the transmit data line (pin 2) when this clock transitions from OFF to ON (so it is stable during the ON to OFF transition when the DCE registers the bit). Pin 17 is the receiver clock (RCK), or receive timing (RT); the DTE reads the next bit from the receive data line (pin 3) when this clock transitions from ON to OFF.

Alternatively, the DTE can provide a clock signal, called transmitter timing (TT, pin 24) for transmitted data. Data is changed when the clock transitions from OFF to ON, and read during the ON to OFF transition. TT can be used to overcome the problem of propagation delay in a long cable. ST must traverse a cable of unknown length and delay, clock a bit out of the DTE after another unknown delay, and return it to the DCE over the same unknown cable delay. When sending data at high speed, the data bit may not arrive in time for the ON to OFF transition of ST.

Since the relation between the transmitted bit and TT can be fixed in the DTE design, and since both signals traverse the same cable length, using TT eliminates the issue. TT may be generated by looping ST back with an appropriate phase change to align it with the transmitted data. ST loop back to TT lets the DTE use the DCE as the frequency reference, and correct the clock to data timing.

Synchronous clocking is required for such protocols as SDLC, HDLC, and X.25.

Secondary channel

[edit]

A secondary data channel, identical in capability to the primary channel, can optionally be implemented by the DTE and DCE devices. Pin assignments are as follows:

Signal Pin
Common Ground 7 (same as primary)
Secondary Transmitted Data (STD or S.TxD) 14
Secondary Received Data (SRD or S.RxD) 16
Secondary Request To Send (SRTS or S.RTS) 19
Secondary Clear To Send (SCTS or S.CRS) 13
Secondary Carrier Detect (SDCD or S.DCD) 12
[edit]

Other serial signaling standards may not interoperate with standard-compliant RS-232 ports. For example, using the TTL levels of near +5 V and 0 V puts the mark level in the undefined area of the standard. Such levels are sometimes used with NMEA 0183-compliant GPS receivers and depth finders. A chip such as MAX232 is required to convert the voltage levels.

A 20 mA current loop uses the absence of 20 mA current for high, and the presence of current in the loop for low; this signaling method is often used for long-distance and optically isolated links. Connection of a current-loop device to a compliant RS-232 port requires a level translator. Current-loop devices can supply voltages in excess of the must-withstand voltage limits of a compliant device. The original IBM PC serial port card implemented a 20 mA current-loop interface, which was never emulated by other suppliers of plug-compatible equipment.

Other serial interfaces similar to RS-232:

  • RS-422 – a high-speed system similar to RS-232 but with differential signaling
  • RS-423 – a high-speed system similar to RS-422 but with unbalanced signaling
  • RS-449 – a functional and mechanical interface that used RS-422 and RS-423 signals; never caught on like RS-232 and was withdrawn by the EIA
  • RS-485 – a descendant of RS-422 that can be used as a bus in multidrop configurations
  • MIL-STD-188 – a system like RS-232 but with better impedance and rise time control. One very significant difference: RS-232 uses a positive voltage to indicate a 0 and a negative voltage to indicate a 1. MIL-STD-188 uses a negative voltage for 0 and a positive voltage for a 1.
  • EIA-530 – a high-speed system using RS-422 or RS-423 electrical properties in an EIA-232 pinout configuration, thus combining the best of both; supersedes RS-449
  • EIA/TIA-561 – defines RS-232 pinouts for eight-position, eight-contact (8P8C) modular connectors (which may be improperly called RJ45 connectors)
  • EIA/TIA-562 – low-voltage version of EIA/TIA-232
  • TIA-574 – standardizes the 9-pin D-subminiature connector pinout for use with EIA-232 electrical signalling, as originated on the IBM PC/AT
  • EIA/TIA-694 – similar to TIA/EIA-232-F but with support for higher data rates up to 512 kbit/s

The International Telecommunication Union publishes standard ITR-R V.24 (formerly CCITT standard V.24), "List of Definitions for Interchange Circuits between Data Terminal Equipment (DTE) and Data Circuit-Terminating Equipment (DCE)" with circuit definitions compatible to those in EIA RS 232. V.24 does not specify signal levels or timing. Electrical parameters for signals are specified in ITU-R-V.28.

Development tools

[edit]

When developing or troubleshooting systems using RS-232, close examination of hardware signals can be important to find problems. This can be done using simple devices with LEDs that indicate the logic levels of data and control signals. "Y" cables may be used to allow using another serial port to monitor all traffic on one direction. A serial line analyzer is a device similar to a logic analyzer but specialized for RS-232's voltage levels, connectors, and, where used, clock signals; it collects, stores, and displays the data and control signals, allowing developers to view them in detail. Some simply display the signals as waveforms; more elaborate versions include the ability to decode characters in ASCII or other common codes and to interpret common protocols used over RS-232 such as SDLC, HDLC, DDCMP, and X.25. Serial line analyzers are available as standalone units, as software and interface cables for general-purpose logic analyzers and oscilloscopes, and as programs that run on common personal computers and devices.

See also

[edit]

References

[edit]
  1. ^ a b Metering Glossary Archived 2012-11-29 at the Wayback Machine Landis + Gyr Tutorial (see EIA)
  2. ^ a b c d e f Evans, Jr., John M.; O'Neill, Joseph T.; Little, John L.; Albus, James S.; Barbera, Anthony J.; Fife, Dennis W.; Fong, Elizabeth N.; Gilsinn, David E.; Holberton, Frances E.; Lucas, Brian G.; Lyon, Gordon E.; Marron, Beatrice A. S.; Neumann, Albercht J.; Vickers, Mabel V.; Walker, Justin C. (October 1976), Standards for Computer Aided Manufacturing (Second Interim Report ed.), Office of Developmental Automation and Control Technology, Institute for Computer Sciences and Technology, National Bureau of Standards, Washington, DC, USA: Manufacturing Technology Division, Air Force Materials Laboratory, Wright-Patterson Air Force Base, Ohio 45433, NBSIR 76-1094, retrieved 2017-03-04
  3. ^ "Connecting the Beast?". This Old Mill. 2017-03-28. Retrieved 2023-06-08.
  4. ^ EIA standard RS-232-C: Interface between Data Terminal Equipment and Data Communication Equipment Employing Serial Binary Data Interchange. Washington, USA: Electronic Industries Association, Engineering Department. 1969. OCLC 38637094.
  5. ^ "RS232 Tutorial on Data Interface and cables". ARC Electronics. 2010. Retrieved 2011-07-28.
  6. ^ "TIA Facts at a Glance". About TIA. Telecommunications Industry Association. Retrieved 2011-07-28.
  7. ^ S. Mackay, E. Wright, D. Reynders, J. Park, Practical Industrial Data Networks: Design, Installation, and Troubleshooting, Newnes, 2004 ISBN 07506 5807X, pages 41-42
  8. ^ Horowitz, Paul; Hill, Winfield (1989). The Art of Electronics (2nd ed.). Cambridge, England: Cambridge University Press. pp. 723–726. ISBN 0-521-37095-7.
  9. ^ PC 97 Hardware Design Guide. Redmond, Washington, USA: Microsoft Press. 1997. ISBN 1-57231-381-1.
  10. ^ "Lengths of serial cables". www.tldp.org. Retrieved 2020-01-01.
  11. ^ Andrews, Jean (2020). CompTIA A+ Guide to IT technical support. Dark, Joy, West, Jill (Tenth ed.). Boston, MA, USA: Cengage Learning. p. 267. ISBN 978-0-357-10829-1. OCLC 1090438548.
  12. ^ Wilson, Michael R. (January 2000). "TIA/EIA-422-B Overview" (PDF). Application Note 1031. National Semiconductor. Archived from the original (PDF) on 2010-01-06. Retrieved 2011-07-28.
  13. ^ Lawrence, Tony (1992). "Serial Wiring". A. P. Lawrence. Retrieved 2011-07-28.
  14. ^ "Serial (PC 25)". Pinout Guide.
  15. ^ Leedom, Casey (1990-02-20). "Re: EIA-232 full duplex RTS/CTS flow control standard proposal". Newsgroupcomp.dcom.modems. Usenet: 49249@lll-winken.LLNL.GOV. Retrieved 2014-02-03.

Further reading

[edit]
[edit]