串行线路上传输数据报的非标准协议:SLIP
簡介
TCP/IP協議族可以在許多網絡介質上運行,如: IEEE 802.3 (以太網)和802.5(令牌環)局域網,X.25線路,衛星連接和串行線路。除了串行線路外,其它的介質上都有包格式的標準。SLIP,串行線路IP,實際上是一個標準,它通常用于運行TCP/IP協議點對點連接之中。它并非Internet標準。
歷史
SLIP起始于八十年代初3COM UNET TCP/IP實現,它僅是一個包協議:SLIP定義了一系列字符將IP包在串行線路上變成幀格式,僅此而已。它不提供尋址,包類型標識,差錯控制或壓縮機制。因為此協議十分簡單,所以非常容易實現。在1984年左右,Rick Adams為Berkeley Unix和Sun Microsystems工作站實現了SLIP并推廣到世界。它很快被用于在主機和路由器之間的串行線路連接。SLIP通常用于專線連接,有時也用于拔號連接,其速度經常在1200bps和19.2Kbps之間。對于主機和路由器之間的連接是十分有用的。
實用性
SLIP在大部分基于Berkeley UNIX的系統上可用,在Berkeley 4.3BSD 中也包括SLIP。SLIP在Ultrix,Sun UNIX和大部分由Berkeley演變而來的UNIX上可用。一些終端集中器和IBM PC也支持它。
協議
SLIP協議定義兩個特殊字符:END和ESC。END是八進制300(十進制192),ESC是八進制(十進制219),這與ASCII碼中的ESC字符不沖突;為了討論的方便,這里所說的ESC均是SLIP的ESC字符。若要發送一個包,SLIP主機只需要以包的形式發送數據即可。如果數據與END字符相同,則發送ESC和八進制的334(十進制220)代替。如果和ESC相同,則以ESC和八進制335(十進制221)代替。當包數據發送結束,則發送一個END字符。Phil Karn提出一個改進的算法,可以在包頭和飽包尾都使用END。這將消除由于線路噪聲帶來的錯誤。在一般情況下,接收方只用觀察兩個END,這將產生錯誤的IP包。如果SLIP實現不放棄0長度包,那IP實現會這樣做的。如果因為噪聲,此包將被拋棄,而不影響下面的包。因為沒有標準的SLIP說明,因此沒有真正定義的最大SLIP包大小。我們最好接受由Berkeley UNIX SLIP drivers定義的大小:1006字節,包括IP和傳輸協議頭(不包括幀字符。因此,新的SLIP實現應該準備接收1006字節的數據報,而且不應該發送大于1006字節的數據報。
不足之處
有一些用戶希望SLIP提供但它沒有提供的功能,公平地說,SLIP僅僅是很久前,問題并不那么重要時設計的普通協議。下面是顯而易見的SLIP的不足之處:
- 尋址功能:
SLIP連接的雙方都出于路由的目的需要知道對方的IP地址。并且,當使用SLIP作為主機拔號到路由器的目的時,尋址機制會是動態的,路由器需要通知拔號主機主機的IP地址。而現在,SLIP卻沒有提供通過SLIP連接傳送地址信息的機制。
- 類型標識:
SLIP沒有類型域,因此,在SLIP連接上僅能運行一種協議,所有在配置了TCP/IP和DECnet的主機之間不可能使用SLIP。而SLIP是串行線路IP,如果以串行線路連接多協議的計算機,這些計算機應該具有以一種以上協議通信的能力。
- 差錯檢測與校正:
線路噪聲可能使包在傳送過程中損壞,因為線路速率比較低,因此,重新發送的代價是昂貴的。在SLIP層,差錯控制并不是必須的,因為IP應用程序可以檢測到損壞的包(IP頭和UDP,TCP校驗碼是足夠的),但是一些應用程序如NFS通常忽略錯誤而單純依靠網絡介質來檢測損壞的包。因為重新傳送的代價很大,因此SLIP提供差錯檢測與校正是更有效的方法。
- 壓縮:
因為拔號線路速率比較慢,包的壓縮將大大提高包的吞吐量。通常,在單獨一個TCP連接的包序列中的IP和TCP頭中幾乎沒有多少變化,所以普通的壓縮算法就可以僅發送改變的包頭部分而不是整個包頭。已經在這方面做了一些工作,上面的問題中的全部或一部分正在研究之中。
SLIP驅動程序
下面的C語言函數可以發送并接收SLIP包。他們依靠兩個函數完成功能:send_char()和recv_char(),它們分別在串行線路上發送和接收一個字節。
/* SLIP特殊字符 */ #define END 0300 /*標明包結束*/ #define ESC 0333 /*標明字節填充*/ #define ESC_END 0334 /*ESC ESC_END用于包中數據和和END相同時的轉意字符*/ #define ESC_ESC 0335 /*ESC ESC_ESC用于包中數據和和ESC相同時的轉意字符*/ /* SEND_PACKET:發送長度為LEN的的包,起始位置在P*/ void send_packet(p, len) char *p; int len; { /*發送一個END字符*/ send_char(END); /*發送包內的數據*/ while(len--) { switch(*p) { /*如果需要轉意,則進行相應的處理*/ case END: send_char(ESC); send_char(ESC_END); break; case ESC: send_char(ESC); send_char(ESC_ESC); break; /*如果不需要轉意,則直接發送*/ default: send_char(*p); } p++; } /*通知接收方發送結束*/ send_char(END); } /* RECV_PACKET:接收包數據,存儲于P位置,如果接收到的數據大于LEN,則被截斷,函數返回接收到的字節數*/ int recv_packet(p, len) char *p; int len; { char c; int received = 0; while(1) { /*接收字符*/ c = recv_char(); switch(c) { /*如果接收到END,包數據結束,如果包內沒有數據,直接拋棄*/ case END: if(received) return received; else break; /*下面的代碼用于處理轉意字符*/ case ESC: c = recv_char(); switch(c) { case ESC_END: c = END; break; case ESC_ESC: c = ESC; break; } default: if(received < len) p[received++] = c; } } }
轉載于:https://www.cnblogs.com/starspace/archive/2009/02/03/1383099.html
總結
以上是生活随笔為你收集整理的串行线路上传输数据报的非标准协议:SLIP的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Day2-T1
- 下一篇: windbg 分析pchunter导致的