Serial Line Internet Protocol
Internet protocol suite |
---|
Application layer |
Transport layer |
Internet layer |
Link layer |
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
- Parallel Line Internet Protocol
- Slirp
- KA9Q
- Direct cable connection
- In-band signaling
- KISS (TNC)
- Consistent Overhead Byte Stuffing
References
- ↑ SLIP does not actually care about the internal structures of IP: any network layer protocols can be sent over the wire.
- ↑ "Internet Q&A". The New York Times. May 31, 1996. http://www.nytimes.com/library/cyber/qa/0531freed.html.
- ↑ "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.0 3.1 RFC 1547: "Requirements for an Internet Standard Point-to-Point Protocol"
- ↑ Understanding TCP/IP (Chapter 4.2 Compressed SLIP). https://www.oreilly.com/library/view/understanding-tcpip/9781904811718/ch04s02.html.
- ↑ 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
- ↑ "RFC 1055: Nonstandard for transmission of IP datagrams over serial lines: SLIP" (in en). 1 June 1988. https://datatracker.ietf.org/doc/html/rfc1055.
- ↑ "slattach(8)". https://man.freebsd.org/cgi/man.cgi?query=slip&apropos=0&sektion=8&manpath=FreeBSD+7.4-RELEASE&arch=default&format=html.
- ↑ Torvalds, Linus (13 May 2023). "History for mkiss.c". https://github.com/torvalds/linux/blob/9a48d604672220545d209e9996c2a1edbb5637f6/drivers/net/hamradio/mkiss.c.
- ↑ Torvalds, Linus (13 May 2023). "drivers/net/slip/Kconfig". https://github.com/torvalds/linux/blob/master/drivers/net/slip/Kconfig.
- ↑ Linux Programmer's Manual – Administration and Privileged Commands "Other possible values are slip (normal SLIP), adaptive (adaptive CSLIP/SLIP)... –
Original source: https://en.wikipedia.org/wiki/Serial Line Internet Protocol.
Read more |