RNDIS和ECM的热插拔问题 4 x4 L. b8 |1 N5 p# s 最近修复了一波 RNDIS 和 ECM的热插拔通信异常问题,添加了通过menuconfig配置RNDIS delay linkup的配置选项。问题修复点如下: . |# d. i; U, O/ T RNDIS: · 当存在通信链接时 热插拔 Windows会发送REMOTE_NDIS_RESET_MSG,该指令未实现,现已实现。 · 当存在通信链接时 热插拔 eth_tx线程大几率会死等传输完成的信号量通知,导致LWIP卡死。 · 当存在通信链接时 热插拔 eth_rx的接收缓冲未重置,导致接收数据异常。 ECM: · 当存在通信链接时 热插拔 eth_tx线程大几率会死等传输完成的信号量通知,导致LWIP卡死。 · 当存在通信链接时 热插拔 eth_rx的接收缓冲未重置,导致接收数据异常。 现已测试 stm32f469i-discovery / LWIP2.0.2 /Windows 10 1903下 RNDIS,iperf传输过程中反复热插拔后功能正常, delay linkup宏开启前后功能正常,连续热插拔功能正常。 现已测试 stm32f469i-discovery / LWIP2.0.2 /MacOS Mojave 10.14.2下 ECM,iperf传输过程中反复热插拔后功能正常。 " L7 g7 c0 D1 Z( u 相关Pull Request: http://github.com/RT-Thread/rt-thread/pull/2764(因微信无法插入外部链接,请将以上链接复制至外部浏览器打开) . X7 `+ F- t: q 关于NDIS RNDIS全称Remote NDIS 是Microsoft定义的一种USB以太网卡模型,说到RNDIS 必须要说说另一个东西,NDIS。 NDIS(Network Driver InterfaceSpecification)是网络驱动程序接口规范的简称。它横跨传输层、网络层和数据链路层,定义了网卡或网卡驱动程序与上层协议驱动程序之间的通信接口规范,屏蔽了底层物理硬件的不同,使上层的协议驱动程序可以和底层任何型号的网卡通信。NDIS为网络驱动程序创建了一个完整的开发环境,只需调用NDIS函数,而不用考虑操作系统的内核以及与其他驱动程序的接口问题,从而使得网络驱动程序可以从与操作系统的复杂通讯中分离,极大地方便了网络驱动程序的编写。另外,利用NDIS的封装特性,可以专注于一层驱动的设计,减少了设计的复杂性,同时易于扩展驱动程序栈。 ( [( V! N& q# h/ N3 p# j0 x& q 而RNDIS 就是NDIS这种规范基于USB的一种具体实现,RNDIS目前可以在Windows7 or later(讲道理Vista也是可以的)上自动加载驱动,无需第三方驱动。而对于Linux和MacOS来说RNDIS则需要安装第三方驱动了,部分Linux发行版内置了RNDIS的驱动(谁叫Windows用的人多了)。至于LinuxMac 下如何使用RNDIS这里不跟你多解释,因为我提供了另一种解决方案--------CDC-ECM。 CDC-ECM(EthernetNetworking Control Model)是USB联盟定义的标准USB以太网控制器模型(很遗憾,Windows下没有驱动),绝大部分Linux发行版和MacOS都支持该种USB设备的驱动。这里讲的绝大多数包括了各种pi,当然如果你自己编译的linux手动剔除了这份驱动就没办法了。 , E- y) ~" n# B. c% o& K: L 下载RNDIS/ECM白皮书请由此入: http://www.rt-thread.org/qa/thread-11718-1-1.html(因微信无法插入外部链接,请将以上链接复制至外部浏览器打开) ! ~# @3 o3 z" O$ G6 f5 U 如何在RT-Thread上使用这个功能 要用这玩意 首先你的RT-Thread bsp得有usb驱动 -- 推荐大家使用下面的bsp或者仿照下面的bsp对STM32F4系列的USB驱动进行快速移植。(超简单) bsp/stm32/stm32f469-st-disco , l. q: K, F* z6 V 有正点原子 L4 IOT Board的朋友也可以用相关的bsp。 大概的操作步骤如下: $ S6 C! Q# ?- N0 t9 r 1) 如果你的bsp的menuconfig有配置USB的驱动加载开关(比如bsp/stm32/stm32f469-st-disco),那么把它打开。 这里不是每一个bsp都有此配置,有些bsp直接通过usb组件是否开启来判断是否使用usb驱动 4 X$ ~8 w/ I' A' s2 r* W2) 把LWIP打开 这里必须先打开LWIP才能在USBDevice找到RNDIS/ECM % v8 ~9 g1 B. a3)把RNDIS/ECM打开 RNDIS: ECM: ; q" n5 K8 r/ l3 G0 q3 j5 C# i4)编译下载插USB。 然后你的Windows/Mac/Linux 上就能看到网卡了。是不是超简单。 - e' l1 }6 @3 c) o$ H FAQ 4 ?/ m# p( M3 Q" h Q为什么设备上不了网? 因为你只是和电脑连起来了而已,并没有路由器,甚至没有DHCP,Windows上可以使用网络共享或者网络桥接的方式,如果是用Linux的人。我估计也不用我多哔哔。 Q如果想要板子做DHCP怎么办? menuconfig里面开DHCP 然后在网卡linkup后调用 dhcpd_start("u0"); ECM的代码里面做了如果开DHCP的选项就会自动启动DHCP服务器,可以做参考。 - ~0 N) a1 a9 N Q速度怎么样? 链接速度为FS 12Mbps HS 480Mbps,当然实际上是达不到这个速度的。不过延迟那是相当的低。 Q可以干嘛? 临时取代一些调试麻烦得网络接口(WIFI,以太网)来调试一些网络应用,也可以用来给有USB却没有以太网的芯片扩展一种上网方式,也可以内置一个web服务器用于配置设备等等等等....发挥你的想象力。 " j: Z7 A& P6 _! `, B' a! ]8 g, ^' K4 K& @ |
脑洞大开 |
收藏学习 |
我记得beaglebone black开箱程序就是直接插usb,然后蹦出个网卡,教程说直接开网页就能进cloud9编程了,当时觉得这功能d爆了 |
谢谢分享! |
最全USB HID开发资料,悉心整理一个月,亲自测试
USB Audio设计与实现
【MCU实战经验】+STM32F107的USB使用
圈圈发布USB图书第二版有感,以及分享一些我学习USB过程...
STM32F4-DISC 实现USB主机(U盘)和USB设备(虚拟串口)自动切换
STM32 USB-HID通信移植步骤STM32 USB HID键盘例程
【经验分享】在进行 USB CDC 类开发时,无法发送 64整数倍的数据
如何让CDC类USB设备批量接收64字节以上数据
用STM32F4实现的USB摄像头UVC,配合上位机可识别车牌
STM32 USB CDC 虚拟多串口