《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 設(shè)計(jì)應(yīng)用 > 基于ARM的AdHoc網(wǎng)絡(luò)平臺的實(shí)現(xiàn)
基于ARM的AdHoc網(wǎng)絡(luò)平臺的實(shí)現(xiàn)
電子設(shè)計(jì)應(yīng)用
沈曉松,宿景芳
摘要: 由于AdHoc網(wǎng)絡(luò)無中心、動態(tài)拓?fù)涞忍攸c(diǎn),它需要各個(gè)節(jié)點(diǎn)都具有路由轉(zhuǎn)發(fā)功能。本文開發(fā)的AdHoc網(wǎng)絡(luò)節(jié)點(diǎn)通過在ARM平臺上移植路由協(xié)議而實(shí)現(xiàn)了數(shù)據(jù)包轉(zhuǎn)發(fā)功能。
Abstract:
Key words :

功能概述

由于Ad Hoc網(wǎng)絡(luò)無中心、動態(tài)拓?fù)涞忍攸c(diǎn),它需要各個(gè)節(jié)點(diǎn)都具有路由轉(zhuǎn)發(fā)功能。本文開發(fā)的Ad Hoc網(wǎng)絡(luò)節(jié)點(diǎn)通過在ARM平臺上移植路由協(xié)議而實(shí)現(xiàn)了數(shù)據(jù)包轉(zhuǎn)發(fā)功能。
 

 

 

圖1 節(jié)點(diǎn)轉(zhuǎn)發(fā)

以圖1所示的網(wǎng)絡(luò)進(jìn)行功能示意,其中A、B、D是普通的移動電腦終端,C是本文開發(fā)的ARM平臺。A和D是通信的端點(diǎn),D不在A的一跳范圍之內(nèi)(A的覆蓋范圍如圖中虛線所示)。假設(shè)開始時(shí)B成為了A和D的中繼節(jié)點(diǎn),完成A、D之間的數(shù)據(jù)轉(zhuǎn)發(fā)功能。當(dāng)B節(jié)點(diǎn)出現(xiàn)故障時(shí),C能自動代替B成為新的中繼節(jié)點(diǎn),維持A、D之間的通信。

該ARM平臺除了路由協(xié)議以外,同時(shí)完成了ftp、iptables等工具的移植,還可以繼續(xù)增添語音、視頻等服務(wù)。

硬件平臺

以處理器為核心,無線網(wǎng)卡收到數(shù)據(jù)包后交給上層處理,需要發(fā)出的數(shù)據(jù)包也由處理器控制無線網(wǎng)卡來發(fā)出。當(dāng)然SDRAM、閃存、電源這些模塊也是系統(tǒng)不可缺少的。

本文采用ARM920T為內(nèi)核的三星處理器S3C2410A。S3C2410A 是32位低功耗RISC處理器,同時(shí)支持Thumb 16位壓縮指令集,其工作頻率為203MHz。S3C2410A有292個(gè)管腳,集成了許多片上功能,例如以太網(wǎng)控制器、UART控制器、可編程I/O口及中斷控制器等。

考慮到接口體積,該平臺選用USB接口的華碩WL-167g無線網(wǎng)卡,提供無線通信功能。

硬件平臺設(shè)計(jì)結(jié)構(gòu)如圖2所示。

 

基于ARM的Ad Hoc網(wǎng)絡(luò)平臺結(jié)構(gòu)

 

圖2 硬件平臺結(jié)構(gòu)圖

在硬件調(diào)試中一個(gè)應(yīng)該注意的問題就是S3C2410A的nWait引腳在不使用時(shí)應(yīng)接上拉電阻,否則系統(tǒng)在啟動模式時(shí)將不能正常啟動。

軟件平臺

vivi是韓國MIZI公司開發(fā)的Bootloader,適用于ARM9處理器,其作用是初始化硬件設(shè)備、建立內(nèi)存空間的映射圖,從而將系統(tǒng)的軟硬件環(huán)境設(shè)置成一個(gè)合適的狀態(tài),以便為運(yùn)行操作系統(tǒng)準(zhǔn)備正確的環(huán)境。引導(dǎo)程序執(zhí)行完后會將控制權(quán)交給內(nèi)核(zImage),內(nèi)核是操作系統(tǒng)的核心,內(nèi)核需要的各種配置文件、數(shù)據(jù)及上層軟件都存放在根文件系統(tǒng)之中。整個(gè)軟件平臺的結(jié)構(gòu)如圖3所示。

 

圖3 軟件平臺示意圖

內(nèi)核鏡像的生成

這里不贅述內(nèi)核生成方法,需要注意此過程容易遇到三類錯誤:一是編譯出錯,應(yīng)該檢查庫文件是否齊全,另外gcc版本太高也會導(dǎo)致編譯錯誤,重新安裝低版本gcc后即可解決;二是內(nèi)核配置應(yīng)將Default kernel command string設(shè)置為noinitrd root=/dev/mtdblock3 console=ttySAC0,115200 init=/linuxrc,“console=ttySAC0,115200”使內(nèi)核啟動期間的信息全部輸出到串口0上,波特率為115200,“mtdblock3”代表第4個(gè)Nand閃存分區(qū),該分區(qū)為根文件系統(tǒng),init是指定啟動腳本,“init=/linuxrc”表示啟動初始化文件位置;三是應(yīng)該在drivers/mtd/nand/s3c2410.c中,設(shè)置NAND_ECC_SOFT = NAND_ECC_NONE,這樣就關(guān)閉了ECC校驗(yàn)。因?yàn)閮?nèi)核是通過vivi寫到Nand閃存中的,vivi使用的軟件ECC算法與內(nèi)核中校驗(yàn)算法不同。

無線網(wǎng)卡驅(qū)動的移植

本文使用華碩USB無線網(wǎng)卡WL-167g,其網(wǎng)卡驅(qū)動是rt73。

移植步驟如下:

a、下載RT73_Linux_STA_Drv1.0.4.0.tar.gz,解壓后生成Module和WPA_Supplicant兩個(gè)目錄,將目錄Module中的所有文件都拷貝到內(nèi)核源碼包drivers/usb/net/rt73下,修改Makefile如下編譯選項(xiàng):

KDIR := path/linux-2.6.18

path為內(nèi)核源碼包所在路徑。

b、由于要在內(nèi)核源碼包里進(jìn)行交叉編譯,所以修改linux-2.6.18 /drivers/usb/net/Kconfig,加入以下內(nèi)容:

config RT73

tristate“support for rt73 wireless usb device”

depends on USB && NET && USB_USBNET

c、修改drivers/usb/net/Makefile,加入rt73的編譯項(xiàng):

obj-$(CONFIG_RT73)+= rt73

d、對內(nèi)核重新進(jìn)行配置,

將配置界面中新增的“support for rt73 wireless usb device”選為模塊。

e、make modules

在drivers/usb/net/rt73目錄下生成rt73.ko驅(qū)動文件,將rt73.ko放到根文件系統(tǒng)中,再燒寫到ARM板上無線網(wǎng)卡即可正常工作。

f、無線網(wǎng)卡的配置

無線網(wǎng)卡有managed、Ad-hoc兩種模式。managed模式稱為基礎(chǔ)設(shè)施模式,又稱接入點(diǎn)模式;Ad-hoc模式稱為點(diǎn)對點(diǎn)模式或無中心模式,用來在無線網(wǎng)卡之間進(jìn)行一跳通信。Ad Hoc網(wǎng)絡(luò)就是在Ad-hoc模式基礎(chǔ)上通過網(wǎng)絡(luò)協(xié)議使得該網(wǎng)絡(luò)支持多跳通信,因此該模式的使用和性能對Ad Hoc網(wǎng)絡(luò)的影響至關(guān)重要,以下是Ad-hoc模式配置方法,rausb0表示無線網(wǎng)卡:

1)、ifconfig rausb0 10.0.1.1 up

設(shè)置節(jié)點(diǎn)IP為10.0.1.1。

2)、iwpriv rausb0 set AdhocOfdm=2

設(shè)置rausb0為11g only模式,即54M速率模式,這是802.11g所能支持的最高速率。

3)、iwconfig rausb0 channel 3

設(shè)置信道為3。

4)、iwconfig rausb0 mode ad-hoc essid bcnl

設(shè)置網(wǎng)卡模式為ad-hoc,essid為“bcnl”。

上述配置過程中使用的“iw”開頭的命令都是無線工具集中的命令,其源碼包是wireless_tools.29.tar.gz,經(jīng)過交叉編譯后即可使用。

AODV路由協(xié)議的移植

本文使用的代碼是aodv-uu-0.9.5.tar.gz。AODV分為兩個(gè)部分,一個(gè)是內(nèi)核態(tài)模塊kaodv.ko,一個(gè)是用戶態(tài)模塊aodvd。AODV主要部分工作在用戶態(tài),用于維護(hù)內(nèi)核路由表。

AODV需要內(nèi)核支持,在內(nèi)核配置時(shí)要選上netfilter選項(xiàng)。先編譯內(nèi)核態(tài)模塊kaodv.ko,步驟如下:

a、將aodv-uu-0.9.5/lnx目錄的內(nèi)容拷到內(nèi)核源碼包linux-2.6.18/net/ipv4/kaodv目錄下,修改linux-2.6.18/net/ipv4/Kconfig,添加如下內(nèi)容:

config KAODV_UU

tristate "support for aodv-uu adhoc routing protocol"

b、在linux-2.6.18/net/ipv4/Makefile末尾添加如下的編譯選項(xiàng):

obj-$(CONFIG_KAODV_UU) += kaodv/

c、make menuconfig,找到如下的目錄項(xiàng):

Networking --->

[*] Networking support Networking options --->

support for aodv-uu adhoc routing protocol選為模塊編譯。

d、make modules將生成kaodv.ko。以下介紹用戶態(tài)aodvd編譯:

將aodv-uu-0.9.5/Makefile做適當(dāng)修改,使其在交叉編譯的環(huán)境下只編譯用戶態(tài)部分。

將得到的kaodv.ko和aodvd拷貝到根文件系統(tǒng)中,再燒寫到ARM板上。

insmod kaodv.ko

./ aodvd

這樣aodv協(xié)議就運(yùn)行起來了。在協(xié)議移植中有兩點(diǎn)需要注意:一是Makefile中ARM_CCFLAGS=-mbig-endian應(yīng)該注釋掉,否則運(yùn)行時(shí)會產(chǎn)生大小端混亂的問題;二是將kaodv.ko和aodvd分開編譯,因?yàn)橥瑫r(shí)編譯時(shí)總是提示編譯器缺少文件,甚至用其他交叉編譯器依然不能解決問題,而這些錯誤大多是編譯內(nèi)核模塊產(chǎn)生的。

測試和結(jié)論

為簡單起見,本測試使用兩個(gè)筆記本和一個(gè)ARM平臺組建成Ad Hoc網(wǎng)絡(luò),如圖4所示,A節(jié)點(diǎn)IP為10.0.1.1,B節(jié)點(diǎn)IP為10.0.1.2,C節(jié)點(diǎn)IP為10.0.1.3(經(jīng)測試將ARM平臺做通信端,A或C做中繼,網(wǎng)絡(luò)同樣可以正常運(yùn)行)。

 

圖4 測試拓?fù)涫疽鈭D

為了簡單地實(shí)現(xiàn)C節(jié)點(diǎn)不在A節(jié)點(diǎn)一跳范圍內(nèi),可以使用iptables實(shí)現(xiàn)過濾。

在A節(jié)點(diǎn)執(zhí)行:

iptables –A INPUT –p ALL –m mac –mac-source C.mac –j DROP

在C節(jié)點(diǎn)執(zhí)行:

iptables –A INPUT –p ALL –m mac –mac-source A.mac –j DROP

以上的C.mac、A.mac是C和A的實(shí)際mac地址,這樣A節(jié)點(diǎn)拒絕C發(fā)給它的數(shù)據(jù)包,C節(jié)點(diǎn)也拒絕A發(fā)給它的數(shù)據(jù)包,保證二者一跳不可達(dá)。

在C節(jié)點(diǎn)ping -R 10.0.1.1,鏈路不通,說明過濾成功,B沒有進(jìn)行數(shù)據(jù)包轉(zhuǎn)發(fā)。

在各節(jié)點(diǎn)上運(yùn)行AODV后,在C節(jié)點(diǎn)ping -R 10.0.1.1,結(jié)果如圖5所示。

圖5 測試結(jié)果

可見,B正確地進(jìn)行了數(shù)據(jù)包轉(zhuǎn)發(fā),AODV協(xié)議正常運(yùn)行,ARM平臺成功運(yùn)行。

在A節(jié)點(diǎn)執(zhí)行l(wèi)ftp 10.0.1.3,并下載普通文件。這樣數(shù)據(jù)包由中間的ARM平臺B轉(zhuǎn)發(fā),下載完成后,查看C節(jié)點(diǎn)的日志文件/var/log/vsftpd.log,發(fā)現(xiàn)上傳和下載的速率基本相同,有將近700kBps的速率,達(dá)到5.4Mbps的速率。粗略估算聚合物電池供電能使ARM平臺穩(wěn)定運(yùn)行8小時(shí)。

通過以上測試,搭建一個(gè)Ad Hoc網(wǎng)絡(luò)的ARM平臺的目標(biāo)已經(jīng)達(dá)到。通過對有多個(gè)ARM平臺的Ad Hoc網(wǎng)絡(luò)進(jìn)行測試,發(fā)現(xiàn)當(dāng)某節(jié)點(diǎn)感知無線信號很弱時(shí),無線網(wǎng)卡的essid存在自動變化的情況。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。