Serial Line Internet Protocol

From HandWiki
Short description: 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

Hex value Dec Value Oct Value Abbreviation Description
0xC0 192 300 END Frame End
0xDB 219 333 ESC Frame Escape
0xDC 220 334 ESC_END Transposed Frame End
0xDD 221 335 ESC_ESC Transposed Frame Escape

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 an error-prone dial-up connection. It is however still useful for testing operating systems' response capabilities under load (by looking at flood-ping statistics).

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. "Internet Q&A". The New York Times. May 31, 1996. http://www.nytimes.com/library/cyber/qa/0531freed.html. 
  2. "The Executive Computer; For Befuddled Newcomers, Easier Access". The New York Times. May 8, 1994. https://www.nytimes.com/1994/05/08/business/the-executive-computer-for-befuddled-newcomers-easier-access-to-the-internet.html. 
  3. 3.0 3.1 RFC 1547: "Requirements for an Internet Standard Point-to-Point Protocol"
  4. Understanding TCP/IP (Chapter 4.2 Compressed SLIP). https://www.oreilly.com/library/view/understanding-tcpip/9781904811718/ch04s02.html. 
  5. Jacobson, V. (February 1990). "Compressing TCP/IP Headers for Low-Speed Serial Links". http://tools.ietf.org/html/rfc1144.  — introduced the Van Jacobson TCP/IP Header Compression used by CSLIP
  6. "RFC 1055: Nonstandard for transmission of IP datagrams over serial lines: SLIP" (in en). 1 June 1988. https://datatracker.ietf.org/doc/html/rfc1055. 
  7. "slattach(8)". https://man.freebsd.org/cgi/man.cgi?query=slip&apropos=0&sektion=8&manpath=FreeBSD+7.4-RELEASE&arch=default&format=html. 
  8. Torvalds, Linus (13 May 2023). "History for mkiss.c". https://github.com/torvalds/linux/blob/9a48d604672220545d209e9996c2a1edbb5637f6/drivers/net/hamradio/mkiss.c. 
  9. Torvalds, Linus (13 May 2023). "drivers/net/slip/Kconfig". https://github.com/torvalds/linux/blob/master/drivers/net/slip/Kconfig. 
  10. slattach(8) – Linux Programmer's Manual – Administration and Privileged Commands "Other possible values are slip (normal SLIP), adaptive (adaptive CSLIP/SLIP)...