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)于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)辦法了。
如何在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)槟阒皇呛?a href="http://m.xsypw.cn/v/tag/1247/" target="_blank">電腦連起來(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ā)揮你的想象力。
-
mcu
+關(guān)注
關(guān)注
146文章
17370瀏覽量
352916 -
以太網(wǎng)
+關(guān)注
關(guān)注
40文章
5466瀏覽量
172866 -
網(wǎng)卡
+關(guān)注
關(guān)注
4文章
315瀏覽量
27485
原文標(biāo)題:TCP/IP Over USB 用USB傳輸以太網(wǎng)數(shù)據(jù),給你的MCU加個(gè)網(wǎng)卡
文章出處:【微信號(hào):RTThread,微信公眾號(hào):RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
快速入門(mén)!RNDIS網(wǎng)卡實(shí)現(xiàn)USB上網(wǎng)~
![快速入門(mén)!RNDIS<b class='flag-5'>網(wǎng)卡</b>實(shí)現(xiàn)<b class='flag-5'>USB</b>上網(wǎng)~](https://file1.elecfans.com/web3/M00/03/72/wKgZPGdpFqWAZlwkAABbsAP2O1I404.png)
為什么MPLS仍是以太網(wǎng)傳輸技術(shù)的首選
![為什么MPLS仍是<b class='flag-5'>以太網(wǎng)</b><b class='flag-5'>傳輸</b>技術(shù)的首選](https://file1.elecfans.com/web3/M00/00/63/wKgZPGdJFqSAPy_NAAArTnoGJNU567.png)
以太網(wǎng)和TCP/IP的關(guān)系解析
以太網(wǎng)的傳輸介質(zhì)和工作模式
以太網(wǎng)數(shù)據(jù)采集網(wǎng)關(guān):數(shù)據(jù)匯聚與傳輸的關(guān)鍵橋梁
![<b class='flag-5'>以太網(wǎng)</b><b class='flag-5'>數(shù)據(jù)</b>采集網(wǎng)關(guān):<b class='flag-5'>數(shù)據(jù)</b>匯聚與<b class='flag-5'>傳輸</b>的關(guān)鍵橋梁](https://file1.elecfans.com//web2/M00/08/9D/wKgaombyXTeAVuIPAAPVgT1WpFg604.png)
水電表集中器支持以太網(wǎng)傳輸數(shù)據(jù)嗎?
![水電表集中器支持<b class='flag-5'>以太網(wǎng)</b><b class='flag-5'>傳輸</b><b class='flag-5'>數(shù)據(jù)</b>嗎?](https://file1.elecfans.com/web2/M00/02/61/wKgZoma7KpmAMAmbAABtolBeDjc673.png)
以太網(wǎng)無(wú)法連接外網(wǎng)IP,提示No route to host,為什么?
RS485轉(zhuǎn)LoRa-以太網(wǎng)TCP轉(zhuǎn)LoRa
![RS485轉(zhuǎn)LoRa-<b class='flag-5'>以太網(wǎng)</b><b class='flag-5'>TCP</b>轉(zhuǎn)LoRa](https://file1.elecfans.com/web2/M00/F0/48/wKgZomZyRLiAd6zgAABXbNAllyk415.png)
以太網(wǎng)接口的數(shù)據(jù)傳輸原理詳解
用stm32f4的以太網(wǎng)傳輸ADC采用數(shù)據(jù),ADC采樣數(shù)據(jù)會(huì)發(fā)生偏差的原因?
用示波器分析以太網(wǎng)傳輸機(jī)制
![<b class='flag-5'>用</b>示波器分析<b class='flag-5'>以太網(wǎng)</b><b class='flag-5'>傳輸</b>機(jī)制](https://file.elecfans.com/web2/M00/6D/35/poYBAGM1MoCAWOOXAAAqWi8Xt8w214.png)
STM32H743以太網(wǎng)與高速USB同時(shí)工作遇到的疑問(wèn)求解
應(yīng)用場(chǎng)景:USB轉(zhuǎn)以太網(wǎng)標(biāo)準(zhǔn)模塊
請(qǐng)問(wèn)STM32G4系列的MCU可以支持以太網(wǎng)嗎?
工業(yè)以太網(wǎng)的基本原理及優(yōu)勢(shì)
![工業(yè)<b class='flag-5'>以太網(wǎng)</b>的基本原理及優(yōu)勢(shì)](https://file1.elecfans.com/web2/M00/C3/C6/wKgaomXoKeWAbDNNAAHAbk1HA9E809.png)
評(píng)論