嵌入式TCP/IP的實現(xiàn)
TCP/IP的嵌入式實現(xiàn)一般通過以軟件方式嵌入到ROM中,然后通過輕網絡通訊技術與專用嵌入式網關連接,在嵌入式處理器中運行TCP/IP協(xié)議,提供TCP/IP到用戶的輕型網絡的連接和路由功能。
內存管理方法和無多余數據包拷貝的實現(xiàn)
嵌入式TCP/IP的內存管理可以用鏈表方法,即根據數據包大小分配相應大小的內存塊。如圖4所示,鏈表將內存塊鏈接起來,used字段表示該內存塊是否正在使用,pSstart和pEend則表示數據部分有效數據的開始地址和結束地址。搜索內存鏈表找到一個沒有分配的比所需空間大的內存塊,截取所需的大小。該內存塊被截取以后可能還有較多剩余,這時將剩余部分從原內存塊中分離出來,成為一個新的內存塊,并插入鏈表。釋放時,將used值置為假, 如果pNext或者pPre指向的鏈表單元也是空閑的,則將其和自己合并,以防止內存分片。在協(xié)議層之間傳送數據包只需傳送內存塊的起始地址。這種內存管理方法,空間浪費小但是運算量相對較大。
圖4 基于嵌入式TCP/IP內存管理
整序、重發(fā)和窗口控制的實現(xiàn)
對于嵌入式TCP/IP系統(tǒng),可以使用隊列緩存的方式來實現(xiàn)整序、重發(fā)和窗口控制。隊列的一個元素指向一個數據包,隊列的最大長度沒有限制。
對于整序,使用ooSeq隊列,如果發(fā)現(xiàn)接收的TCP包序號并不是期望的,但序號在接收窗口內,此時不能立刻接收這個包也不應丟棄,可先將這個包放入ooSeq隊列。當期望TCP包被接收后,再查看ooSeq隊列現(xiàn)在是否有TCP包成為了期望的數據包,如果有則將其取出并處理。
對于重發(fā),使用unacked隊列,每一個需要被應答的TCP數據包發(fā)送以后都要放入unacked隊列,等到被應答以后才從隊列中刪除。TCP重發(fā)定時只針對unacked隊列第一個TCP包,如果定時超出,重新發(fā)送,重發(fā)次數超出規(guī)定值,則報錯。
對于窗口控制,使用unsend隊列,如果發(fā)現(xiàn)對方的窗口過小無法接收這個數據包,則只發(fā)送部分數據,將多余部分放入unsend隊列,等待對方發(fā)來TCP包通知新的窗口大小時,再次判斷是否可以發(fā)送。如果在unsend隊列不為空的情況下,需要發(fā)送的數據包都應插入unsend隊列。
嵌入式TCP/IP的性能分析
圖5給出了將優(yōu)化設計后的TCP/IP移植到ARM9處理器、CS8900A網絡控制器中,時鐘頻率為133MHz下,與Internet連接的情況。
圖5 連接圖
系統(tǒng)支持最大發(fā)起連接數約為380,最大并發(fā)連接率約為170cps。隨著呼叫數的增加,平均分組到達也隨之增加,導致網絡傳輸數據的增加,從而最大建立時間變長。但最小的建立連接時間基本保持不變,說明系統(tǒng)具有良好的性能。
圖6給出了隨建立時間變化的接通率。圖中存在一個臨界點,成功的連接率隨著TCP連接嘗試數目增加而減少,直至為0,而響應時間也急劇上升,這是由嵌入式處理器的處理能力有限造成的。
圖6 隨建立時間變化的連接圖
結語
本文從實現(xiàn)相應的功能又節(jié)省系統(tǒng)資源角度出發(fā),對嵌入式TCP/IP協(xié)議簇進行優(yōu)化設計,可以在各種嵌入式處理器上實現(xiàn)Internet接入。
經過優(yōu)化設計的嵌入式TCP/IP支持套接字形式的多個TCP連接、支持多個網絡設備、支持通過網關發(fā)送數據包和數據包轉發(fā)功能,以及支持TCP包的整序、重發(fā)和窗口控制流量控制。實踐證明,這種設計方式靈活,能按用戶需求實現(xiàn)復雜的功能。
轉載請注明出處。