RNDIS和ECM的热插拔问题
最近修复了一波 RNDIS 和 ECM的热插拔通信异常问题,添加了通过menuconfig
配置RNDIS delay linkup
的配置选项。问题修复点如下:
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传输过程中反复热插拔后功能正常。
相关Pull Request:
https://github.com/RT-Thread/rt-thread/pull/2764(因微信无法插入外部链接,请将以上链接复制至外部浏览器打开)
关于NDIS
RNDIS全称Remote NDIS 是Microsoft定义的一种USB以太网卡模型,说到RNDIS 必须要说说另一个东西,NDIS。
NDIS(Network Driver Interface Specification)是网络驱动程序接口规范的简称。它横跨传输层、网络层和数据链路层,定义了网卡或网卡驱动程序与上层协议驱动程序之间的通信接口规范,屏蔽了底层物理硬件的不同,使上层的协议驱动程序可以和底层任何型号的网卡通信。NDIS为网络驱动程序创建了一个完整的开发环境,只需调用NDIS函数,而不用考虑操作系统的内核以及与其他驱动程序的接口问题,从而使得网络驱动程序可以从与操作系统的复杂通讯中分离,极大地方便了网络驱动程序的编写。另外,利用NDIS的封装特性,可以专注于一层驱动的设计,减少了设计的复杂性,同时易于扩展驱动程序栈。
而RNDIS 就是NDIS这种规范基于USB的一种具体实现,RNDIS目前可以在Windows7 or later(讲道理Vist