




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
PAGEPAGEII摘要基于ARM處理器的網(wǎng)絡(luò)數(shù)據(jù)傳輸技術(shù)結(jié)合了嵌入式設(shè)備工作穩(wěn)定,實時性好,集成度高,環(huán)境適應(yīng)能力強(qiáng),成本低等優(yōu)點與網(wǎng)絡(luò)覆蓋廣泛及接口具有良好通用性的優(yōu)點,在各種數(shù)據(jù)傳輸現(xiàn)場中具有越來越廣泛的應(yīng)用前景。本文是基于RAM處理器的網(wǎng)絡(luò)數(shù)據(jù)傳輸技術(shù)的研究,網(wǎng)絡(luò)數(shù)據(jù)以圖像數(shù)據(jù)的傳輸為例,并且研究對象采用了通過網(wǎng)絡(luò)傳輸圖像數(shù)據(jù)的應(yīng)用系統(tǒng),所以本文提出在單芯片上實現(xiàn)全局控制+輕量級RTOS內(nèi)核+精簡TCP/IP協(xié)議棧的系統(tǒng)架構(gòu)方式,設(shè)計一個基于S3C2440開發(fā)板的網(wǎng)絡(luò)圖像數(shù)據(jù)實時傳輸?shù)那度胧较到y(tǒng)。關(guān)鍵詞:網(wǎng)絡(luò)數(shù)據(jù)傳輸嵌入式LinuxTCP/IP協(xié)議AbstractUnifiedtheembeddedequipmentworkbasedontheARMprocessornetworkdatatransmissiontechnologytobestable,timelinesswasgood,theintegrationratewashigh,environmentadaptiveness,thecostlowstatusmeritandthenetworkcoverwidespreadandtheconnectionhadthegoodversatilemerit,hadthemoreandmorewidespreadapplicationprospectineachkindofdatatransmissionscene.ThisarticleisbasedontheRAMprocessornetworkdatatransmissiontechnologyresearch,thenetworkdatataketheimagedatatransmissionasanexample,andtheobjectofstudyhasusedthroughthenetworktransmissionimagedataapplicationsystem,thereforethisarticleproposedrealizestheoverallsituationcontrol+lightweightRTOSessenceonthesinglechip+tosimplifytheTCP/IPagreementstackthesystemconstructionway,designsonebasedontheS3C2440developmentboardnetworkimagedatareal-timetransmissionembeddedsystem.Keywords:DataTransmissionNetworkEmbeddedLinuxTCP/IPAgreement目錄第一章緒論 11.課題的背景及其意義 12.本文所做工作 1第二章嵌入式系統(tǒng)及圖像的網(wǎng)絡(luò)傳輸 32.1嵌入式系統(tǒng)概述 32.1.1嵌入式系統(tǒng)的定義 32.1.2嵌入式系統(tǒng)的特點 32.1.3嵌入式系統(tǒng)的組成 42.1.4嵌入式Linux 52.1.5嵌入式系統(tǒng)開發(fā)與調(diào)試 52.2基于嵌入式系統(tǒng)的圖像的網(wǎng)絡(luò)傳輸 62.3嵌入式網(wǎng)絡(luò)傳輸?shù)膱D像壓縮算法 6本章小結(jié) 7第三章基于嵌入式系統(tǒng)的圖像網(wǎng)絡(luò)傳輸?shù)南到y(tǒng)設(shè)計 83.1系統(tǒng)結(jié)構(gòu)設(shè)計 83.2硬件平臺設(shè)計 93.2.1S3C2440體系結(jié)構(gòu)及特點 93.3軟件設(shè)計 13本章小結(jié) 13第四章TCP/IP協(xié)議概述 144.1網(wǎng)絡(luò)分層結(jié)構(gòu) 144.1.1OSI七層參考模型 144.1.2TCP/IP參考模型 154.2TCP/IP網(wǎng)絡(luò)協(xié)議 164.2.1嵌入式TCP/IP協(xié)議 164.2.2IP協(xié)議 164.2.3UDP/TCP協(xié)議 174.2.4ARP協(xié)議 17本章小結(jié) 17第五章基于嵌入式系統(tǒng)的圖像網(wǎng)絡(luò)傳輸?shù)能浖O(shè)計 195.1LINUX在ARM硬件平臺上的移植 195.1.1移植環(huán)境 195.1.2建立交叉編譯環(huán)境 195.1.3BOOTLOADER 205.2燒寫和啟動LINUX以及LINUX內(nèi)核編譯 225.2.1燒寫Linux內(nèi)核 225.2.2燒寫根文件系統(tǒng) 225.2.3啟動Linux 235.2.4安裝編譯工具 235.2.5編譯內(nèi)核 245.2.6cramfs根文件系統(tǒng)的創(chuàng)建 245.3嵌入式TCP/IP協(xié)議棧的設(shè)計 255.3.1ARP協(xié)議的實現(xiàn) 265.3.2IP協(xié)議與ICMP協(xié)議的實現(xiàn) 275.3.3TCP與UDP協(xié)議的實現(xiàn) 29本章小結(jié) 32第六章總結(jié)與展望 336.1全文總結(jié) 336.2不足與展望 33參考文獻(xiàn) 35致謝 37附錄 38第一章緒論1.課題的背景及其意義數(shù)據(jù)信號獲取以及轉(zhuǎn)移可以采用直接存儲在采集現(xiàn)場本地,收集一段時間的數(shù)據(jù)后由工作人員到采集現(xiàn)場將數(shù)據(jù)取回,或者通過某種途徑實時傳輸?shù)胶蠖?,前者對實時性要求比較高的場合以及某些較為危險的工業(yè)現(xiàn)場缺乏實用價值,后者能實時將采集的數(shù)據(jù)信號傳輸?shù)娇刂贫?,較為及時地反映出采集現(xiàn)場的實際情況,無疑具有更多的靈活性與實用價值,同時由于Internet的廣泛的覆蓋以及接口的通用性,傳輸?shù)姆绞酵ㄟ^網(wǎng)絡(luò)來進(jìn)行,將會使成本降低并且讓系統(tǒng)規(guī)劃的難度減小的優(yōu)勢。采用通過網(wǎng)絡(luò)實時傳輸數(shù)據(jù)的方式可以采用傳統(tǒng)的PC+數(shù)據(jù)采集卡的方式或者基于具備網(wǎng)絡(luò)功能的嵌入式設(shè)備的方式,前者雖然具備實現(xiàn)簡單,功能多樣化的優(yōu)點,但也存在體積龐大,穩(wěn)定性低,在惡劣環(huán)境中難以工作,成本較高,功能不可裁減等劣勢,相比較而言,嵌入式設(shè)備具備工作穩(wěn)定,易于攜帶和安裝,操作靈活的特點,同時還具有實時性好,集成度高,環(huán)境適應(yīng)能力強(qiáng),系統(tǒng)成本低,同時也易于根據(jù)實際需要進(jìn)行功能的添加與裁減等優(yōu)點,在各種數(shù)據(jù)信號獲取的各種應(yīng)用場合,將得到越來越廣泛的應(yīng)用,是今后的一個發(fā)展趨勢。在網(wǎng)絡(luò)中傳輸圖像數(shù)據(jù),由于網(wǎng)絡(luò)的傳輸速率有限,為了實現(xiàn)圖像數(shù)據(jù)的穩(wěn)定傳輸,必須對圖像進(jìn)行壓縮,無損壓縮的壓縮比比較低,對降低碼率的貢獻(xiàn)有限,所以在對圖像質(zhì)量沒有精確要求的情況下通常采用有損壓縮算法。由于嵌入式系統(tǒng)具有計算能力有限的特性,而這是設(shè)計面向一般PC或者工作站的圖像壓縮算法所不需要考慮的,其壓縮算法有其固有的特點,需要單獨對其進(jìn)行研究。目前針對嵌入式系統(tǒng)進(jìn)行圖像壓縮的工作,主要集中在對動態(tài)圖像實時壓縮算法實現(xiàn)的研究和基于專用圖像壓縮芯片構(gòu)架實用系統(tǒng)上,對于對成本敏感,每秒需要傳輸?shù)膱D像的幀數(shù)只要求在若干幀以內(nèi)的場合下適用的壓縮算法的研究還鮮有所聞,隨著工業(yè)以太網(wǎng)技術(shù)和Internet的迅速發(fā)展,越來越多圖像獲取設(shè)備將接入網(wǎng)絡(luò),這種較為低端的網(wǎng)絡(luò)圖像傳輸設(shè)備的應(yīng)用將越來越廣泛,對于其上的圖像壓縮算法的進(jìn)行一定的探討,實現(xiàn)一個同時具備網(wǎng)絡(luò)功能和圖像壓縮功能的嵌入式設(shè)備,對該領(lǐng)域進(jìn)行一次有益的探索與嘗試,是一項很有意義的工作。2.本文所做工作本文第二章介紹了相關(guān)的背景知識,包括嵌入式系統(tǒng),圖像的網(wǎng)絡(luò)傳輸,以及兩者相結(jié)合的討論。第三章從系統(tǒng)架構(gòu)的角度對實現(xiàn)的系統(tǒng)進(jìn)行描述,介紹了系統(tǒng)總體方案,芯片選型的考慮和系統(tǒng)集成的具體工作。第四章重點介紹了TCP/IP協(xié)議以及相關(guān)協(xié)議,為下一章的的網(wǎng)絡(luò)傳輸TCP/IP協(xié)議的設(shè)計做好理論鋪墊。第五章全面地介紹了系統(tǒng)的軟件設(shè)計工作,包括操作系統(tǒng)的移植過程,嵌入式TCP/IP協(xié)議的設(shè)計,以及在應(yīng)用層實現(xiàn)網(wǎng)絡(luò)圖像數(shù)據(jù)傳輸。第六章對全文進(jìn)行簡明的總結(jié),并對該領(lǐng)域的研究進(jìn)行展望。第二章嵌入式系統(tǒng)及圖像的網(wǎng)絡(luò)傳輸2.1嵌入式系統(tǒng)概述2.1.1嵌入式系統(tǒng)的定義根據(jù)IEEE(國際電氣和電子工程師協(xié)會)的定義,嵌入式系統(tǒng)是“用于控制、監(jiān)視或者輔助操作機(jī)器和設(shè)備的裝置(devicesusedtocontrol,monitor,orassisttheoperationofequipment,maehineryorplants)。嵌入式系統(tǒng)定義:是現(xiàn)代科學(xué)的多學(xué)科互相融合的以應(yīng)用技術(shù)產(chǎn)品為核心,以計算機(jī)技術(shù)為基礎(chǔ),以通信技術(shù)為載體,以消費類產(chǎn)品為對象,引入各類傳感器,進(jìn)入Internet網(wǎng)絡(luò)連接,適應(yīng)應(yīng)用環(huán)境的產(chǎn)品。2.1.2嵌入式系統(tǒng)的特點(1)嵌入式系統(tǒng)通常是面向特定應(yīng)用的。嵌入式系統(tǒng)的專用性很強(qiáng),其中的軟件系統(tǒng)和硬件的結(jié)合非常緊密,一般需要針對硬件進(jìn)行系統(tǒng)的移植,同時針對不同的任務(wù),往往需要對系統(tǒng)進(jìn)行較大更改,程序的編譯下載要和系統(tǒng)相結(jié)合,這種修改和通用軟件的“升級”是完全不同的概念。(2)系統(tǒng)精簡。嵌入式系統(tǒng)一般沒有系統(tǒng)軟件和應(yīng)用軟件的明顯區(qū)分,不要求其功能設(shè)計及實現(xiàn)上過于復(fù)雜,這樣一方面利于控制系統(tǒng)成本,同時也利于實現(xiàn)系統(tǒng)安全。(3)高實時性嵌入式操作系統(tǒng)。這是嵌入式軟件的基本要求,而且軟件要求固態(tài)存儲,以提高速度。軟件代碼要求高質(zhì)量和高可靠性、實時性。(4)為了提高執(zhí)行速度和系統(tǒng)可靠性,嵌入式系統(tǒng)中的軟件一般都固化在存儲器芯片或單片機(jī)本身中,而不是存貯于磁盤等載體中。(5)嵌入式軟件開發(fā)走向標(biāo)準(zhǔn)化。為了合理地調(diào)度多任務(wù)、利用系統(tǒng)資源、系統(tǒng)函數(shù)以及和專家?guī)旌瘮?shù)接口,用戶必須自行選配RTOS(RealTimeOperatingSystem)開發(fā)平臺,這樣才能保證程序執(zhí)行的實時性、可靠性,并減少開發(fā)時間,保障軟件質(zhì)量。(6)嵌入式系統(tǒng)本身不具備自主開發(fā)能力,即使設(shè)計完成以后用戶通常也是不能對其中的程序功能進(jìn)行修改的,必須有一套開發(fā)工具和環(huán)境才能進(jìn)行開發(fā)。開發(fā)時往往有主機(jī)和目標(biāo)機(jī)的概念,主機(jī)用于程序的開發(fā),目標(biāo)機(jī)作為最后的執(zhí)行機(jī),開發(fā)時需要交替結(jié)合進(jìn)行。2.1.3嵌入式系統(tǒng)的組成嵌入式系統(tǒng)包括硬件和軟件兩部分。圖2.1嵌入式系統(tǒng)的組成框圖1.專用硬件包括嵌入式處理器、存儲器和I/O端口及外圍設(shè)備等。其核心是嵌入式處理器。嵌入式處理器一般具備以下4個特點:①對實時多任務(wù)有很強(qiáng)的支持能力,能完成多任務(wù)并且有較短的中斷響應(yīng)時間,從而使內(nèi)部的代碼和實時內(nèi)核的執(zhí)行時間減少到最低限度;②具有功能很強(qiáng)的存儲區(qū)保護(hù)功能。這是由于嵌入式系統(tǒng)的軟件結(jié)構(gòu)已模塊化,而為了避免在軟件模塊之間出現(xiàn)錯誤的交叉作用,需要設(shè)計強(qiáng)大的存儲區(qū)保護(hù)功能,同時也有利于軟件診斷;③可擴(kuò)展的處理器結(jié)構(gòu),以能最迅速地開發(fā)出滿足應(yīng)用的最高性能的嵌入式微處理器為準(zhǔn);④嵌入式微處理器必須功耗很低,尤其是用于便攜式的無線及移動的計算和通信設(shè)備,靠電池供電的嵌入式系統(tǒng)更是如此。2.應(yīng)用軟件是實現(xiàn)嵌入式系統(tǒng)功能的關(guān)鍵,包括操作系統(tǒng)軟件和應(yīng)用程序。有時設(shè)計人員把這兩種軟件組合在一起。應(yīng)用程序控制著系統(tǒng)的運(yùn)作和行為;而操作系統(tǒng)控制著應(yīng)用程序編程與硬件的交互作用。嵌入式系統(tǒng)軟件的特征如下:①軟件要求固態(tài)化存儲。為了提高執(zhí)行速度和系統(tǒng)可靠性,嵌入式系統(tǒng)中的軟件一般固化在存儲器芯片或單片機(jī)本身中,而不存貯于磁盤等載體中;②軟件代碼高質(zhì)量、高可靠性。盡管半導(dǎo)體技術(shù)的發(fā)展使處理器速度不斷提高、片上存儲器容量不斷增加,但在大多數(shù)應(yīng)用中,存儲空間仍然是寶貴的,還存在實時性的要求。為此要求程序編寫和編譯工具的質(zhì)量要高,以減少程序二進(jìn)制代碼長度、提高執(zhí)行速度;③系統(tǒng)軟件(OS)的高實時性是基本要求。在多任務(wù)嵌入式系統(tǒng)中,對重要性各不相同的任務(wù)進(jìn)行統(tǒng)籌兼顧的合調(diào)度是保證每個任務(wù)及時執(zhí)行的關(guān)鍵,單純通過提高處理器速度是無法完成和沒有效率的,這種任務(wù)調(diào)度只能由優(yōu)化編寫的系統(tǒng)軟件來完成。2.1.4嵌入式Linux本文選擇的嵌入式系統(tǒng)為Linux。嵌入式Linux支持多種體系結(jié)構(gòu),有強(qiáng)大的網(wǎng)絡(luò)功能支持,支持多文件系統(tǒng),有豐富的外設(shè)驅(qū)動,此外Linux還具備一整套工具鏈,使用戶容易自行建立嵌入式系統(tǒng)的開發(fā)環(huán)境、交叉運(yùn)行環(huán)境,并且可以跨越嵌入式系統(tǒng)開發(fā)中仿真工具的障礙。一般開發(fā)嵌入式操作系統(tǒng)的程序調(diào)試和跟蹤都是使用仿真器來實現(xiàn)的,而使用Linux系統(tǒng)做原型的時候,可以繞過這個障礙,直接使用內(nèi)核調(diào)試器來做操作系統(tǒng)的內(nèi)核調(diào)試和查錯。嵌入式應(yīng)用系統(tǒng)的體系結(jié)構(gòu)可用圖2.2分層方式描述:第五層嵌入式應(yīng)用軟件第四層中間支撐軟件層第三層硬件無關(guān)的操作系統(tǒng)內(nèi)核層第二層硬件抽象層(HAL)第一層硬件系統(tǒng)圖2.2嵌入式應(yīng)用系統(tǒng)的體系結(jié)構(gòu)分層體系結(jié)構(gòu)層與層之間的依賴關(guān)系是上層完全依賴于下層,這種依賴主要是由明確定義的接口來實現(xiàn)的,能很好的滿足體系結(jié)構(gòu)的要求。2.1.5嵌入式系統(tǒng)開發(fā)與調(diào)試由于開發(fā)平臺受到存儲容量和功能的限制,嵌入式應(yīng)用的開發(fā)和調(diào)試需要借助一套專門的開發(fā)工具和軟硬件環(huán)境來完成。硬件環(huán)境包括:具有文件傳送功能的宿主機(jī),具有編譯調(diào)試功能的仿真器。軟件包括:操作系統(tǒng)軟件、編譯調(diào)試軟件、文件傳輸軟件等。嵌入式應(yīng)用系統(tǒng)設(shè)計完成以后,一般不具備在其上進(jìn)行進(jìn)一步開發(fā)的能力,如果要進(jìn)行功能的擴(kuò)充和改進(jìn),必須在宿主機(jī)上進(jìn)行重新設(shè)計。嵌入式應(yīng)用軟件開發(fā)可以通過兩種途徑進(jìn)行:一種是直接利用匯編和嵌入式高級語言對硬件編程,由于嵌入式程序具有直接在CPU芯片上運(yùn)行的能力,這種程序只需要在其開發(fā)調(diào)試仿真器環(huán)境下編譯運(yùn)行通過后直接下載ROM即可;第二種是為了利用CPU的強(qiáng)大功能,便于對硬件和軟件的管理,引入嵌入式的操作系統(tǒng)和相應(yīng)的編譯環(huán)境,由操作系統(tǒng)來管理軟硬件資源(存儲管理,文件管理,進(jìn)程管理,中斷管理等)。由于操作系統(tǒng)對高級語言(C語言)的支持和其強(qiáng)大的網(wǎng)絡(luò)功能,我們可以進(jìn)行高級語言的編程,屏蔽對低層的直接訪問,使得具有復(fù)雜功能的應(yīng)用程序的編寫和實現(xiàn)變得更加容易和方便。2.2基于嵌入式系統(tǒng)的圖像的網(wǎng)絡(luò)傳輸在網(wǎng)絡(luò)中傳輸圖像數(shù)據(jù),由于網(wǎng)絡(luò)的傳輸速率有限,為了實現(xiàn)圖像數(shù)據(jù)的穩(wěn)定傳輸,必須對圖像數(shù)據(jù)進(jìn)行壓縮,無損壓縮的壓縮比比較低,對降低碼率的貢獻(xiàn)有限,所以在對圖像質(zhì)量沒有精確要求的情況下通常采用有損壓縮算法。由于嵌入式系統(tǒng)具有計算能力有限的特性,需要基于該特點考慮具有適用性和實用性的壓縮算法。目前針對嵌入式系統(tǒng)進(jìn)行圖像壓縮的工作,主要集中在以下的兩個方面:(1)動態(tài)圖像的實時壓縮:要求對視頻信號進(jìn)行實時的壓縮,壓縮算法基于通用的標(biāo)準(zhǔn),應(yīng)用為視頻監(jiān)控系統(tǒng)或者視頻會議系統(tǒng),標(biāo)準(zhǔn)為MPEG-2,MPEG-4,H.264等,一般使用高端數(shù)字信號處理器如TI的6200系列或者Philps的Trimedia來實現(xiàn)算法,配合處理能力強(qiáng)的高端控制器如ARM9,XScale,使用嵌入式Linux或者嵌入式WindowsXP作為操作系統(tǒng),或者是使用高中端處理器配合視頻壓縮專用芯片來構(gòu)架系統(tǒng),這種技術(shù)的典型應(yīng)用是銀行系統(tǒng)中的24小時實時監(jiān)控錄像,特點是對實時性要求高,要求壓縮后重建的圖像質(zhì)量好,對成本較不敏感。(2)靜態(tài)圖像的高質(zhì)量壓縮:要求重建后的圖像與原圖相差極小,一般使用無損壓縮或者根據(jù)JPEG2000標(biāo)準(zhǔn)進(jìn)行低壓縮比有損壓縮,使用中檔數(shù)字信號處理器如TI的6711配合中檔處理器。典型應(yīng)用是醫(yī)學(xué)圖像采集與存儲系統(tǒng),特點為對重建的圖像質(zhì)量要求高。2.3嵌入式網(wǎng)絡(luò)傳輸?shù)膱D像壓縮算法本文所考慮的應(yīng)用方向是在嵌入式系統(tǒng)上的壓縮算法,因此采用基于零樹小波編碼的算法。該算法具有以下特點:(1)算法思想簡潔,易于通過程序?qū)崿F(xiàn),并且可以通過對原有算法某些步驟的改善與省略實現(xiàn)精簡的目的;(2)零樹小波編碼是一種嵌入式編碼,編碼所得的比特流按其重要性排序,可以在任意一點結(jié)束編碼,允許精確度達(dá)到一個目標(biāo)壓縮率和目標(biāo)比特率,而仍能確切地產(chǎn)生同樣的圖像?;诹銟湫〔ň幋a的算法進(jìn)行圖像壓縮大體需要經(jīng)過以下步驟:(1)選擇小波基及其對應(yīng)的小波濾波器;(2)輸入待壓縮圖像點值序列;(3)給出分解層數(shù)L和圖像數(shù)據(jù)向量長度k;(4)對源圖像采用分解算法進(jìn)行小波變換,得到不同層次不同圖號的子圖;(5)根據(jù)不同層次不同子圖的特點,對相應(yīng)小波系數(shù)的各個部分進(jìn)行嵌入式編碼。反過來,在恢復(fù)圖像(圖像解壓縮)時,需先根據(jù)密碼書還原出各層小波系數(shù),最后利用重構(gòu)算法對還原后的小波系數(shù)進(jìn)行反變換以重建源圖像。本章小結(jié)本章對嵌入式系統(tǒng)的定義、特點以及本文所采用的嵌入式操作系統(tǒng)Linux進(jìn)行介紹,并介紹了嵌入式網(wǎng)絡(luò)與圖像獲取結(jié)合的優(yōu)點,同時分析了圖像采集速率要求不高的嵌入式系統(tǒng)上實現(xiàn)的壓縮算法的特點,得出零樹小波算法作為其壓縮算法較佳的結(jié)論。第三章基于嵌入式系統(tǒng)的圖像網(wǎng)絡(luò)傳輸?shù)南到y(tǒng)設(shè)計本文設(shè)計的系統(tǒng)是面向成本敏感,每秒需要傳輸?shù)膱D像的幀數(shù)只要求在若干幀以內(nèi)的場合下適用的嵌入式圖像網(wǎng)絡(luò)傳輸應(yīng)用,前面章節(jié)己經(jīng)說明該系統(tǒng)的理想實現(xiàn)模式是在一個中檔處理器上運(yùn)行一個非標(biāo)準(zhǔn)的靜態(tài)圖像壓縮算法程序來實現(xiàn)壓縮。從系統(tǒng)設(shè)計的角度來考察,設(shè)計工作包括系統(tǒng)總體方案的考慮,硬件平臺的搭建與系統(tǒng)軟件實現(xiàn)。3.1系統(tǒng)結(jié)構(gòu)設(shè)計本系統(tǒng)結(jié)構(gòu)框圖如下:圖3.1系統(tǒng)結(jié)構(gòu)框圖由于系統(tǒng)同時需要進(jìn)行圖像壓縮,數(shù)據(jù)的網(wǎng)絡(luò)傳輸,這些功能模塊之間存在并行執(zhí)行的可能性,引入操作系統(tǒng),基于操作系統(tǒng)的多任務(wù)模式,利用操作系統(tǒng)提供的任務(wù)間通信機(jī)制對應(yīng)用程序進(jìn)行設(shè)計有利于降低應(yīng)用程序的設(shè)計難度與提高其執(zhí)行效率。由于系統(tǒng)資源有限,網(wǎng)絡(luò)功能的實現(xiàn)在軟件上由一個功能精簡的嵌入式TCP/IP協(xié)議棧來實現(xiàn),該協(xié)議棧是TCP/IP協(xié)議棧的一個功能子集,只保留一些對于系統(tǒng)必須的協(xié)議(關(guān)于該協(xié)議棧的考慮,將在軟件設(shè)計部分詳細(xì)分析)。網(wǎng)絡(luò)接入方式的考慮,考慮到以太網(wǎng)技術(shù)的的優(yōu)點:成本低;速度在近年得到較大提高以及因普遍應(yīng)用形成了廣泛支持(以太網(wǎng)是世界上應(yīng)用最多的網(wǎng)絡(luò),包括各種工業(yè)用網(wǎng)絡(luò),有超過93%的網(wǎng)絡(luò)節(jié)點為以太網(wǎng)。)。選擇以太網(wǎng)作為網(wǎng)絡(luò)接入方式使得系統(tǒng)具有較高的通用性與較強(qiáng)的適應(yīng)性。從系統(tǒng)的功能考慮,硬件平臺的架構(gòu)基于主控芯片+以太網(wǎng)控制器+其他必要外設(shè),每一模塊的功能界定清晰,通過一定的接口設(shè)計工作各模塊之間可以很好地實現(xiàn)協(xié)調(diào)工作。系統(tǒng)設(shè)計根據(jù)設(shè)計的目標(biāo)確定了本系統(tǒng)設(shè)計的框架,軟件與硬件的大體結(jié)構(gòu),是系統(tǒng)實現(xiàn)的基礎(chǔ)。下面將對硬件架構(gòu)與軟件設(shè)計的具體實現(xiàn)進(jìn)行說明。3.2硬件平臺設(shè)計圖3.2硬件結(jié)構(gòu)框圖硬件平臺設(shè)計的首要工作是選擇主控芯片,對于本文設(shè)計系統(tǒng),主控芯片是一個具有中等控制能力與計算能力的處理器,性價比較高,具備盡量多的系統(tǒng)所需的片上外設(shè)?;谶@樣的考慮,選擇ARM系列的三星公司的S3C2440處理器作為系統(tǒng)的主控芯片。3.2.1S3C2440體系結(jié)構(gòu)及特點ARM(AdvancedRISCMachine)是基于精簡指令集的一種計算機(jī)體系結(jié)構(gòu)實現(xiàn),ARM系列的處理器當(dāng)前有ARM7,ARM9,ARM9E,ARM10等多個產(chǎn)品。所有的ARM處理器都共享ARM通用的基礎(chǔ)體系結(jié)構(gòu),所以開發(fā)者在不同的ARM處理器上做操作系統(tǒng)移植時,將可以節(jié)省工作量,這無疑將大大降低軟件開發(fā)成本。三星公司推出的S3C2440A處理器,是一個16/32位的RISC微處理器。內(nèi)含ARM920T內(nèi)核,ARM920T實現(xiàn)了MMU,AMBA,BUS和Harvard高速緩沖體系結(jié)構(gòu),其低功耗且全靜態(tài)設(shè)計特別適合對成本和功耗敏感型的應(yīng)用。S3C2440微處理器提供了一系列完整的系統(tǒng)外圍設(shè)備圖3.3S3C2440結(jié)構(gòu)框圖其中的ARM920T處理器內(nèi)核采用哈佛結(jié)構(gòu),5級流水線(包括取指、分析、執(zhí)行、訪存、寫存);分立的指令和數(shù)據(jù)Cache都是16KB,8個字的數(shù)據(jù)總線;采用增強(qiáng)的ARM體系V4的MMU,以提供對指令和數(shù)據(jù)地址的翻譯和訪問許可檢查;支持ARM調(diào)試結(jié)構(gòu),包含了輔助軟件和硬件調(diào)試的邏輯電路;還具有協(xié)處理器支持。ARM920T的功能模塊如圖3.4所示:ARM920T處理器的編程模型包括ARM9TDMI內(nèi)核以及以下增加和更改。1.ARM920T處理器包含了兩個協(xié)處理器:CP14:允許軟件訪問調(diào)試通信通道。CP15:系統(tǒng)控制協(xié)處理器,提供附加的寄存器,用來配置和控制ARM920T的Cathe、MMU、保護(hù)系統(tǒng)、時鐘模式和其他系統(tǒng)操作,可以使用MCRM和RC訪問CP15定義的寄存器。2.提供了外部協(xié)處理器界面,允許在同一片上布置相關(guān)的協(xié)處理器,例如:一個浮點運(yùn)算單元。可以用適當(dāng)?shù)膮f(xié)處理器指令訪問任何一個掛接在外部協(xié)處理器界面上的協(xié)處理器的寄存器和并進(jìn)行操作。3.取指,讀/寫數(shù)據(jù)的內(nèi)存訪問可以放到Cahte中或緩沖器(Buffer)中。4.內(nèi)存管理單元(MMU)頁表常駐主存,用來描述虛存到物理內(nèi)存的轉(zhuǎn)換、訪問許可、Cathe和寫緩沖配置等。頁表被操作系統(tǒng)軟件所創(chuàng)建,任何時候,一個存儲訪問導(dǎo)致TLB丟失時,ARM920TMMU硬件都會自動訪問頁表。5.ARM920T有一個調(diào)試界面接口,允許使用硬件和軟件調(diào)試工具實時跟蹤指令和數(shù)據(jù)。圖3.4ARM920T功能塊圖1.S3C24401.2V內(nèi)核供電,1.8V/2.5V/3.3V存儲器供電,3.3V外部I/O供電,具備16KB的I—Cache和16KB的D—Cache/MMU;外部存儲控制器(SDRAM控制和片選邏輯);LCD控制器(最大支持4K色STN和256K色TFT)提供1通道LCD專用DMA;4通道DMA并有外部請求引腳;3通道UART(IrDA1.0,16字節(jié)TxFIFO,和16字節(jié)RxFIFO);2通道SPI;1通道主從ⅡC—BUS;1通道ⅡS—BUS音頻編解碼器接口;AC’97解碼器接口;兼容SD主接口協(xié)議1.0版和MMC卡協(xié)議2.11兼容版;2端口USB主機(jī)/1端口USB設(shè)備(1.1版);4通道PWM定時器和1通道內(nèi)部定時器/看門狗定時器;8通道10比特ADC和觸摸屏接口;具有日歷功能的RTC;相機(jī)接口(最大4096*4096像素的投入支持;2048*2048像素的投入,支持縮放);130個通用I/0口和24通道外部中斷源;功耗控制模式:具有普通,慢速,空閑和掉電模式;具有PLL片上時鐘發(fā)生器。2.S3C2440地址空間分配:S3C2440支持兩種啟動模式:一種是從NANDFLASH啟動;一種是從NORFLASH啟動。在這兩種啟動模式下,各片選的存儲空間分配是不同的,這兩種啟動模式的存儲分配圖如下:圖3.5(a)圖是nGCS0片選的NORFLASH啟動模式下的存儲分配圖;(b)圖是NANDFLASH啟動模式下的存儲分配圖。在NANDFLASH模式啟動下,內(nèi)部的4KBytesBootsRAM被映射到nGCS0片選的空間;在NORFLASH啟動模式下,與nGCS0相連的外部存儲器NORFLASH就被映射到nGCS0片選的空間。SDRAM地址空間:0x30000000~0x34000000。3.S3C2440總電源電路:圖3.6S3C2440總電源電路圖本系統(tǒng)主要采用2片SDRAM和1片F(xiàn)lash做為儲存器。SDRAM具有存取速度快的特點,適用于被訪問頻率較高的場合。由于本系統(tǒng)需要傳輸,存儲大量的數(shù)據(jù),因此采用一片32位32MB的SDRAM專門存儲這些數(shù)據(jù)。另一片32MB的SDRAM供整個系統(tǒng)使用。Flash存儲器的特點是掉電不易丟失數(shù)據(jù),適用于存放永久性數(shù)據(jù)。本系統(tǒng)采用64MB的NANDFlash來固化操作系統(tǒng)內(nèi)核,應(yīng)用程序以及其他永久性數(shù)據(jù)。由于S3C2440沒有內(nèi)置的以太網(wǎng)控制器,所以采用了低功耗,性能優(yōu)越的16位以太網(wǎng)網(wǎng)控制器——CS8900,它負(fù)責(zé)處理有關(guān)以太網(wǎng)數(shù)據(jù)楨的發(fā)送和接收。3.3軟件設(shè)計軟件設(shè)計工作主要包括系統(tǒng)啟動代碼編寫,各外設(shè)驅(qū)動程序編寫,操作系統(tǒng)選擇及移植,嵌入式TCP/IP協(xié)議棧編寫,應(yīng)用程序設(shè)計等,其中啟動代碼,外設(shè)驅(qū)動程序(包括DMA,TIMER,中斷控制器,串口等)實現(xiàn)較為簡單,不再占用論文篇幅進(jìn)行詳細(xì)介紹。操作系統(tǒng)選擇及移植,嵌入式TCP/IP協(xié)議棧編寫,應(yīng)用程序設(shè)計的內(nèi)容較多,且體現(xiàn)了本文主要的工作,為其單獨安排在第五章進(jìn)行介紹。本章小結(jié)本章介紹了基于嵌入式系統(tǒng)的圖像網(wǎng)絡(luò)傳輸?shù)南到y(tǒng)設(shè)計的工作,主要討論了總體方案的考慮與硬件和軟件平臺的設(shè)計,介紹了本文所采用的芯片S3C2440處理器。第四章TCP/IP協(xié)議概述4.1網(wǎng)絡(luò)分層結(jié)構(gòu)為了減少協(xié)議設(shè)計的復(fù)雜性,大多數(shù)網(wǎng)絡(luò)都按層(layer)或級(level)的方式來組織,每一層都建立在它的下層之上。不同的網(wǎng)絡(luò),其層的數(shù)量、各層的名字、內(nèi)容和功能都不盡相同。但在所有的網(wǎng)絡(luò)中,每一層的目的都是向它的上一層提供一定的服務(wù),而把如何實現(xiàn)這一服務(wù)的細(xì)節(jié)對上一層加以屏蔽。關(guān)于協(xié)議分層,有兩個思想占據(jù)了該領(lǐng)域的主導(dǎo)地位。第一個思路基于國際標(biāo)準(zhǔn)化組織ISO早期所做的工作,稱為ISO的OSI開放系統(tǒng)互聯(lián)參考模型(opensysteminterconnectionreferencemodel);第二個就是TCP/IP參考模型。4.1.1OSI七層參考模型圖4.1OSI七層網(wǎng)絡(luò)模型結(jié)構(gòu)OSI參考模型是關(guān)于如何把開放式系統(tǒng)(即為了與其他系統(tǒng)通信而相互開放的系統(tǒng))連接起來的。模型共有七層,現(xiàn)將其各主要功能分述如下:物理層(physicallayer):涉及到通信在信道上傳輸?shù)脑急忍亓?,主要處理機(jī)械的、電氣的和過程的接口,以及物理層下的物理傳輸介質(zhì)等問題。數(shù)據(jù)鏈路層(datalinklayer):主要任務(wù)是加強(qiáng)物理層傳輸原始比特的功能,使之對網(wǎng)絡(luò)層顯現(xiàn)為一條無錯線路。傳輸以幀的格式實現(xiàn)。其中還有一個特殊的子層——介質(zhì)訪問子層,它主要控制對共享信道的訪問。網(wǎng)絡(luò)層(networklayer):關(guān)鍵問題是確定分組從源端到目的端如何選擇路由。傳輸層(transportlayer):基本功能是從會話層接收數(shù)據(jù),并且在必要時把它分成較小的單元,傳遞給網(wǎng)絡(luò)層,并確定到達(dá)對方的各段信息準(zhǔn)確無誤。通常會話層每請求建立一個傳輸連接,傳輸層就為其創(chuàng)造一個獨立的網(wǎng)絡(luò)連接。會話層(sessionlayer):允許不同機(jī)器上的用戶建立會話關(guān)系,其服務(wù)有管理對話、令牌管理、同步等。表示層(presentationlayer):完成某些特定的功能,如用一種大家一致同意的標(biāo)準(zhǔn)方法對數(shù)據(jù)編碼。應(yīng)用層(applicationlayer):包含大量人們普遍需要的協(xié)議,如文件傳輸。OSI模型的數(shù)據(jù)傳輸,是一個關(guān)鍵的概念,雖然數(shù)據(jù)的實際傳輸方向是垂直的,但每一層在編程時卻好像數(shù)據(jù)一直是水平傳輸?shù)摹?.1.2TCP/IP參考模型廣泛地講,TCP/IP軟件分成五個概念層次,建立在第五層上的是四個軟件層,圖4.2給出了這些概念性層次結(jié)構(gòu)以及在這些層次之間傳輸?shù)臄?shù)據(jù)形式。圖4.2TCP/IP網(wǎng)絡(luò)層次模型及各層之間傳輸數(shù)據(jù)形式應(yīng)用層(applicationlayer):在這個最高層,用戶調(diào)用應(yīng)用程序通過TCP/IP互聯(lián)網(wǎng)來訪問可用的服務(wù)。與各個運(yùn)輸層協(xié)議交互的應(yīng)用程序負(fù)責(zé)接受和發(fā)送數(shù)據(jù)。傳輸層(transportlayer):基本任務(wù)是提供應(yīng)用程序之間的通信服務(wù),這種通信又叫端到端通信。不但要系統(tǒng)地管理信息的流動,還要提供可靠的傳輸服務(wù),以確保數(shù)據(jù)到達(dá)無差錯,無亂序。網(wǎng)絡(luò)層(internetlayer):用來處理機(jī)器之間的通信問題。其傳輸格式表現(xiàn)為IP數(shù)據(jù)報,還要根據(jù)需要發(fā)出和接受ICMP(Internet控制報文協(xié)議)差錯和控制報文。網(wǎng)絡(luò)接口層(networkinterfacelayer):又稱數(shù)據(jù)鏈路層,負(fù)責(zé)接受IP數(shù)據(jù)報并把數(shù)據(jù)報通過選定的網(wǎng)絡(luò)發(fā)送出去。它包括一個設(shè)備驅(qū)動程序,也可能包括一個復(fù)雜的子系統(tǒng),使用自己的數(shù)據(jù)鏈路協(xié)議,如以太網(wǎng)協(xié)議。4.2TCP/IP網(wǎng)絡(luò)協(xié)議TCP/IP網(wǎng)絡(luò)以一種自治和對等的方式操作,互聯(lián)的計算機(jī)都可以作為主機(jī)出現(xiàn),任一計算機(jī)的應(yīng)用都可以動態(tài)地與對等計算機(jī)上的另一個應(yīng)用建立一個連接,而不需要中心控制服務(wù)器。對等網(wǎng)絡(luò)的主要優(yōu)點是允許網(wǎng)絡(luò)范圍內(nèi)的系統(tǒng)資源得到最大限度的共享。TCP/IP是一個網(wǎng)絡(luò)協(xié)議族,協(xié)議按上面所述不同的網(wǎng)絡(luò)層次進(jìn)行開發(fā),每一層分別復(fù)雜不同的通信功能,相應(yīng)的有不同的協(xié)議。TCP/IP協(xié)議的核心是TCP、UDP和IP協(xié)議。4.2.1嵌入式TCP/IP協(xié)議嵌入式系統(tǒng)與TCP/IP網(wǎng)絡(luò)的互聯(lián),這一技術(shù)在許多領(lǐng)域得以廣泛的應(yīng)用。但由于網(wǎng)絡(luò)協(xié)議的復(fù)雜性與嵌入式系統(tǒng)的MCU相對簡單之間的矛盾,極大地制約了嵌入式系統(tǒng)實現(xiàn)網(wǎng)絡(luò)化的進(jìn)程。傳統(tǒng)的TCP/IP協(xié)議是以PC機(jī)、服務(wù)器為應(yīng)用平臺的,協(xié)議復(fù)雜,功能強(qiáng)大,面面俱到,而且沒有實時的概念,這種情況與嵌入式系統(tǒng)的要求是格格不入的。嵌入式TCP/IP協(xié)議即是從以滿足嵌入式系統(tǒng)的實際需求為目的這一指導(dǎo)思想出發(fā),建立在嵌入式Internet理論的基礎(chǔ)上,通過對龐大、功能齊全的TCP/IP協(xié)議的仔細(xì)研究,對標(biāo)準(zhǔn)的TCP/IP協(xié)議進(jìn)行了一定的取舍,從而制定出了一套簡單的,適用于嵌入式系統(tǒng)的并且能完成相應(yīng)網(wǎng)絡(luò)功能的協(xié)議,稱為嵌入式TCP/IP協(xié)議。4.2.2IP協(xié)議IP協(xié)議位于網(wǎng)絡(luò)層,是TCP/IP協(xié)議族中最核心的協(xié)議,所有的TCP、UDP、ICMP及IGMP數(shù)據(jù)都以IP數(shù)據(jù)包格式傳輸。IP是一個無連接和不可靠協(xié)議,不可靠的意思是它不能保證IP數(shù)據(jù)包能成功地到達(dá)目的地,IP僅提供最好的傳輸服務(wù),如果發(fā)生某種錯誤,IP丟棄該數(shù)據(jù)包,然后發(fā)送ICMP消息包給信源端,任何要求的可靠性必須由上層來提供。無連接是指IP并不維護(hù)任何關(guān)于后續(xù)數(shù)據(jù)包的狀態(tài)信息每個數(shù)據(jù)包的處理是相互獨立的,即IP數(shù)據(jù)包可以不按發(fā)送順序接受。IP最終要的作用是將數(shù)據(jù)包裝成為目的機(jī)IP地址的數(shù)據(jù)包;另一個重要的作用是將一個過長的數(shù)據(jù)包分解和重裝配;IP同樣也處理因數(shù)據(jù)包經(jīng)由ICMP而產(chǎn)生的傳輸問題;最后,IP規(guī)定網(wǎng)關(guān)設(shè)備如何處理數(shù)據(jù)包。4.2.3UDP/TCP協(xié)議UDP是一個簡單的面向數(shù)據(jù)包的運(yùn)輸層的協(xié)議。UDP和TCP都屬于IP上層的傳輸層協(xié)議,二者都使用端口號作為送往主機(jī)的解碼地址。UDP為維護(hù)數(shù)據(jù)包的整體性應(yīng)盡最大可能地選用校驗。UDP數(shù)據(jù)包的可靠性是與IP相當(dāng)?shù)模琔DP客戶機(jī)向指定的遠(yuǎn)端主機(jī)發(fā)送數(shù)據(jù)包時,并沒事先確認(rèn)對方是否做好了接收數(shù)據(jù)地準(zhǔn)備,所以,遠(yuǎn)端主機(jī)收到的數(shù)據(jù)包未能保證其正確的順序。但是由于TCP所傳數(shù)據(jù)流應(yīng)用了順序號和應(yīng)答措施,可以發(fā)現(xiàn)數(shù)據(jù)的丟失、段的失序和對傳輸錯誤的排除,所以TCP協(xié)議提供的是數(shù)據(jù)流的可靠傳輸。端口號表示發(fā)送進(jìn)程和接受進(jìn)程。需要指出的是由于IP層已經(jīng)把IP數(shù)據(jù)包分配給TCP或UDP(根據(jù)IP首部中協(xié)議字節(jié)段值),因此TCP端口號由TCP來查看,而UDP端口號由UDP來查看,TCP和UDP的端口號是相互獨立的。4.2.4ARP協(xié)議ARP地址解析協(xié)議,它是一個隱藏底層網(wǎng)絡(luò)物理編址、允許給每臺機(jī)器分配一個任意IP地址的底層協(xié)議。ARP提供的是一種把IP地址映射到物理地址的機(jī)制。因此我們要了解IP和物理地址兩種編址形式:IP地址:互聯(lián)網(wǎng)上的每個接口必須有一個唯一的Internet地址(也稱IP地址),IP地址長32bit。物理地址:該地址用來指明計算機(jī)所安裝的網(wǎng)卡的地址,網(wǎng)卡地址是由IEEE統(tǒng)一分配給網(wǎng)卡制造商的,每個網(wǎng)卡的地址在世界范圍內(nèi)是唯一的。所有的物理地址的MSB位的值為零,即48位網(wǎng)卡地址的最高位位“0”。以太網(wǎng)中所說的目的地址和源地址都是指物理地址。ARP是在源主機(jī)不知目的地址的前提下才需要的。協(xié)議的實現(xiàn)可以從兩個方面來考慮:一是發(fā)送方,在以太網(wǎng)幀的傳輸中是以物理地址為目的地址的,但在應(yīng)用層我們是以網(wǎng)絡(luò)的IP地址來操作的,當(dāng)給定一個目的站的IP地址時,發(fā)送方軟件會查詢它的ARP緩存,看是否有從該IP地址到物理地址的映射,若有,則軟件提取該物理地址,把數(shù)據(jù)放到使用該地址的幀中,并發(fā)送該幀,若沒有,則軟件必須廣播一個ARP請求并等待應(yīng)答。從接收方考慮,如果網(wǎng)絡(luò)上過來的是ARP請求幀,則查看自己是否是請求的目標(biāo)(是否與自己的IP地址相符),如果符合則發(fā)送ARP應(yīng)答幀。本章小結(jié)本章介紹了TCP/IP協(xié)議以及相關(guān)協(xié)議,為下一章的網(wǎng)絡(luò)傳輸TCP/IP協(xié)議的設(shè)計做好理論基礎(chǔ)。第五章基于嵌入式系統(tǒng)的圖像網(wǎng)絡(luò)傳輸?shù)能浖O(shè)計本章是系統(tǒng)設(shè)計中的核心部分,包括系統(tǒng)實現(xiàn)多任務(wù)運(yùn)行的基礎(chǔ)——操作系統(tǒng)的移植,網(wǎng)絡(luò)功能的基礎(chǔ)——TCP/IP協(xié)議棧的設(shè)計。5.1Linux在ARM硬件平臺上的移植5.1.1移植環(huán)境1.硬件資源及連接一臺PC機(jī),ARM硬件平臺,交叉串口連接線,交叉網(wǎng)線,USB連接線,5V穩(wěn)壓電源。用交叉串口連接線將開發(fā)板上的串口P1與PC機(jī)串口1相連;用交叉網(wǎng)線將CON3與PC機(jī)相連;用USB連接線將開發(fā)板與PC機(jī)相連;5V電源連接到開發(fā)板上。2.調(diào)試終端配置在PC機(jī)上DNW,在configuration中設(shè)置為:COM1,波特率為115200,8位,無奇偶位,停止位1,無硬件流。如下圖所示:圖5.1終端設(shè)置5.1.2建立交叉編譯環(huán)境交叉編譯是嵌入式開發(fā)過程中的一項重要技術(shù),它的主要特征是某機(jī)器中執(zhí)行的程序代碼不是在本機(jī)編譯生成,而是由另一臺機(jī)器編譯生成,一般把前者稱為目標(biāo)機(jī),后者稱為主機(jī)。嵌入式系統(tǒng)開發(fā)環(huán)境一般分成主機(jī)端(HOST)和目標(biāo)板(ATGRET)兩部分。目前一般采用的解決辦法是首先在通用計算機(jī)上編寫程序,通過交叉編譯生成目標(biāo)平臺上可運(yùn)行的二進(jìn)制代碼,再下載到目標(biāo)平臺上的特定位置上運(yùn)行。在主機(jī)端和目標(biāo)板之間需要通過某種方式進(jìn)行通信,如使用RS232串口。這種通信的目的在于發(fā)送控制指令和傳輸數(shù)據(jù),同時獲得反饋信息。采用交叉編譯的主要原因在于,多數(shù)嵌入式目標(biāo)系統(tǒng)不能提供足夠的資源供編譯過程使用,因而只好將編譯工程轉(zhuǎn)移到高性能的主機(jī)中進(jìn)行。Linux下的交叉編譯環(huán)境重要包括以下幾個部分:針對目標(biāo)系統(tǒng)的編譯器GCC;針對目標(biāo)系統(tǒng)的二進(jìn)制工具Binutils,包括ar,objcopy,strip工具集;目標(biāo)系統(tǒng)的標(biāo)準(zhǔn)C庫Glibc;目標(biāo)系統(tǒng)的Linux內(nèi)核頭文件;GNUMake工具??赏ㄟ^兩種方式建立ARMLinux交叉編譯環(huán)境:手動方式和使用集成環(huán)境。因手動方式比較繁瑣,這里只介紹使用集成環(huán)境建立方法。在Internet上我們可以得到一些整套的開放源碼嵌入式Linux開發(fā)工具,常用的有Denx公司的ELKD和TimeSys公司的TimesysLinux/GUN。這些工具鏈不僅包含了交叉編譯工具GCC、Binutils、GDB,而且包括可以直接使用的RAMDISKImage文件和文件系統(tǒng)制作工具等許多工具和元件。上述兩個集成交叉編譯環(huán)境都支持MIPS、PPC、ARM、x86、XScale等處理器。5.1.3BootLoaderBootLoader就是在操作系統(tǒng)內(nèi)核運(yùn)行之前運(yùn)行的一段小程序。通過這段小程序,我們可以初始化硬件設(shè)備、建立內(nèi)存空間的映射圖,從而將系統(tǒng)的軟硬件環(huán)境帶到一個合適的狀態(tài),以便為最終調(diào)用操作系統(tǒng)內(nèi)核準(zhǔn)備好正確的環(huán)境。從操作系統(tǒng)的角度看,BootLoader的總目標(biāo)就是正確地調(diào)用內(nèi)核來執(zhí)行。1.BootLoader所支持的CPU和嵌入式板每種不同的CPU體系結(jié)構(gòu)都有不同的BootLoader。有些BootLoader也支持多種體系結(jié)構(gòu)的CPU,比如U-Boot就同時支持ARM體系結(jié)構(gòu)和MIPS體系結(jié)構(gòu)。除了依賴于CPU的體系結(jié)構(gòu)外,BootLoader實際上也依賴于具體的嵌入式板級設(shè)備的配置。這也就是說,對于兩塊不同的嵌入式板而言,即使它們是基于同一種CPU而構(gòu)建的,要想讓運(yùn)行在一塊板子上的BootLoader程序也能運(yùn)行在另一塊板子上,通常也都需要修改BootLoader的源程序。2.BootLoader的安裝媒介(InstallationMedium)系統(tǒng)加電或復(fù)位后,所有的CPU通常都從某個由CPU制造商預(yù)先安排的地址上取指令。比如基于ARM920T的CPU在復(fù)位時通常都從地址0x00000000取它的第一條指令。而基于CPU構(gòu)建的嵌入式系統(tǒng)通常都有某種類型的固態(tài)存儲設(shè)備(比如:ROM、EEPROM或FLASH等)被映射到這個預(yù)先安排的地址上。以確保在系統(tǒng)加電后,CPU將首先執(zhí)行BootLoader程序。3.用來控制BootLoader的設(shè)備或機(jī)制主機(jī)和目標(biāo)機(jī)之間一般通過串口建立連接,BootLoader軟件在執(zhí)行時通常會通過串口來進(jìn)行I/0,比如:輸出打印信息到串口,從串口讀取用戶控制字符等。4.BootLoader的啟動過程有單階段(SingleStage)和多階段(MultiStage)之分。通常多階段的BootLoader能提供更為復(fù)雜的功能,以及更好的可移植性。從固態(tài)存儲設(shè)備上啟動的BootLoader大多都是2階段的啟動過程,也即啟動過程可以分為Stagel和Stage2兩部分。依賴于CPU體系結(jié)構(gòu)的代碼,比如設(shè)備初始化代碼等,通常都放在Stagel中,而且通常都用匯編語言來實現(xiàn),以達(dá)到短小精悍的目的。而Stage2則通常用C語言來實現(xiàn),這樣可以實現(xiàn)給復(fù)雜的功能,而且代碼會具有更好的可讀性和可移植性。5.BootLoader的操作模式(OperationMode)大多數(shù)BootLoader都包含兩種不同的操作模式:“啟動加載”模式和“下載”模式,這種區(qū)別僅對于開發(fā)人員才有意義。但從最終用戶的角度看,BootLoader的作用就是用來加載操作系統(tǒng),而并不存在所謂的啟動加載模式與下載工作模式的區(qū)別。①啟動加載(BootLoading)模式:這種模式也稱為“自主”(Autonomous)模式。也即BootLoader從目標(biāo)機(jī)上的某個固態(tài)存儲設(shè)備上將操作系統(tǒng)加載到RAM中運(yùn)行,整個過程并沒有用戶的介入。這種模式是BootLoader的正常工作模式,因此在嵌入式產(chǎn)品發(fā)布的時侯,BootLoader顯然必須工作在這種模式下。②下載(Downloading)模式:在這種模式下,目標(biāo)機(jī)上的BootLoader將通過串口連接或網(wǎng)絡(luò)連接等通信手段從主機(jī)(Host)下載文件,比如:下載內(nèi)核映像和根文件系統(tǒng)映像等。從主機(jī)下載的文件通常首先被BootLoader保存到目標(biāo)機(jī)的RAM中,然后再被BootLoader寫到目標(biāo)機(jī)上的FLASH類固態(tài)存儲設(shè)備中。BootLoader的這種模式通常在第一次安裝內(nèi)核與根文件系統(tǒng)時被使用;此外,以后的系統(tǒng)更新也會使用BootLoader的這種工作模式。工作于這種模式下的BootLoader通常都會向它的終端用戶提供一個簡單的命令行接口。6.BootLoader與主機(jī)之間進(jìn)行文件傳輸所用的通信設(shè)備及協(xié)議最常見的情況就是,目標(biāo)機(jī)上的BootLoader通過串口與主機(jī)之間進(jìn)行文件傳輸,傳輸協(xié)議通常是xmodem/ymodem/zmodem協(xié)議中的一種。但是,串口傳輸?shù)乃俣仁怯邢薜?,因此通過以太網(wǎng)連接并借助TFTP協(xié)議來下載文件是個更好的選擇,但此時一般需要主機(jī)方提供相應(yīng)的軟件。比如,在通過以太網(wǎng)連接和TFTP協(xié)議來下載文件時,主機(jī)方必須有一個軟件用來的提供TFTP服務(wù)。5.2燒寫和啟動Linux以及Linux內(nèi)核編譯5.2.1燒寫Linux內(nèi)核(1)上電啟動開發(fā)板,進(jìn)入BIOS界面。(2)USBDEVICE的連接線,選擇“1”,選擇USB下載,接著出現(xiàn)“Enteranewtemporarydownloadaddress:”的提示,在這個提示下輸入程序下載的地址,這里設(shè)置為0x32000000(不要與BIOS的地址0x30100000相沖突),同時要注意用USB下載要先在PC端裝好驅(qū)動程序,保證USB連接好,有時PC端出現(xiàn)發(fā)現(xiàn)無法識別的USB設(shè)備時,在BIOS中輸入ESC取消下載,等幾秒鐘后再輸入“1”啟動USB下載。(3)點擊“USBPort”“Transmit”選項,選擇zlmage(這個映像文件在光盤目錄的“目標(biāo)代碼”文件夾下),點擊“打開”,USB下載開始。下載結(jié)束后,會返回主功能菜單。(4)下載成功后,在出現(xiàn)主功能菜單后,選擇“4”,將出現(xiàn)提示,輸入“1”,在接下來的提示輸入“Y”,將zlmage燒寫到NANDFLASH的分區(qū)1中。燒寫成功后,會自動進(jìn)入主功能菜單。5.2.2燒寫根文件系統(tǒng)(1)上電啟動開發(fā)板,進(jìn)入BIOS界面。(2)USBDEVICE的連接線,選擇“1”,選擇USB下載,接著出現(xiàn)“Enteranewtemporarydownloadaddress:”的提示,在這個提示下輸入程序下載的地址,這里設(shè)置為0x32000000(不要與BIOS的地址0x30100000相沖突),同時要注意用USB下載要先在PC端裝好驅(qū)動程序,保證USB連接好,有時PC端出現(xiàn)發(fā)現(xiàn)無法識別的USB設(shè)備時,在BIOS中輸入ESC取消下載,等幾秒鐘后再輸入“1”啟動USB下載。(3)當(dāng)USBDEVICE成功枚舉后,點擊“USBPort”“Transmit”選項,選擇YLSBC2440_demo.cramfs(這個映像文件在光盤目錄的“目標(biāo)代碼”文件夾下)。(4)下載成功后,在出現(xiàn)主功能菜單后,選擇“4.WritefiletoNandFlash”進(jìn)行程序燒寫,在接下來的分區(qū)選擇中,選擇分區(qū)“2”,出現(xiàn)提示輸入后選擇“Y”(5)設(shè)置根文件系統(tǒng)分區(qū)位置參數(shù),這個參數(shù)主要是傳遞給內(nèi)核的,在主功能菜單中,選擇“7.Configparaments”進(jìn)入系統(tǒng)參數(shù)配置,接著選擇“7.rootfs”對Linux啟動根目錄進(jìn)行配置,然后回車,在出現(xiàn)“pleaseentervalue:”提示下輸入“2”設(shè)置Linux根文件系統(tǒng)為2分區(qū),然后回車,然后再進(jìn)行一次回車或者選擇“15”退出,會提示“Doyouwanttosaveparameters?pressyorYforsave.”,這時輸入“Y”,這樣就將根文件系統(tǒng)所在的分區(qū)位置參數(shù)保存了。(6)設(shè)置LCD顯示參數(shù),因為在板子的LCD標(biāo)準(zhǔn)配置是Sharp3.5。在BIOS的主功能菜單中,選擇“8.Configparaments”。接著選擇“14.Userpara”,然后回車,在“pleaseentervalue:”提示下輸入“display=shp240”,然后回車,在進(jìn)行一次回車或者選擇“15.Exit”退出,這是將提示“Doyouwanttosaveparameters?pressyorYforsave.”,接著輸入“Y”5.2.3啟動Linux將Linux內(nèi)核和Linux根文件系統(tǒng)燒寫好之后,接下來就是啟動Linux了,啟動Linux有兩種方式:一種是通過BIOS的5號功能來啟動;另一種是設(shè)置Linux自啟動。1.通過BIOS的5號功能來啟動Linux。開發(fā)板進(jìn)入BIOS主功能菜單后,選擇“5”2.Linux自啟動。進(jìn)入BIOS的主功能菜單后,選擇“7”對啟動參數(shù)進(jìn)行設(shè)置,在接著出現(xiàn)的選項中輸入“0”進(jìn)行啟動系統(tǒng)選擇設(shè)置,然后回車,在出現(xiàn)“pleaseentervalue:”的提示下,輸入“1”,然后回車,接著再進(jìn)行一次回車,將會提示“Doyouwanttosaveparameters?pressyorYforsave.”,這時輸入“5.2.4安裝編譯工具編譯嵌入式Linux內(nèi)核前,要先安裝交叉編譯工具toolchain,隨板光盤已附帶編譯工具。編譯工具cross-3.4.1.tar.bz2,安裝此編譯器只需要在/usr/local目錄下建一個arm的目錄,先將光盤目錄“Linux源碼和工具”下“toolchain”文件夾下的cross-3.4.1.tar.bz2拷貝到某個目錄下,然后進(jìn)入該目錄,執(zhí)行解包命令tarxjvfcross-3.4.1.tar.bz2即可,之后可編輯/etc/bashrc文件,在最后增加路徑exportPATH=/usr/local/arm/3.4.1/bin:$PATH,以后編譯內(nèi)核或其他應(yīng)用程序均可用arm-linux-來指定交叉編譯器。可以使用echo$PATH來查看環(huán)境變量中是否有/usr/local/arm/3.4.1/bin路徑變量。5.2.5編譯內(nèi)核(1)解壓內(nèi)核包:先將光盤目錄的“Linux源碼和工具”的Linux內(nèi)核包拷貝到某個目錄下,進(jìn)入這個目錄,然后解壓這個Linux源碼包,命令為:Tarxjvflinux-2.3.12-2440.tar.bz2(2)編輯Makefile文件:進(jìn)入解壓的目錄后,運(yùn)行命令:vimakefile找到“CROSS_COMPILE=”這行,將它改為“CROSS_COMPILE=/usr/local/arm/3.4.1/bin/arm-linux-”(3)輸入命令:makemenuconfig,進(jìn)入配置欄的“LoadanAlternateConfigurationFile”,輸入配置文件名kernel_2440.cfg并回車,在主菜單里選擇Exit退出并保存設(shè)置。(4)接著輸入命令:makezlmage。(5)編譯結(jié)束后,可在arch/arm/boot目錄下得到linux內(nèi)核壓縮映像zlmage。5.2.6cramfs根文件系統(tǒng)的創(chuàng)建(1)將YLSBC2440_camare_demo.cramfs拷貝到任意目錄下。(2)在該目錄下建立兩個文件:mkdirromsmkdirtmp(3)將YLSBC2440_camare_demo.cramfs掛接到chang目錄:mountYLSBC2440_camare_demo.cramfs.roms-oloop(4)將roms目錄下的內(nèi)容壓縮:Tar-cvf1.tarroms這樣將在roms的上一級目錄產(chǎn)生一個1.tar的包。(5)將包解壓到tmp目錄下:umountromscd..mv1.tartmpcdtmptar-xvf1.tarrm1.tar(6)經(jīng)過上面的步驟就可以將自己的驅(qū)動和應(yīng)用程序添加到cramfs根文件系統(tǒng)中了。進(jìn)入tmp目錄下的文件夾,在這個目錄下運(yùn)行命令:MkcramfstmpYL2440_demo_test.cramfs運(yùn)行成功后會在該目錄下生成YL2440_demo_test.cramfs根文件系統(tǒng)mkcramfs工具在光盤:Linux內(nèi)核源碼和工具\(yùn)toolchain下。(7)根文件系統(tǒng)制作成功后,就可以將YL2440_demo_test.cramfs燒寫到相應(yīng)的地方。5.3嵌入式TCP/IP協(xié)議棧的設(shè)計眾所周知,TCP/IP是一個協(xié)議族,它由幾百種網(wǎng)絡(luò)通信協(xié)議組成,這些協(xié)議用于組織計算機(jī)網(wǎng)絡(luò)中的數(shù)據(jù)通信。嵌入式系統(tǒng)是一種以應(yīng)用為核心、以計算機(jī)技術(shù)為基礎(chǔ)、功能穩(wěn)定的專用計算機(jī)系統(tǒng)。嵌入式TCP/IP協(xié)議棧其功能必定在嵌入式系統(tǒng)的定義范疇之內(nèi)。因此,嵌入式TCP/IP協(xié)議棧的功能是特定的,它不要求(也不可能)實現(xiàn)所有的TCP/IP協(xié)議,其實現(xiàn)的必定是TCP/IP族的一個子集。基于這一思想,我們在設(shè)計嵌入式TCP/IP協(xié)議棧時在TCP/IP協(xié)議的子集中實現(xiàn),降低設(shè)計的難度。由于系統(tǒng)資源有限,本文系統(tǒng)設(shè)計的協(xié)議棧的目標(biāo)是一個能實現(xiàn)所需功能的盡量精簡的協(xié)議棧。本文系統(tǒng)中的ARP協(xié)議,IP協(xié)議及ICMP協(xié)議是TCP/IP協(xié)議棧最基本的也是必須的協(xié)議,對于傳輸層協(xié)議,本文系統(tǒng)的協(xié)議棧根據(jù)具體需要實現(xiàn)了UDP與TCP。UDP沒有保證可靠性的機(jī)制,沒有其他的關(guān)卡機(jī)制,得以實現(xiàn)全速地發(fā)送(即充分發(fā)揮物理通信設(shè)備的速度)。考慮到本論文設(shè)計的系統(tǒng)需要傳輸大量的圖像數(shù)據(jù),而圖像的傳送對實時性要求較高并且對于掉包不敏感,而由于在局域網(wǎng)環(huán)境下丟包錯序的現(xiàn)象很少見,同時可以在應(yīng)用程序中適當(dāng)?shù)靥砑雍唵蔚目刂茩C(jī)制對亂序進(jìn)行處理,系統(tǒng)中圖像數(shù)據(jù)的傳輸采用UDP具有更優(yōu)的效果。相對于UDP,TCP的可靠性是以許多復(fù)雜措施及由此而增加的開銷為代價換來的,TCP提供可靠的數(shù)據(jù)流,但處理的開銷較大,傳輸率有所降低。通過遠(yuǎn)程控制臺通過網(wǎng)絡(luò)對系統(tǒng)的工作進(jìn)行控制的過程具有數(shù)據(jù)量小,需要保證控制參數(shù)在發(fā)送與接受過程中的順序及內(nèi)容的嚴(yán)格正確的特點,并且在一個完整的控制過程中的的交互當(dāng)中,雙方應(yīng)能了解對方當(dāng)前的狀態(tài),TCP的機(jī)制能有效地滿足這些要求,控制臺程序與圖像采集系統(tǒng)中的控制線程通過建立TCP連接進(jìn)行通信是很有必要的。圖5.2實現(xiàn)的TCP/IP協(xié)議棧中各協(xié)議的關(guān)系5.3.1ARP協(xié)議的實現(xiàn)ARP協(xié)議即地址解析協(xié)議,是將IP地址與網(wǎng)絡(luò)物理地址一一對應(yīng)的協(xié)議。在IPv4中地址長度是32位,在以太網(wǎng)中,設(shè)備的地址是48位(即MAC地址)。一張ARP表,用來支持在MAC地址和IP地址之間的一一對應(yīng)關(guān)系。它提供兩者的相互轉(zhuǎn)換。主要流程為:當(dāng)傳送一個的包要傳向一個局域網(wǎng)的主機(jī)時,當(dāng)它到達(dá)網(wǎng)關(guān)時,網(wǎng)關(guān)要求ARP對應(yīng)程序找到物理主機(jī)或與IP地址相對應(yīng)的MAC地址,ARP對應(yīng)程序在緩存中尋找,如果找到地址,則提供此地址,以傳送到主機(jī),如果未找到,ARP對應(yīng)程序就在網(wǎng)上廣播一個特殊格式的消息,如果一臺機(jī)器發(fā)現(xiàn)是自己的IP地址,它就發(fā)送回應(yīng),這樣就指出了相應(yīng)的地址,ARP對應(yīng)程序更新自己的緩存并將此包送到回應(yīng)的MAC地址。程序設(shè)計時需要定義一個IP地址與以太網(wǎng)地址映射的表,在對方發(fā)送ARP請求包時,可以從該映射表中讀取相應(yīng)的數(shù)據(jù)回復(fù)給對方,在接受到對方的ARP包時將對方的IP地址與以太網(wǎng)地址映射存儲到該表中,程序中通過兩個模塊ARPSend()和ARPReceive()來實現(xiàn)發(fā)送和接收ARP報文的功能。其中ARPReceive()程序設(shè)計框圖如下:圖5.3ARPReceive()程序設(shè)計框圖發(fā)送包模塊ARPSend()的處理流程較簡單,先在映射表中查找有無相應(yīng)IP地址與MAC地址映射的項,如果無則發(fā)送ARP請求包。5.3.2IP協(xié)議與ICMP協(xié)議的實現(xiàn)(1)IP協(xié)議。在IP協(xié)議的實現(xiàn)中,可以作以下的簡述:即不接收分片包。分片包需要根據(jù)包頭中的一些信息進(jìn)行重組,這將會占用大量的存儲器空間與處理器資源,在系統(tǒng)資源比較緊張的情況下,可以考慮忽略。程序?qū)崿F(xiàn)IP協(xié)議,在接收到IP數(shù)據(jù)包,需要對包中攜帶的信息進(jìn)行檢查,根據(jù)這些信息分別做出丟棄該包的處理或者判斷該包中攜帶的數(shù)據(jù)由哪個處理程序進(jìn)行處理。對發(fā)送而言則相對簡單,只需要對上層協(xié)議產(chǎn)生的包進(jìn)行封裝,加上一個IP包頭。在本系統(tǒng)中的設(shè)計中,實現(xiàn)IP層功能的模塊分別是負(fù)責(zé)IP包的發(fā)送的IPSend()模塊與接收處理的IPReceive()模塊。這兩個模塊的處理流程分別通過框圖來表示:圖5.4IPSend()流程框圖圖5.5IPReceive()流程框圖(2)ICMP協(xié)議。ICMP協(xié)議是作為IP上面的傳輸層實現(xiàn)的,但它與IP層緊密結(jié)合在一起,經(jīng)常被認(rèn)為是IP層的一個組成部分。ICMP傳遞差錯報文以及其他需要注意的信息。ICMP報文通常被IP層或者跟高層協(xié)議使用。ICMP報文是被封裝在IP數(shù)據(jù)報中傳輸?shù)?,ICMP有許多種類型,對于一個只需要基本功能的精簡的協(xié)議棧而言,只需要實現(xiàn)一個“回顯應(yīng)答”(PING)功能就可以了。實現(xiàn)ICMP協(xié)議主要通過模塊ICMPSend()和ICMPReceive()來實現(xiàn),ICMPReceive()對接收到的ICMP數(shù)據(jù)報進(jìn)行處理。如果類型字段是ECHO_REQUEST,就需要調(diào)用相關(guān)拷貝函數(shù)將該ICMP報文拷貝到發(fā)送緩沖區(qū),修改其類型字段和IP后返回;ICMPSend()只是簡單地將包往下交給IP層。圖5.6ICMPReceive()流程框圖5.3.3TCP與UDP協(xié)議的實現(xiàn)用TCP協(xié)議傳輸?shù)乃^數(shù)據(jù)實際指的是數(shù)據(jù)流中的段,而用UDP協(xié)議傳輸?shù)乃^數(shù)據(jù)指的是數(shù)據(jù)報。TCP和UDP都屬于IP上層的傳輸層協(xié)議。二者都使用端口號作為送往主機(jī)的解碼地址。端口號由各個具體應(yīng)用所確定,同時使用多個端口號能完成“一機(jī)多網(wǎng)”的操作。每個UDP數(shù)據(jù)包和TCP數(shù)據(jù)段中都含源端口號和目的端口號。為接收遠(yuǎn)端的輸入而等待著執(zhí)行接入操作的主機(jī)是所謂的服務(wù)器,發(fā)起接入請求的主機(jī)就是所謂的客戶機(jī)。服務(wù)器為最常服務(wù)的應(yīng)用如FTP(文件傳輸協(xié)議)、Email和HTTP,分配了知名的端口號并對其進(jìn)行持續(xù)地監(jiān)聽。作為傳輸源的客戶機(jī)通常選擇隨機(jī)的端口號,并向已分配了知名端口號的服務(wù)器發(fā)出接入請求??蛻魬?yīng)用所取的端口號應(yīng)大于1024,1024以下的端口號是為知名應(yīng)用而預(yù)留的。對于應(yīng)用程序中的每個TCP與UDP的套接口,系統(tǒng)維護(hù)兩個Socket鏈,分別對應(yīng)TCP與UDP,每個節(jié)點對應(yīng)一個應(yīng)用程序正在使用的套接口,維護(hù)相關(guān)的必要信息,在一個新的套接口建立時,關(guān)于該套接口的節(jié)點插入到Socket鏈的頭部,對于每個接收到的TCP報文或者UDP報文將通過遍歷相應(yīng)的Socket鏈來獲取必要信息及轉(zhuǎn)到相應(yīng)處理程序中,同樣在發(fā)送每個TCP報文或者UDP報文時,同時需要根據(jù)對應(yīng)的Socket節(jié)點進(jìn)行一定的操作。(1)UDP協(xié)議在上文所描述的Socket鏈中每個UDP套接口的節(jié)點相關(guān)的數(shù)據(jù)結(jié)構(gòu)中需要包含:套接口的四元組字段;是否接收到提交到應(yīng)用程序的新數(shù)據(jù)和應(yīng)用程序是否有新數(shù)據(jù)發(fā)送的判斷字段;接收到的提交到應(yīng)用程序的數(shù)據(jù)的緩沖區(qū)首地址字段;從應(yīng)用程序中獲得的需要發(fā)送的數(shù)據(jù)的緩沖區(qū)首地址字段等必須的字段。(2)TCP協(xié)議在程序中實現(xiàn)這個狀態(tài)機(jī),需要為每個TCP連接維護(hù)其狀態(tài),在上文所描述的Socket鏈中每個TCP套接口的節(jié)點相關(guān)的數(shù)據(jù)結(jié)構(gòu)中需要包含:狀態(tài)字段;套接口的四元組字段;收發(fā)序號字段;是否接收到提交到應(yīng)用程序的新數(shù)據(jù)和應(yīng)用程序是否有新數(shù)據(jù)發(fā)送的判斷字段;接收到的提交到應(yīng)用程序的數(shù)據(jù)的緩沖區(qū)首地址字段;從應(yīng)用程序中獲得的需要發(fā)送的數(shù)據(jù)的緩沖區(qū)首地址字段等必要的元素以提供狀態(tài)機(jī)運(yùn)行時必須的信息,狀態(tài)機(jī)運(yùn)行時根據(jù)接收到的TCP包中的信息與對應(yīng)的Socket節(jié)點中的字段進(jìn)行比較并根據(jù)需要修改字段的內(nèi)容,發(fā)送包則直接更新對應(yīng)的Socket節(jié)點中的字段內(nèi)容。狀態(tài)機(jī)通過函數(shù)TCP_Handler來實現(xiàn),TCPHandler的實現(xiàn)流程如圖5.7所示,該函數(shù)對應(yīng)用程序透明。圖5.7TCPHandler函數(shù)流程圖程序提供的接口函數(shù)主要為:1.TCP_Open:主動發(fā)起TCP連接;2.TCP_Listen:創(chuàng)建監(jiān)聽套接口;3.TCP_Send:發(fā)送數(shù)據(jù);4.TCP_Flush:發(fā)送緊急數(shù)據(jù);5.TCP_Close:關(guān)閉套接口。應(yīng)用程序通過調(diào)用這些函數(shù)來實現(xiàn)相應(yīng)的TCP相關(guān)的操作。實現(xiàn)了上述的協(xié)議,系統(tǒng)的基本網(wǎng)絡(luò)功能就構(gòu)架起來了,在這個基礎(chǔ)上圖像的傳輸以及接收控制臺的控制命令兩大功能可以得到實現(xiàn)。通過網(wǎng)關(guān)還可以接入公網(wǎng)。在本文實現(xiàn)的基本網(wǎng)絡(luò)功能的基礎(chǔ)上進(jìn)一步的工作可以考慮編寫PPP協(xié)議使設(shè)備直接接入公網(wǎng),以及編寫HTTP協(xié)議并通過CGI技術(shù)使得控制可以通過WEB來實現(xiàn)等。本章小結(jié)本章主要講述了將Linux內(nèi)核移植到ARM平臺的過程,第二章介紹了ARMS3C2440處理器的體系結(jié)構(gòu),本章在此基礎(chǔ)上給出了具體的開發(fā)環(huán)境并搭建了交叉編譯環(huán)境,進(jìn)行了燒寫和啟動Linux,并進(jìn)行了Linux內(nèi)核的編
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 廣東南華工商職業(yè)學(xué)院《現(xiàn)代醫(yī)藥生物技術(shù)與倫理》2023-2024學(xué)年第二學(xué)期期末試卷
- 電子類專業(yè)英語詞匯大全
- DB15-T 3967.9-2025 氣候可行性論證技術(shù)規(guī)范 第9部分 物流類園區(qū)(開發(fā)區(qū))
- 第四單元(主題家鄉(xiāng)文化生活)教考銜接作文寫作指導(dǎo)-2025年高考語文復(fù)習(xí)
- 綠色環(huán)保住宅建設(shè)承包合同
- 度信息技術(shù)設(shè)備采購合同范本
- 《2025年企業(yè)解除勞動合同協(xié)商協(xié)議書》
- 2025起重機(jī)械安裝拆卸安全合作協(xié)議合同范本
- 2025二手裝載機(jī)出售合同
- 2025年初中物理九年級上冊(人教版)電流與電壓和電阻的關(guān)系(第一課時)-1教學(xué)設(shè)計
- 深靜脈血栓形成干預(yù)策略
- 證券投資基金信息披露xbrl模板第3號《年度報告和半年度報告》
- 工程力學(xué)電子教材
- 中國各個省份城市地區(qū)區(qū)縣表格
- 土木工程師(水利水電)資格《專業(yè)知識》考試題庫-水土保持(重點題)
- N1級護(hù)理人員理論知識考試題庫與答案
- 危險化學(xué)品安全周知卡(鈉石灰、硫酸氫鈉、硝酸鋅、氯化銅、氯化鋅)
- GB/T 4513.1-2015不定形耐火材料第1部分:介紹和分類
- 精華版-趙武靈王胡服騎射課件
- 電鍍及化學(xué)鍍課件
- 項目模板拆除申請表
評論
0/150
提交評論