Serial_Line_Internet_Protocol

Serial Line Internet Protocol

Serial Line Internet Protocol

Internet Protocol encapsulation for serial ports and router connections


The Serial Line Internet Protocol (SLIP)[1][2] is an encapsulation of the Internet Protocol[lower-alpha 1] designed to work over serial ports and router connections. It is documented in RFC 1055. On personal computers, SLIP has largely been replaced by the Point-to-Point Protocol (PPP), which is better engineered, has more features, and does not require its IP address configuration to be set before it is established. On microcontrollers, however, SLIP is still the preferred way of encapsulating IP packets, due to its very small overhead.

Some people refer to the successful and widely used RFC 1055 Serial Line Internet Protocol as "Rick Adams' SLIP",[3] to avoid confusion with other proposed protocols named "SLIP". Those other protocols include the much more complicated RFC 914 appendix D Serial Line Interface Protocol.[3]

Description

More information Hex value, Dec Value ...

SLIP modifies a standard TCP/IP datagram by:

  • appending a special "END" byte to it, which distinguishes datagram boundaries in the byte stream,
  • if the END byte occurs in the data to be sent, the two byte sequence ESC, ESC_END is sent instead,
  • if the ESC byte occurs in the data, the two byte sequence ESC, ESC_ESC is sent.
  • variants of the protocol may begin, as well as end, packets with END.

SLIP requires a serial port configuration of 8 data bits, no parity, and either EIA hardware flow control, or CLOCAL mode (3-wire null-modem) UART operation settings.

SLIP does not provide error detection, being reliant on upper layer protocols for this. Therefore, SLIP on its own is not satisfactory over a link which is error-prone, such as a poor quality dial-up connection.

SLIP escape characters were also required on some modem connections to escape Hayes command set, allowing therefore to pass binary data through those modems that would recognize some characters as commands.

CSLIP

A version of SLIP with header compression is called Compressed SLIP (CSLIP).[4] The compression algorithm used in CSLIP is known as Van Jacobson TCP/IP Header Compression.[5] CSLIP has no effect on the data payload of a packet and is independent of any compression by the serial line modem used for transmission. It reduces the Transmission Control Protocol (TCP) header from twenty bytes to seven bytes. CSLIP has no effect on User Datagram Protocol (UDP) datagrams.

History

RFC 1055, a "non-standard" for SLIP, traces its origins to the 3COM UNET TCP/IP implementation from the 1980s. Rick Adams added SLIP to the popular 4.2BSD in 1984 and it "quickly caught on". By the time of the RFC (1988), it is described as "commonly used on dedicated serial links and sometimes for dialup purposes".[6]

The last version of FreeBSD to include "slattach" (a command for connecting to slip) in the manual database is FreeBSD 7.4, released 2011. The manual claims that auto-negotiation exists for CSLIP. The FreeBSD version is inherited from 4.3BSD.[7]

Linux formerly used the same code base for SLIP and KISS (TNC). The split occurred before the start of kernel git history (Linux-2.6.12-rc2, 2005).[8] The SLIP driver offers a special "6-bit" escaped mode to accommodate modems incapable of handling non-ASCII characters.[9] The Linux slattach command (written independently) also has the ability to auto-detect CSLIP support.[10]

See also


References

  1. SLIP does not actually care about the internal structures of IP: any network layer protocols can be sent over the wire.
  1. RFC 1547: "Requirements for an Internet Standard Point-to-Point Protocol"
  2. Jacobson, V. (February 1990). "Compressing TCP/IP Headers for Low-Speed Serial Links". โ€” introduced the Van Jacobson TCP/IP Header Compression used by CSLIP
  3. "slattach(8)". man.freebsd.org.
  4. Torvalds, Linus (13 May 2023). "History for mkiss.c". Retrieved 13 May 2023.
  5. Torvalds, Linus (13 May 2023). "drivers/net/slip/Kconfig".
  6. slattach(8) โ€“ Linux Programmer's Manual โ€“ Administration and Privileged Commands "Other possible values are slip (normal SLIP), adaptive (adaptive CSLIP/SLIP)...

Share this article:

This article uses material from the Wikipedia article Serial_Line_Internet_Protocol, and is written by contributors. Text is available under a CC BY-SA 4.0 International License; additional terms may apply. Images, videos and audio are available under their respective licenses.