當(dāng)前位置:首頁 > 通信技術(shù) > 通信技術(shù)
[導(dǎo)讀] 引言眾所周知,WiFi與其他短距離無線通信相比,具有通信速率高、穩(wěn)定、安全、支持設(shè)備多等優(yōu)點(diǎn)。尤其是近幾年智能手機(jī)迅速發(fā)展,使WiFi快速普及,這就給傳統(tǒng)的嵌入式系統(tǒng)無線通信帶來了機(jī)遇和挑戰(zhàn)。就通信角度而言,

 引言

眾所周知,WiFi與其他短距離無線通信相比,具有通信速率高、穩(wěn)定、安全、支持設(shè)備多等優(yōu)點(diǎn)。尤其是近幾年智能手機(jī)迅速發(fā)展,使WiFi快速普及,這就給傳統(tǒng)的嵌入式系統(tǒng)無線通信帶來了機(jī)遇和挑戰(zhàn)。就通信角度而言,數(shù)以億計的智能手機(jī)其實(shí)就是一個個潛在的手持遙控器或數(shù)據(jù)終端,如果能在嵌入式系統(tǒng)中支持WiFi網(wǎng)絡(luò),將極大地拓展與外部的通信方式。但是,由于WiFi對系統(tǒng)資源要求比較高,所以嵌入式系統(tǒng)采用WiFi的發(fā)展相對滯后,常見的方案是,在原有的嵌入式系統(tǒng)中外接一個WiFi通信轉(zhuǎn)接模塊,將Wi Fi信號轉(zhuǎn)換為UART、SPI等常見的通信方式。這種方式實(shí)現(xiàn)比較簡單,但是缺點(diǎn)也非常明顯,額外增加了成本,這也是阻礙嵌入式系統(tǒng)WiFi發(fā)展的一個主要因素。本文介紹了直接將WiFi網(wǎng)卡集成到嵌入式系統(tǒng)的解決方案,系統(tǒng)MCU直接驅(qū)動USB接口的WiFi網(wǎng)卡,從而省去了WiFi轉(zhuǎn)UART等橋接模塊,明顯降低了系統(tǒng)成本,而且同時理論上解決了采用橋接模塊潛在的通信速率瓶頸問題。

1 系統(tǒng)方案

本文設(shè)計的嵌入式WiFi方案是智能手機(jī)以WiFi方式遙控智能小車的系統(tǒng),系統(tǒng)架構(gòu)如圖1所示。手機(jī)端就是一個運(yùn)行在手機(jī)上的Android應(yīng)用程序,小車端的核心控制板采用STM32F105RB芯片,WiFi網(wǎng)卡采用基于RT5370的嵌入式模塊。RT5370是一款USB接口的WiFi芯片,基于其實(shí)現(xiàn)的USB無線網(wǎng)卡非常常見,價格優(yōu)勢明顯。STM32F105RB是ST公司STM32系列芯片的一款,72 MHz主頻,具有128 KB Flash、48 KB RAM和豐富的I/O資源,同時價格比較低,在中小嵌入式系統(tǒng)中廣泛采用,同時其支持USB OTG,可以驅(qū)動RT5370。

該系統(tǒng)的核心就是在基于STM32F105RB的小車控制板上實(shí)現(xiàn)對RT5370 WiFi模塊的支持,使該控制板工作在AP模式,手機(jī)通過WiFi從控制板獲得IP,然后運(yùn)行相應(yīng)的Android應(yīng)用程序控制小車。

2 硬件設(shè)計

小車控制板包括WiFi接口和功率輸出驅(qū)動兩大部分。因為本文的重點(diǎn)是嵌入式WiFi實(shí)現(xiàn),所以只給出該部分的硬件實(shí)現(xiàn),如圖2所示。圖中STM32F105RB的USB工作在主機(jī)模式,與WiFi模塊通過6引腳2.0 mm的單排針連接。由于STM32F105RB USB模塊內(nèi)部有下拉電阻,所以電路連接非常簡單。

3 軟件流程及移植

系統(tǒng)軟件架構(gòu)如圖3所示。整個系統(tǒng)由USB驅(qū)動、WiFi協(xié)議棧、網(wǎng)絡(luò)協(xié)議棧、應(yīng)用程序4個主要部分組成。

USB部分實(shí)現(xiàn)WiFi網(wǎng)卡和系統(tǒng)MCU之間的通信,WiFi網(wǎng)卡收發(fā)的數(shù)據(jù)通過USB與MCU進(jìn)行交互,STM32F105RB作為USB主機(jī),WiFi網(wǎng)卡作為USB客戶端。

WiFi協(xié)議棧負(fù)責(zé)802.11協(xié)議的解析和封裝,向下和USB驅(qū)動交互,向上和TCP/IP協(xié)議棧交互:發(fā)送端,從TCP/IP協(xié)議棧接收數(shù)據(jù),封裝成WiFi封包,通過調(diào)用USB驅(qū)動實(shí)現(xiàn)物理發(fā)送;接收端,從USB驅(qū)動接收數(shù)據(jù),解析802.11協(xié)議,傳送給TCP/IP協(xié)議棧,實(shí)現(xiàn)向應(yīng)用層的傳遞。

TCP/IP協(xié)議棧實(shí)現(xiàn)IP、ICMP、UDP、TCP等協(xié)議,包括實(shí)現(xiàn)協(xié)議封裝、解析以及基本的路由。當(dāng)前有很多優(yōu)秀的開源TCP/IP協(xié)議棧,本項目中選用LWIP,因為該協(xié)議比較成熟,適合資源有限的嵌入式系統(tǒng)。LWIP支持DHCP客戶端,但是在該系統(tǒng)中作為AP來用,需要DHCP服務(wù)器,這里自己設(shè)計了一個簡單的DHCP服務(wù)器。

應(yīng)用程序部分,調(diào)用網(wǎng)絡(luò)編程接口和手機(jī)進(jìn)行通信,將收到的數(shù)據(jù)轉(zhuǎn)化為驅(qū)動小車輸出的PWM信號,來驅(qū)動小車。

3.1 USB驅(qū)動

ST公司的固件庫提供了對于USB的支持。本系統(tǒng)就基于該USB庫架構(gòu),實(shí)現(xiàn)了USB WiFi模塊需要的特定功能。

STM32的USB庫架構(gòu)如圖4所示,其給用戶提供的接口非常清晰,包括USB主機(jī)的初始化,以及對應(yīng)狀態(tài)機(jī)的實(shí)現(xiàn)。

3.1.1 USB主機(jī)初始化

USB主機(jī)的初始化通過USBH_Init函數(shù)實(shí)現(xiàn),這個函數(shù)有5個結(jié)構(gòu)類型的參數(shù),在調(diào)用這個函數(shù)前,需要先設(shè)置好這5個參數(shù)的內(nèi)容。該函數(shù)原形如下:

參數(shù)pdev,phost分別代表STM32 USB的核心控制結(jié)構(gòu)和USB主機(jī)的控制結(jié)構(gòu),在STM32的USB庫中已經(jīng)定義,對應(yīng)USB_OTG_CORE和USB_HOST。USB_OTG_FS_CORE_ID表示工作在USB的全速方式。參數(shù)Class_cb和usr_cb為用戶定義的USB類控制結(jié)構(gòu)和用戶定義的初始化結(jié)構(gòu)。這兩個結(jié)構(gòu)是要實(shí)現(xiàn)的內(nèi)容,其中,用戶定義的USB類控制結(jié)構(gòu),包括初始化、釋放、請求和狀態(tài)機(jī)4個處理函數(shù),分別在代表用戶設(shè)計的USB類的初始化、釋放、初始化請求和正常工作狀態(tài)中會用到。

用戶根據(jù)要求分別實(shí)現(xiàn)對應(yīng)的功能,對應(yīng)本項目的WiFi模塊,具體的移植實(shí)現(xiàn)如下:

其中,USBH_CDC_InterfaceInit實(shí)現(xiàn)WiFi模塊的初始化,對應(yīng)Linux版本驅(qū)動中的芯片寄存器配置、通信緩沖區(qū)配置、加載固件的掛鉤函數(shù)等處理,以及在MainVirtualIF_open中實(shí)現(xiàn)打開WiFi等操作。USBH_CDC_Handle則實(shí)現(xiàn)USB的狀態(tài)機(jī)功能。

用戶定義的初始化函數(shù)是給用戶提供一個實(shí)現(xiàn)自己特定初始化操作的接口,這里沒有用到。

這些參數(shù)都設(shè)置好后,直接調(diào)用USBH_Init即可實(shí)現(xiàn)對USB硬件和架構(gòu)的初始化。

3.1.2 USB狀態(tài)機(jī)

USB初始化完成后,其核心處理都是由USB狀態(tài)機(jī)USBH_Process來實(shí)現(xiàn)從枚舉、功能處理到異?;謴?fù)等的管理,其中會通過函數(shù)掛鉤的方式調(diào)用在初始化過程中設(shè)置的對應(yīng)函數(shù)。

具體狀態(tài)轉(zhuǎn)換過程如圖5所示。首先主機(jī)檢測是否有USB模塊插入,如果有,則轉(zhuǎn)入枚舉過程。對于本系統(tǒng)來說,WiFi模塊直接安裝在控制板上,上電后就會檢測到有插入并轉(zhuǎn)入枚舉過程;枚舉結(jié)束后,STM32F105RB的USB庫會給用戶提供一個用戶輸入和特定類初始化的操作,對于該WiFi模塊,歸屬于通信類,在類初始化操作中會作WiFi模塊相應(yīng)地初始化,包括讀取模塊的配置信息、MAC地址等;在這些初始化過程完成后,會進(jìn)入模塊狀態(tài)機(jī)處理過程,對于該WiFi模塊來說,就是循環(huán)處理接收數(shù)據(jù)的過程。在這個過程中如果發(fā)生異常,則進(jìn)入異常處理后重新從空閑狀態(tài)開始狀態(tài)切換。標(biāo)準(zhǔn)的STM32F105RBUSB模塊還有USB模塊拔除的狀態(tài)轉(zhuǎn)換,由于該項目中WiFi模塊直接裝在母板上,所以不會進(jìn)入這個狀態(tài)。

特別地,USB WiFi狀態(tài)機(jī)處理函數(shù)主要實(shí)現(xiàn)WiFi數(shù)據(jù)的傳輸,具體的傳輸通過USB的批處理傳輸方式進(jìn)行。對于數(shù)據(jù)接收,系統(tǒng)會一直輪詢WiFi模塊,判斷是否有數(shù)據(jù)可用。如果有,則將數(shù)據(jù)讀入接收緩沖區(qū)中,并設(shè)置相應(yīng)的標(biāo)志通知上層軟件。對于數(shù)據(jù)發(fā)送,上層直接發(fā)起數(shù)據(jù)傳輸,調(diào)用USB發(fā)送函數(shù),進(jìn)行發(fā)送。

3.2 802.1 1協(xié)議驅(qū)動

WiFi協(xié)議棧的實(shí)現(xiàn)基于Mediatek官方提供的Linux源碼驅(qū)動,相應(yīng)移植到該項目的STM32F105RB系統(tǒng)中。圖6分析了RT5370 Linux的驅(qū)動流程和需要完成的對應(yīng)移植工作。

從左邊的驅(qū)動流程可以看出,首先是設(shè)置Linux驅(qū)動架構(gòu)下面的probe、open等函數(shù),在本系統(tǒng)中這塊并不需要,直接從硬件初始化開始,由于驅(qū)動本身就是可移植性比較好的C語言代碼,所以這塊代碼基本可以直接移植過來;然后是驅(qū)動所需的通信緩沖區(qū)的資源初始化,這部分和操作系統(tǒng)相關(guān),根據(jù)本系統(tǒng)的情況,直接預(yù)留相應(yīng)的內(nèi)存作為通信緩沖區(qū);WiFi對應(yīng)的配置信息在Linux下是一個配置文件,在存在根文件的系統(tǒng)中,對于沒有文件系統(tǒng)的情況,直接將對應(yīng)的配置值以默認(rèn)值的方式保存,但是這也導(dǎo)致了一個問題,相應(yīng)的WiFi配置(如SSID等)不可以更改,需要在后續(xù)實(shí)現(xiàn)中完善;這些設(shè)置工作都準(zhǔn)備好后,啟動對應(yīng)的定時器和2個任務(wù)分別處理WiFi的廣播Beacon連接信息和實(shí)際用戶數(shù)據(jù),并用相應(yīng)的定時器和模塊實(shí)現(xiàn)。

3.3 TCP/IP協(xié)議棧LWIP

完成了WiFi驅(qū)動從Linux到STM32F105RB系統(tǒng)的移植后,相當(dāng)于實(shí)現(xiàn)了OSI模型中網(wǎng)絡(luò)層的移植,后續(xù)就是相應(yīng)協(xié)議棧的移植。本項目中協(xié)議棧選用LWIP,版本是v1.3.2。需要指出的是,由于該項目的USB WiFi工作于AP模式,需要實(shí)現(xiàn)DHCP服務(wù)器的功能。而在LWIP中只有DHCP客戶端功能,服務(wù)器需要自己實(shí)現(xiàn),在本項目中根據(jù)需要實(shí)現(xiàn)了一個簡單的DHCP服務(wù)器。

3.4 應(yīng)用程序

在實(shí)現(xiàn)了WiFi驅(qū)動、協(xié)議棧以及DHCP服務(wù)器后,基于STM32的WiFi已經(jīng)可以工作,分別用手機(jī)和計算機(jī)與控制板連接,成功獲得IP,在計算機(jī)端運(yùn)行ping命令,可以成功ping通。在此基礎(chǔ)上,編寫基于LWIP的套接子程序,以及相應(yīng)的小車驅(qū)動程序,實(shí)現(xiàn)通過手機(jī)可以流暢地控制小車。

結(jié)語

試驗表明,該系統(tǒng)實(shí)現(xiàn)的WiFi除具有成本方面的優(yōu)勢外,還具有系統(tǒng)啟動快、通信響應(yīng)快的特點(diǎn),通常系統(tǒng)2 s即可以啟動,手機(jī)3 s即可以獲得IP,比常用路由器的響應(yīng)快了很多;ICMP響應(yīng)通常小于2 ms,響應(yīng)速度的優(yōu)勢也非常明顯。用手機(jī)通過WiFi控制智能小車,可以做到流暢控制。理論和實(shí)踐證明,在基于Cortex—M3的低成本嵌入式系統(tǒng)中實(shí)現(xiàn)WiFi是完全可行的。

當(dāng)然,由于時間限制,該項目WiFi系統(tǒng)的加密功能,以及通常的WiFi系統(tǒng)需要的基于web界面方式的配置功能尚未實(shí)現(xiàn)??紤]到當(dāng)前STM32F105RB的資源使用情況,我們使用了80 KB空間,系統(tǒng)還留有48 KB空間,后續(xù)完整實(shí)現(xiàn)加密和Web界面配置在理論上是可行的,有待進(jìn)一步驗證。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉