RNDIS和ECM的熱插拔問(wèn)題
最近修復(fù)了一波 RNDIS 和 ECM的熱插拔通信異常問(wèn)題,添加了通過(guò)menuconfig
配置RNDIS delay linkup
的配置選項(xiàng)。問(wèn)題修復(fù)點(diǎn)如下:
RNDIS:
當(dāng)存在通信鏈接時(shí) 熱插拔 Windows會(huì)發(fā)送REMOTE_NDIS_RESET_MSG,該指令未實(shí)現(xiàn),現(xiàn)已實(shí)現(xiàn)。
當(dāng)存在通信鏈接時(shí) 熱插拔 eth_tx線程大幾率會(huì)死等傳輸完成的信號(hào)量通知,導(dǎo)致LWIP卡死。
當(dāng)存在通信鏈接時(shí) 熱插拔 eth_rx的接收緩沖未重置,導(dǎo)致接收數(shù)據(jù)異常。
ECM:
當(dāng)存在通信鏈接時(shí) 熱插拔 eth_tx線程大幾率會(huì)死等傳輸完成的信號(hào)量通知,導(dǎo)致LWIP卡死。
當(dāng)存在通信鏈接時(shí) 熱插拔 eth_rx的接收緩沖未重置,導(dǎo)致接收數(shù)據(jù)異常。
現(xiàn)已測(cè)試stm32f469i-discovery / LWIP2.0.2 / Windows 10 1903下 RNDIS
,iperf傳輸過(guò)程中反復(fù)熱插拔后功能正常, delay linkup宏開(kāi)啟前后功能正常,連續(xù)熱插拔功能正常。
現(xiàn)已測(cè)試stm32f469i-discovery / LWIP2.0.2 / MacOS Mojave 10.14.2下 ECM
,iperf傳輸過(guò)程中反復(fù)熱插拔后功能正常。
相關(guān)Pull Request:
https://github.com/RT-Thread/rt-thread/pull/2764(因微信無(wú)法插入外部鏈接,請(qǐng)將以上鏈接復(fù)制至外部瀏覽器打開(kāi))
關(guān)于NDIS
RNDIS全稱(chēng)Remote NDIS 是Microsoft定義的一種USB以太網(wǎng)卡模型,說(shuō)到RNDIS 必須要說(shuō)說(shuō)另一個(gè)東西,NDIS。
NDIS(Network Driver Interface Specification)是網(wǎng)絡(luò)驅(qū)動(dòng)程序接口規(guī)范的簡(jiǎn)稱(chēng)。它橫跨傳輸層、網(wǎng)絡(luò)層和數(shù)據(jù)鏈路層,定義了網(wǎng)卡或網(wǎng)卡驅(qū)動(dòng)程序與上層協(xié)議驅(qū)動(dòng)程序之間的通信接口規(guī)范,屏蔽了底層物理硬件的不同,使上層的協(xié)議驅(qū)動(dòng)程序可以和底層任何型號(hào)的網(wǎng)卡通信。NDIS為網(wǎng)絡(luò)驅(qū)動(dòng)程序創(chuàng)建了一個(gè)完整的開(kāi)發(fā)環(huán)境,只需調(diào)用NDIS函數(shù),而不用考慮操作系統(tǒng)的內(nèi)核以及與其他驅(qū)動(dòng)程序的接口問(wèn)題,從而使得網(wǎng)絡(luò)驅(qū)動(dòng)程序可以從與操作系統(tǒng)的復(fù)雜通訊中分離,極大地方便了網(wǎng)絡(luò)驅(qū)動(dòng)程序的編寫(xiě)。另外,利用NDIS的封裝特性,可以專(zhuān)注于一層驅(qū)動(dòng)的設(shè)計(jì),減少了設(shè)計(jì)的復(fù)雜性,同時(shí)易于擴(kuò)展驅(qū)動(dòng)程序棧。
而RNDIS 就是NDIS這種規(guī)范基于USB的一種具體實(shí)現(xiàn),RNDIS目前可以在Windows7 or later(講道理Vista也是可以的)上自動(dòng)加載驅(qū)動(dòng),無(wú)需第三方驅(qū)動(dòng)。而對(duì)于Linux和MacOS來(lái)說(shuō)RNDIS則需要安裝第三方驅(qū)動(dòng)了,部分Linux發(fā)行版內(nèi)置了RNDIS的驅(qū)動(dòng)(誰(shuí)叫Windows用的人多了)。至于Linux Mac 下如何使用RNDIS這里不跟你多解釋?zhuān)驗(yàn)槲姨峁┝肆硪环N解決方案--------CDC-ECM。
CDC-ECM(Ethernet Networking Control Model)是USB聯(lián)盟定義的標(biāo)準(zhǔn)USB以太網(wǎng)控制器模型(很遺憾,Windows下沒(méi)有驅(qū)動(dòng)),絕大部分Linux發(fā)行版和MacOS都支持該種USB設(shè)備的驅(qū)動(dòng)。這里講的絕大多數(shù)包括了各種pi,當(dāng)然如果你自己編譯的linux手動(dòng)剔除了這份驅(qū)動(dòng)就沒(méi)辦法了。
下載RNDIS/ECM白皮書(shū)請(qǐng)由此入:
https://www.rt-thread.org/qa/thread-11718-1-1.html(因微信無(wú)法插入外部鏈接,請(qǐng)將以上鏈接復(fù)制至外部瀏覽器打開(kāi))
如何在RT-Thread上使用這個(gè)功能
要用這玩意 首先你的RT-Thread bsp得有usb驅(qū)動(dòng) -- 推薦大家使用下面的bsp或者仿照下面的bsp對(duì)STM32F4系列的USB驅(qū)動(dòng)進(jìn)行快速移植。(超簡(jiǎn)單)
bsp/stm32/stm32f469-st-disco
有正點(diǎn)原子 L4 IOT Board的朋友也可以用相關(guān)的bsp。
大概的操作步驟如下:
1) 如果你的bsp的menuconfig有配置USB的驅(qū)動(dòng)加載開(kāi)關(guān)(比如bsp/stm32/stm32f469-st-disco),那么把它打開(kāi)。
這里不是每一個(gè)bsp都有此配置,有些bsp直接通過(guò)usb組件是否開(kāi)啟來(lái)判斷是否使用usb驅(qū)動(dòng)
2) 把LWIP打開(kāi)
這里必須先打開(kāi)LWIP才能在USB Device找到RNDIS/ECM
3)把RNDIS/ECM打開(kāi)
RNDIS:
ECM:
4)編譯下載插USB。
然后你的Windows/Mac/Linux 上就能看到網(wǎng)卡了。是不是超簡(jiǎn)單。
FAQ
Q
為什么設(shè)備上不了網(wǎng)?
因?yàn)槟阒皇呛碗娔X連起來(lái)了而已,并沒(méi)有路由器,甚至沒(méi)有DHCP,Windows上可以使用網(wǎng)絡(luò)共享或者網(wǎng)絡(luò)橋接的方式,如果是用Linux的人。我估計(jì)也不用我多嗶嗶。
Q
如果想要板子做DHCP怎么辦?
menuconfig里面開(kāi)DHCP 然后在網(wǎng)卡linkup后調(diào)用 dhcpd_start('u0'); ECM的代碼里面做了如果開(kāi)DHCP的選項(xiàng)就會(huì)自動(dòng)啟動(dòng)DHCP服務(wù)器,可以做參考。
Q
速度怎么樣?
鏈接速度為FS 12Mbps HS 480Mbps,當(dāng)然實(shí)際上是達(dá)不到這個(gè)速度的。不過(guò)延遲那是相當(dāng)?shù)牡汀?/p>
Q
可以干嘛?
臨時(shí)取代一些調(diào)試麻煩得網(wǎng)絡(luò)接口(WIFI,以太網(wǎng))來(lái)調(diào)試一些網(wǎng)絡(luò)應(yīng)用,也可以用來(lái)給有USB卻沒(méi)有以太網(wǎng)的芯片擴(kuò)展一種上網(wǎng)方式,也可以?xún)?nèi)置一個(gè)web服務(wù)器用于配置設(shè)備等等等等....發(fā)揮你的想象力。
RT-Thread線上活動(dòng)
1、【RT-Thread能力認(rèn)證考試12月——RCEA】經(jīng)過(guò)第一次考試的驗(yàn)證,RT-Thread能力認(rèn)證得到了更多社區(qū)開(kāi)發(fā)者和產(chǎn)業(yè)界的大力支持!(點(diǎn)此查看)如果您有晉升、求職、尋找更好機(jī)會(huì)的需要,有深入學(xué)習(xí)和掌握RT-Thread的需求,歡迎垂詢(xún)/報(bào)考!
能力認(rèn)證官網(wǎng)鏈接:https://www.rt-thread.org/page/rac.html(在外部瀏覽器打開(kāi))
立即報(bào)名
#題外話(huà)# 喜歡RT-Thread不要忘了在GitHub上留下你的
聯(lián)系客服