幾種開源的TCP/IP協議棧分析

1、BSD TCP/IP協議棧,BSD棧歷史上是其他商業棧的起點,大多數專業TCP/IP棧(VxWorks內嵌的TCP/IP棧)是BSD棧派生的。這是因爲BSD棧在BSD許可協議下提供了這些專業棧的雛形,BSD許用證允許BSD棧以修改或未修改的形式結合這些專業棧的代碼而無須向創建者付版稅。同時,BSD也是許多TCP/IP協議中的創新(如廣域網中餓擁塞控制和避免)的開始點。
ftp://ftp.FreeBSD.org/pub/FreeBSD-stable/src/sys.netinet

2、uC/IP是由Guy Lancaster編寫的一套基於uC/OS且開放源碼的TCP/IP協議棧,亦可移植到其它操作系統,是一套完全免費的、可供研究的TCP/IP協議棧,uC/IP大部分源碼是從公開源碼BSD發佈站點和KA9Q(一個基於DOS單任務環境運行的TCP/IP協議棧)移植過來。uC/IP具有如下一些特點:帶身份驗證和報頭壓縮支持的PPP協議,優化的單一請求/回覆交互過程,支持IP/TCP/UDP協議,可實現的網絡功能較爲強大,並可裁減。UCIP協議棧被設計爲一個帶最小化用戶接口及可應用串行鏈路網絡模塊。根據採用CPU、編譯器和系統所需實現協議的多少,協議棧需要的代碼容量空間在30-60KB之間。
http://ucip.sourceforge.net

3、LwIP是瑞士計算機科學院(Swedish Institute of Computer Science)的Adam Dunkels等開發的一套用於嵌入式系統的開放源代碼TCP/IP協議棧。LwIP的含義是Light Weight(輕型)IP協議,相對於uip。LwIP可以移植到操作系統上,也可以在無操作系統的情況下獨立運行。LwIP TCP/IP實現的重點是在保持TCP協議主要功能的基礎上減少對RAM的佔用,一般它只需要幾十K的RAM和40K左右的ROM就可以運行,這使LwIP協議棧適合在低端嵌入式系統中使用。LwIP的特性如下:支持多網絡接口下的IP轉發,支持ICMP協議 ,包括實驗性擴展的的UDP(用戶數據報協議),包括阻塞控制,RTT估算和快速恢復和快速轉發的TCP(傳輸控制協議),提供專門的內部回調接口(Raw API)用於提高應用程序性能,並提供了可選擇的Berkeley接口API。
http://sics.se/~sdam/lwip/

4、uIP是專門爲8位和16位控制器設計的一個非常小的TCP/IP棧。完全用C編寫,因此可移植到各種不同的結構和操作系統上,一個編譯過的棧可以在幾KB ROM或幾百字節RAM中運行。uIP中還包括一個HTTP服務器作爲服務內容。許可:BSD許用證 http://dunkels.com/adam/uip/

5、TinyTcp 棧是TCP/IP的一個非常小和簡單的實現,它包括一個FTP客戶。TinyTcp是爲了燒入ROM設計的並且現在開始對大端結構似乎是有用的(初始目標是68000芯片)。TinyTcp也包括一個簡單的以太網驅動器用於3COM多總線卡 http://ftp.ecs.soton.ac.uk/pub/elks/utils/tiny-tcp.txt

個人認爲選擇一個開源協議棧可以從四個方面來考慮:一個是是否提供易用的底層硬件API,即與硬件平臺的無關性;一個是與操作系統的內核API。協議棧需要調用的系統函數接口是否容易構造,另一個對於應用支持程度。最關鍵的是佔用的系統資源是否在可接受範圍內,有裁減優化的空間否?
其中,BSD 棧可完整實現TCP/IP協議,但代碼龐大,70KB-150KB之間,裁減優化有難度,uIP和TinyTcp代碼容量小巧,實現功能精簡,限制了在一些較高要求場合下的應用,如可靠性與大容量數據傳輸。LwIP和uC/IP是同量級別的兩個開源協議棧,兩者代碼容量和實現功能相似,LwIP沒有操作系統針對性,它將協議棧與平臺相關的代碼抽象出來,用戶如果要移植到自己的系統,需要完成該部分代碼的封裝,併爲網絡應用支持提供了API接口的可選性。uC/IP協議最初是針對uC/OS設計,爲方便用戶移植實現,同樣也抽象了協議棧與平臺相關代碼,但是協議棧所需調用的系統函數大多參照uC/OS內核函數原型設計,並提供了協議棧的測試函數,方便用戶參考,其不足在於該協議棧對網絡應用支持不足。
根據以上分析,從應用和開發的角度看,似乎LWIP更得到了網上很多朋友使用的青睞;uC/IP在文檔支持與軟件升級管理上有很多不足,但是它最初是針對UC/OS而設計,如果選用UC/OS作爲軟件基礎的話,在系統函數構造方面有優勢。當然你選擇其他操作系統的話,可參照OS_NULL文件夾下的文件修改。
以上的這些開源協議棧也並非免費,拿來就可以用,據我所知,UC/OS的母公司推出UC/OS-TCP/IP花了6人*2年的工作量,國內某公司使用LWIP作爲移植的參照,花了4-5人*2年的工作量來測試與優化協議,使用商用TCP/IP棧的高費用就不足爲奇了。
作爲廣大的愛好者學習而言,如果只是跑跑原型,實驗一下效果,以上的幾種開源協議棧都提供了測試的例子,應該是不錯的選擇。個人的看法:LWIP可優先考慮,至少網上有很多的人一塊研究,參考的資料較多;UC/IP其次,如果你想深入學習TCP/IP的話,移植UC/IP是一種挑戰性的工作,它尚需完善 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章