LwIP協(xié)議在μC/OS操作系統(tǒng)中的實(shí)現(xiàn)
掃描二維碼
隨時(shí)隨地手機(jī)看文章
引 言
當(dāng)今的信息時(shí)代,是一個(gè)構(gòu)筑在網(wǎng)絡(luò)基礎(chǔ)之上的時(shí)代,互聯(lián)網(wǎng)已經(jīng)滲透到人們工作和生活的各個(gè)角落。隨著計(jì)算機(jī)的發(fā)展,嵌入式系統(tǒng)已成為計(jì)算機(jī)領(lǐng)域的一個(gè)重要組成部分。將嵌入式系統(tǒng)與 結(jié)合起來,就可以在兩者之間實(shí)現(xiàn)方便、低廉的信息交流。
但是,目前大多數(shù)嵌入式系統(tǒng)的網(wǎng)絡(luò)功能還十分有限:以MCU為核心,與一些監(jiān)測、伺服、指示設(shè)備配合實(shí)現(xiàn)一定的功能。在一些工業(yè)和汽車應(yīng)用中,利用CAN、、 等總線將MCU組網(wǎng),實(shí)現(xiàn)多個(gè)MCU之間的信息交流,但這種網(wǎng)絡(luò)的有效半徑比較有限,有關(guān)的通信協(xié)議也比較少,并且一般是孤立于以外的,所以局限性較大。把嵌入式系統(tǒng)連接到上,已成為嵌入式系統(tǒng)今后發(fā)展的一個(gè)重要方向,而且也將成為今后嵌入式系統(tǒng)必須具備的功能之一。
嵌入式TCP/IP協(xié)議棧的實(shí)現(xiàn)方式
目前Internet上的通信實(shí)現(xiàn)方式大都是基于TCP/IP協(xié)議,嵌入式設(shè)備要與Internet網(wǎng)絡(luò)直接交換信息,就必須支持TCP/IP協(xié)議。嵌入式系統(tǒng)中TCP/IP協(xié)議棧的實(shí)現(xiàn)方式有硬件固化和軟件實(shí)現(xiàn)兩種。
硬件方式是指利用TCP/IP協(xié)議棧的硬件芯片,由它實(shí)現(xiàn)協(xié)議的轉(zhuǎn)化,從而實(shí)現(xiàn)相應(yīng)的網(wǎng)絡(luò)功能。但這樣做的缺點(diǎn)是增加了硬件成本,對一些功能單一的嵌入式設(shè)備來說是很大的浪費(fèi),而且所增加的成本有時(shí)是難以接受的。
本文提出了一種軟件實(shí)現(xiàn)嵌入式系統(tǒng)網(wǎng)絡(luò)化的方法,通過簡化的TCP/IP協(xié)議LwIP實(shí)現(xiàn)嵌入式系統(tǒng)與網(wǎng)絡(luò)的互聯(lián)。要在完成原來控制系統(tǒng)功能的前提下,同時(shí)實(shí)現(xiàn)網(wǎng)絡(luò)通信,既要發(fā)送又要接收,沒有操作系統(tǒng)支持簡直不可想象,所以將其移植到嵌入式實(shí)時(shí)操作系統(tǒng)μC/OS中,由操作系統(tǒng)對其進(jìn)行任務(wù)的管理與調(diào)度。
LwIP 協(xié)議簡介
LwIP是Light Weight (輕型)IP協(xié)議,有無操作系統(tǒng)的支持都可以運(yùn)行。LwIP實(shí)現(xiàn)的重點(diǎn)是在保持TCP協(xié)議主要功能的基礎(chǔ)上減少對RAM 的占用,一般它只需要幾百字節(jié)的RAM和40K左右的ROM就可以運(yùn)行,這使LwIP協(xié)議棧適合在低端的嵌入式系統(tǒng)中使用。
其主要特性如下:
①支持多網(wǎng)絡(luò)接口下的IP轉(zhuǎn)發(fā);
②支持協(xié)議;
③包括實(shí)驗(yàn)性擴(kuò)展的UDP(用戶數(shù)據(jù)報(bào)協(xié)議);
④包括阻塞控制、RTT 估算、快速恢復(fù)和快速轉(zhuǎn)發(fā)的TCP(傳輸控制協(xié)議);
⑤提供專門的內(nèi)部回調(diào)接口(Raw API),用于提高應(yīng)用程序性能;
⑥可選擇的Berkeley接口API (在多線程情況下使用) 。
μC/OS操作系統(tǒng)
μC/OS是專門為嵌入式應(yīng)用設(shè)計(jì)的實(shí)時(shí)操作系統(tǒng)內(nèi)核,被廣泛應(yīng)用到各種嵌入式系統(tǒng)中。其特點(diǎn)可以概括為以下幾個(gè)方面:源代碼公開,代碼結(jié)構(gòu)清晰、明了,注釋詳盡;可移植性好;可裁剪,可固化;最多可以管理60個(gè)任務(wù),覆蓋器、信號量、事件標(biāo)志、郵箱、隊(duì)列和內(nèi)存管理,還支持互斥型信號量(Mutual Exclusion Semaphore);μC/OS除對商業(yè)應(yīng)用收取少量許可費(fèi)用外,其它用途的應(yīng)用都是免費(fèi)的。但是缺少對外圍設(shè)備和接口的支持,沒有文件系統(tǒng)、網(wǎng)絡(luò)協(xié)議、圖形界面,這些需要用戶自己去實(shí)現(xiàn)。
由于LwIP 會(huì)為每個(gè)網(wǎng)絡(luò)連接動(dòng)態(tài)分配一些信號量和消息隊(duì)列,當(dāng)連接斷開時(shí)會(huì)刪掉這些信號量和消息隊(duì)列。較低的版本如μC/.0不支持信號量和消息隊(duì)列的刪除,所以要選擇高一些的版本,本文中選用的是μC/.51版本。
LwIP協(xié)議的移植
整個(gè)系統(tǒng)的結(jié)構(gòu)如圖1所示,由MCU、網(wǎng)卡、網(wǎng)絡(luò)設(shè)備驅(qū)動(dòng)、μC/OS操作系統(tǒng)、LwIP協(xié)議棧和應(yīng)用程序6 個(gè)部分組成。下面從與MCU 的接口、與網(wǎng)卡接口、與高層應(yīng)用程序接口等幾部分,說明LwIP 移植的具體方法和實(shí)現(xiàn)過程。
圖1 系統(tǒng)示意圖
與M. 2107 接口的實(shí)現(xiàn)
基于X86平臺(tái)的PC機(jī)是小端字節(jié)順序,而M. 2107默認(rèn)為大端存儲(chǔ)系統(tǒng)。因而為了保證數(shù)據(jù)的正確傳輸,對int、uint16、uint32等多于1 字節(jié)類型的數(shù)據(jù)變換其存儲(chǔ)順序。字節(jié)順序是指占內(nèi)存多于一個(gè)字節(jié)類型的數(shù)據(jù)在內(nèi)存中的存放順序,通常有小端、大端兩種字節(jié)順序。小端字節(jié)序是指低字節(jié)數(shù)據(jù)存放在內(nèi)存低地址處,高字節(jié)數(shù)據(jù)存放在內(nèi)存高地址處;大端字節(jié)序是指高字節(jié)數(shù)據(jù)存放在低地址處,低字節(jié)數(shù)據(jù)存放在高地址處。
C編譯器修改
在LwIP中各個(gè)報(bào)頭的定義使用struct結(jié)構(gòu),默認(rèn)情況下C編譯器為結(jié)構(gòu)的每個(gè)成員按其自然對界條件分配空間,但是LwIP使用的是通過結(jié)構(gòu)體中不同數(shù)據(jù)的長度來讀取相應(yīng)的數(shù)據(jù)的,所以必須對編譯器進(jìn)行修改,讓它放棄字節(jié)對齊。
與μC/OS操作系統(tǒng)接口的實(shí)現(xiàn)
與操作系統(tǒng)相關(guān)的結(jié)構(gòu)和函數(shù)主要可以分為信號量、消息隊(duì)列、器函數(shù)和創(chuàng)建新線程函數(shù),下面從4個(gè)部分對移植的過程進(jìn)行詳細(xì)地論述。
(1) 信號量
LwIP中需要使用信號量進(jìn)行通信,所以在sys_arch中應(yīng)實(shí)現(xiàn)相應(yīng)的信號量結(jié)構(gòu)體struct sys_和處理函數(shù)sys_sem_new() 、sys_sem_() 、sys_sem_signal ( ) 和sys_arch_sem_wait ( ) 。由于μC/OS已經(jīng)實(shí)現(xiàn)了信號量OSEVENT的各種操作,并且功能和LwIP上面幾個(gè)函數(shù)的目的功能是完全一樣的,所以只要把μC/OS的函數(shù)重新包裝成上面的函數(shù),就可直接使用。
(2) 消息隊(duì)列
LwIP 使用消息隊(duì)列來緩沖、傳遞數(shù)據(jù)報(bào)文,因此要實(shí)現(xiàn)消息隊(duì)列結(jié)構(gòu)sys_mbox_t ,以及相應(yīng)的操作函數(shù):sys_mbox_new() 、sys_mbox_ () 、sys_mbox _ () 和sys_arch_mbox_fetch() 。μC/OS實(shí)現(xiàn)了消息隊(duì)列結(jié)構(gòu)OSQ 及其操作,但是μC/OS沒有對消息隊(duì)列中的消息進(jìn)行管理,因此不能直接使用,必須在μC/OS的基礎(chǔ)上重新實(shí)現(xiàn)。具體實(shí)現(xiàn)時(shí),對隊(duì)列本身的管理利用μC/OS自己的OSQ操作完成,然后使用μC/OS中的內(nèi)存管理模塊實(shí)現(xiàn)對消息的創(chuàng)建、使用、刪除和回收,兩部分起來形成了LwIP的消息隊(duì)列功能。
(3) 器函數(shù)
LwIP中每個(gè)和TCP/IP相關(guān)的任務(wù)的一系列定時(shí)事件組成一個(gè)單向鏈表,每個(gè)鏈表的起始指針存在lwip_timeouts 的對應(yīng)表項(xiàng)中,如圖2所示。移植時(shí)需要實(shí)現(xiàn)struct sys_timeouts * sys_arch_timeouts (void) 函數(shù),該函數(shù)返回目前正處于運(yùn)行態(tài)的線程所對應(yīng)的timeout 隊(duì)列指針。
圖2 定時(shí)事件鏈表
(4) 創(chuàng)建新線程函數(shù)
在μC/OS 中,沒有線程(thread) 的概念,只有任務(wù)() 。它提供了創(chuàng)建新任務(wù)的系統(tǒng)API調(diào)用OSCreate,因此只要把OSCreate封裝一下,就可以實(shí)現(xiàn)sys_thread_new。需要注意的是LwIP中的thread并沒有μC/OS 中優(yōu)先級的概念,實(shí)現(xiàn)時(shí)要由用戶事先為LwIP中創(chuàng)建的線程分配好優(yōu)先級。
網(wǎng)絡(luò)設(shè)備驅(qū)動(dòng)程序的移植
本系統(tǒng)中選擇的以太網(wǎng)控制芯片是 ,它是8/16 位ISA總線的網(wǎng)卡,遵循IEEE802. 3 協(xié)議。
內(nèi)部按鏈路數(shù)的不同,可以劃分為遠(yuǎn)程DMA通道和本地DMA 兩個(gè)部分。當(dāng)主處理器要向網(wǎng)上發(fā)送數(shù)據(jù)時(shí),先將一幀數(shù)據(jù)通過遠(yuǎn)程DMA 通道送到中的發(fā)送緩沖區(qū),然后發(fā)送傳送命令。RTL8019AS在完成上一幀的發(fā)送后,再進(jìn)行此幀的發(fā)送。RTL8019AS接收到的數(shù)據(jù)通過MAC比較、CRC 校驗(yàn)后,由存到接收緩沖區(qū),收滿一幀后,以中斷或寄存器標(biāo)志的方式通知主處理器,主處理器再通過遠(yuǎn)程DMA 通道讀取這一幀數(shù)據(jù)。
在LwIP中有多個(gè)網(wǎng)絡(luò)接口,每個(gè)網(wǎng)絡(luò)接口都對應(yīng)了一個(gè)struct netif,這個(gè)netif包含了相應(yīng)網(wǎng)絡(luò)接口的屬性、收發(fā)函數(shù)。LwIP 調(diào)用netif 的方法netif->input() 及netif->() 進(jìn)行以太網(wǎng)packet的收、發(fā)等操作。LwIP的網(wǎng)絡(luò)驅(qū)動(dòng)有一定的模型,/src/netif/ethernetif.c 文件即為驅(qū)動(dòng)的模板,用戶為自己的網(wǎng)絡(luò)設(shè)備實(shí)現(xiàn)驅(qū)動(dòng)時(shí)應(yīng)參照此模板。
LwIP 協(xié)議的測試
為了進(jìn)行應(yīng)用程序的測試,首先在μC/OS中初始化LwIP,創(chuàng)建相應(yīng)的任務(wù),值得注意的是LwIP的初始化必須在μC/OS完全啟動(dòng)之后,也就是在任務(wù)中進(jìn)行,因?yàn)樗某跏蓟玫搅诵盘柫康扰c操作系統(tǒng)相關(guān)的操作。
本系統(tǒng)使用EVB2107(Evaluation Board2107) 評估板進(jìn)行應(yīng)用程序的調(diào)試,該評估板是輔助用戶開發(fā)調(diào)試M.系列中的MMC2107 微控制器的一種電路板,外擴(kuò)2MB FLASH和1MB SRAM存儲(chǔ)器,利用EVB 2107用戶可以開發(fā)應(yīng)用程序的代碼。測試時(shí),可以把網(wǎng)卡的IP地址設(shè)置為任意值,在CodeWarrior IDE 的控制臺(tái)窗口中運(yùn)行ping IP地址-l2000-t,不間斷用長度為2000的數(shù)據(jù)報(bào)進(jìn)行ping測試,同時(shí)使用tftp 客戶端軟件給該IP 地址下載一個(gè)幾兆的程序,發(fā)現(xiàn)一切工作正常,說明ARP、、IP、TCP 協(xié)議都已正確運(yùn)行。
總 結(jié)
本設(shè)計(jì)方案兼顧了小容量和通用性的要求,可以在多種硬件平臺(tái)上實(shí)現(xiàn),并且便于移植。