windows RNDIS开发-概念

2024-06-06 10:28
文章标签 windows 开发 概念 rndis

本文主要是介绍windows RNDIS开发-概念,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

远程 NDIS (RNDIS) 是一种独立于总线的类,适用于动态 即插即用 (PnP) 总线(例如 USB、1394、蓝牙和 InfiniBand)上的以太网 (802.3) 网络设备。 远程 NDIS 通过抽象控制和数据通道在主计算机与远程 NDIS 设备之间定义与总线无关的消息协议。 远程 NDIS 足够精确,允许对主计算机上的远程 NDIS 设备提供与供应商无关的类驱动程序支持。

从 Windows XP 开始的 Microsoft Windows 版本包括适用于 USB 设备的远程 NDIS 驱动程序。 此 NDIS 微型端口驱动程序(Rndismp.sys)由 Microsoft 实现和维护,并作为所有受支持的 Windows 版本的一部分来分发。 可以在 %SystemRoot%\System32\drivers 目录中找到它。

若要将此驱动程序用于 USB 设备,IHV 必须提供一个 INF 文件,该文件遵循 远程 NDIS INF 模板中的模板。

远程 NDIS 消息从主机发送到远程 NDIS 设备,远程 NDIS 设备使用相应的完成消息进行响应。 消息还会以未经请求的方式从远程 NDIS 设备发送到主机。

远程 NDIS (RNDIS) 无需硬件供应商为连接到 USB 总线的网络设备编写 NDIS 微型端口设备驱动程序。 远程 NDIS 通过定义与总线无关的消息集并描述此消息集如何在 USB 总线上运行来实现此目的。 由于此远程 NDIS 接口是标准化的,因此一组主机驱动程序可以支持连接到 USB 总线的任意数量的网络设备。 这大大减轻了设备制造商的开发负担,提高了系统的整体稳定性,因为不需要新的驱动程序,并改进了最终用户体验,因为无需安装驱动程序来支持新的 USB 总线连接网络设备。 目前,Microsoft Windows 支持通过 USB 进行远程 NDIS。

下图显示了将设备制造商的 NDIS 微型端口替换为远程 NDIS 微型端口驱动程序和 USB 传输驱动程序的组合。 因此,设备制造商可以专注于设备实现,不必开发 Windows NDIS 设备驱动程序。

Microsoft 提供 NDIS 微型端口驱动程序 Rndismp.sys,该驱动程序实现远程 NDIS 消息集并与通用总线传输驱动程序通信,后者又与相应的总线驱动程序通信。 此 NDIS 微型端口驱动程序由 Microsoft 实现和维护,并作为 Windows 的一部分分发。

以下远程 NDIS 消息集反映了 NDIS 微型端口驱动程序接口的语义:

  • 初始化、重置和停止设备操作
  • 发送和接收网络数据包
  • 设置和查询设备操作参数
  • 指示媒体链接状态和监视设备状态

Microsoft 还提供 USB 总线传输驱动程序,该驱动程序实现一种机制,用于跨 USB 总线传输远程 NDIS 消息。 此驱动程序在远程 NDIS 微型端口驱动程序和特定于总线的驱动程序(如 USB)之间传输标准化的远程 NDIS 消息。 总线特定的驱动程序还需要将任何特定于总线的要求(例如电源管理)映射到标准化的远程 NDIS 消息。 USB 1.1 和 2.0 的传输驱动程序由 Microsoft 实现和维护,并作为 Windows 的一部分分发。

此结构允许将单个设备驱动程序用于具有特定于总线的传输层的任何远程 NDIS 设备。 此外,特定总线上的所有网络设备只需要一个总线传输层。

远程 NDIS 的优势

远程 NDIS 是经过充分理解和经过时间测试的 NDIS 体系结构的扩展。 NDIS 为特定于设备的 NDIS 微型端口驱动程序定义函数调用接口。 此接口定义用于发送和接收网络数据以及查询和设置配置参数和统计信息的基元。 远程 NDIS 通过为 NDIS 微型端口驱动程序接口定义消息包装来利用 NDIS,从而将 NDIS 处理代码从微型端口驱动程序移动到设备本身。 在此和其他方面,远程 NDIS 允许使用各种设备功能和性能级别。 远程 NDIS 模型具有许多优点:

  • 扩展性,无需更改特定于总线的消息传输机制;
  • 能够在短时间内通过更多总线支持更多协议;
  • 已为网络和外部总线设备模型验证的驱动程序体系结构;
  • 远程 NDIS 设备支持 NDIS 网络堆栈中已存在的增值机制;
远程 NDIS 的概念和定义

下面的内容概述了用于在主机和远程 NDIS 设备之间进行通信的信道和较低层驱动程序上的远程 NDIS 要求:

  • 控制通道:控制通道必须可靠,并确保按顺序传递。 它用于除网络数据包的传输之外的所有通信。 除 REMOTE_NDIS_HALT_MSG 和 REMOTE_NDIS_INDICATE_STATUS_MSG外,所有必需的控制消息都是主机启动的请求和响应交换。 设备必须在针对每个总线指定的超时期限内响应;
  • 数据通道:数据通道专用于网络数据包的传输。 它可能包含多个子通道, 例如,针对为相应总线定义的不同服务质量;
  • 初始化和拆解:控件和数据通道将按为相应总线指定的方式进行初始化和设置。 主机向远程 NDIS 设备发送 REMOTE_NDIS_INITIALIZE_MSG 消息。 远程 NDIS 设备在 响应消息REMOTE_NDIS_INITIALIZE_CMPLT中提供有关其类型 (无连接或面向连接的) 、支持的介质和版本的信息。主机或远程 NDIS 设备可以通过 REMOTE_NDIS_HALT_MSG 消息断开信道。 收到此消息后,将丢弃所有未完成的请求和数据包;
  • 设备状态定义:在总线级初始化之后,设备据说处于 RNDIS 未初始化状态。 收到REMOTE_NDIS_INITIALIZE_MSG并使用状态为 RNDIS_STATUS_SUCCESS 的REMOTE_NDIS_INITIALIZE_CMPLT进行响应时,设备将进入 RNDIS 初始化状态。收到REMOTE_NDIS_SET_MSG指定OID_GEN_CURRENT_PACKET_FILTER非零筛选器值后,设备将进入 RNDIS 数据初始化状态。处于 RNDIS-data-initialized 状态时,接收REMOTE_NDIS_SET_MSG为 OID_GEN_CURRENT_PACKET_FILTER指定零筛选器值会强制设备返回到 RNDIS 初始化状态。随时接收REMOTE_NDIS_HALT_MSG或总线级断开连接或硬重置会强制设备进入 RNDIS 未初始化状态;
  • Halt:每当设备处于 RNDIS 初始化或 RNDIS 数据初始化状态时,主机可以通过向设备发送REMOTE_NDIS_HALT_MSG来终止设备的远程 NDIS 功能;
  • 重置信道:发生错误(如消息超时)时,将重置信道。 当设备处于 RNDIS 初始化状态时,主机可以随时通过向设备发送 REMOTE_NDIS_RESET_MSG 消息来启动重置,并且设备必须在完成重置后发送响应消息。 例如,当发生错误(如消息超时)时,主机可能会启动重置。请注意,这是软重置,因为任何处理 (例如,面向连接的设备的 VC 在重置后) 继续有效。 在重置过程中,远程 NDIS 设备会丢弃所有未完成的请求和数据包。 远程设备可能会重置其某些硬件组件,但保持信道不变。如果远程 NDIS 设备执行重新启动,则此事件等效于“删除”后跟“添加”即插即用事件。 主机 NDIS 微型端口驱动程序将停止和删除,并添加新实例并启动。 将重新执行所有总线级和远程 NDIS 初始化。 远程 NDIS 设备可能会在发生严重设备故障时自行重启;
  • 流控制:远程 NDIS 设备可能需要执行流控制,以防止主机使用数据包溢出其数据缓冲区。 任何流控制预配或要求都是特定于总线的;
  • 数字字节排序:远程 NDIS 消息中的所有数值都必须以 little-endian 格式编码 (最低有效字节第一) ;
  • NDIS 消息封装:对于在本机总线消息或基元中封装 NDIS 消息的方式,没有远程 NDIS 规范;
RNDIS 消息传送

有两种类型的远程 NDIS 消息:控制消息和数据消息。 控制消息允许主机和远程 NDIS 设备通过信道相互通信。 数据消息包含主机和设备之间通信所需的消息数据信息,并通过数据通道进行通信。

远程 NDIS 控制消息:远程 NDIS 控制消息可由主机发送到远程 NDIS 设备,远程 NDIS 设备可以发送到主机。 以太网 802.3 无连接设备必须支持以下远程 NDIS 控制消息:

  • REMOTE_NDIS_INITIALIZE_MSG
  • REMOTE_NDIS_INITIALIZE_CMPLT
  • REMOTE_NDIS_HALT_MSG
  • REMOTE_NDIS_QUERY_MSG
  • REMOTE_NDIS_QUERY_CMPLT
  • REMOTE_NDIS_SET_MSG
  • REMOTE_NDIS_SET_CMPLT
  • REMOTE_NDIS_RESET_MSG
  • REMOTE_NDIS_RESET_CMPLT
  • REMOTE_NDIS_INDICATE_STATUS_MSG
  • REMOTE_NDIS_KEEPALIVE_MSG
  • REMOTE_NDIS_KEEPALIVE_CMPLT

远程 NDIS 数据消息:远程 NDIS 设备必须通过 REMOTE_NDIS_PACKET_MSG 消息结构中包含的远程 NDIS 数据包发送和接收数据。 远程 NDIS 数据包还可能包含带外数据以及通过网络传输的数据。

无连接 (例如 802.3) 和面向连接的 (例如,ATM) 设备使用相同的 REMOTE_NDIS_PACKET_MSG 消息结构,以便于处理数据包的通用代码。

远程 NDIS 设备控制

主机使用REMOTE_NDIS_QUERY_MSG和REMOTE_NDIS_SET_MSG来控制远程 NDIS 设备的操作。 NDIS 对象 ID (OID) 与每条消息一起使用,以标识设备操作参数或统计信息计数器。 远程 NDIS OID 列表分为两组:常规 OID 和 802.3 特定 OID。 此外,每个组都包含统计 OID 查询的一个子部分。 任何网络设备都需要常规 OID。

这篇关于windows RNDIS开发-概念的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1035842

相关文章

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用

Windows自动化Python pyautogui RPA操作实现

《Windows自动化PythonpyautoguiRPA操作实现》本文详细介绍了使用Python的pyautogui库进行Windows自动化操作的实现方法,文中通过示例代码介绍的非常详细,对大... 目录依赖包睡眠:鼠标事件:杀死进程:获取所有窗口的名称:显示窗口:根据图片找元素:输入文字:打开应用:依

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

javafx 如何将项目打包为 Windows 的可执行文件exe

《javafx如何将项目打包为Windows的可执行文件exe》文章介绍了三种将JavaFX项目打包为.exe文件的方法:方法1使用jpackage(适用于JDK14及以上版本),方法2使用La... 目录方法 1:使用 jpackage(适用于 JDK 14 及更高版本)方法 2:使用 Launch4j(

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

windows端python版本管理工具pyenv-win安装使用

《windows端python版本管理工具pyenv-win安装使用》:本文主要介绍如何通过git方式下载和配置pyenv-win,包括下载、克隆仓库、配置环境变量等步骤,同时还详细介绍了如何使用... 目录pyenv-win 下载配置环境变量使用 pyenv-win 管理 python 版本一、安装 和

C#图表开发之Chart详解

《C#图表开发之Chart详解》C#中的Chart控件用于开发图表功能,具有Series和ChartArea两个重要属性,Series属性是SeriesCollection类型,包含多个Series对... 目录OverviChina编程ewSeries类总结OverviewC#中,开发图表功能的控件是Char