gpt4 book ai didi

visual-studio - NDIS 和微型端口驱动程序

转载 作者:行者123 更新时间:2023-12-01 04:38:29 32 4
gpt4 key购买 nike

我正在尝试使用 Visual Studio 2012 中提供的 WDK 工具修改以太网驱动程序。

WDK 中提供的示例包括“微型端口适配器”和“NDIS 轻型过滤器”等。我仍处于驱动程序编写的最初阶段,因此很难浏览代码。

在 Visual Studio 2012 中构建微型端口适配器后,我能够安装它 [在我的网络适配器列表中显示为“Microsoft 虚拟微型端口适配器”。]我还可以为其分配 IP 地址和子网掩码。[我发现它没有连接到我电脑上的任何物理设备]。

我还设置了“调试 View ”软件来检查来 self 的适配器的驱动程序消息。[我在代码中使用了“DbgPrint”语句然后构建它。]但是,调试消息被重复打印。

1- 为什么消息会一次又一次地打印出来?这些消息来自程序的“datapath.c”文件和函数“MPSendNetBufferLists”。 ['Net Buffer' 指定在网络上发送或接收的数据。]

2- 我设置了 Wireshark 来捕获适配器上的数据,它显示有来自 ARP、HTTP、SSDP、MDNS 等的请求。我不明白适配器实际上在说什么?我怎样才能阻止它说话?

我可以使用“ping”来查看我分配给适配器的 IP 地址上是否存在连接,它会成功响应,告知所有数据包已发送且没有数据包丢失。

我的目标是通过 IP 地址向此以太网适配器发送和接收“数据”数据包。即-我想要一个应用程序连接到分配给适配器的 IP 地址并与之通信。

3- 我真的可以使用 WDK 中提供的示例来实现吗?

欢迎提出任何其他建议。

PS- 我无法使用 Visual Studio 2012 中内置的 Windows 调试器。我使用了 2 台 PC,并且能够连接驱动程序并将其安装到“目标”PC 上,但无法对断点等进行任何操作。在“目标”PC 上安装驱动程序后,代码和程序什么也没做。对此有什么建议吗?我以为我也可以对驱动程序进行逐步调试。[我知道我错了]。

谢谢阿迪亚

最佳答案

与许多低级驱动程序一样,NDIS 微型端口驱动程序旨在与硬件对话。微型端口的职责是从操作系统接收发送数据包,将它们转换为硬件所需的任何格式,并指示硬件在线路上发送数据包。

WDK 可以(事实上,曾经)包括一个真实世界的示例驱动程序,该驱动程序在真实世界的硬件上发送数据包。但这会导致一些困惑,因为现实世界的驱动程序必须处理许多硬件特定的细节,这些细节会分散示例的要点。如果您从真实世界的驱动程序开始,您要做的第一件事就是识别所有特定于硬件的位并将其删除,这样您就可以用您自己的特定于硬件的位替换它们。

相反,WDK 中的“netvmini”示例是一个伪造的驱动程序。这意味着它假装拥有真正的硬件,但实际上这一切都是谎言。当操作系统向 netvmini 发送数据包时,netvmini 驱动程序将简单地将这些数据包广播到该机器上安装的任何其他 netvmini 微型端口适配器。 (实际上,在同一台机器上安装 2 个 netvmini 适配器模拟了将两个真实适配器插入同一个以太网集线器时会发生的情况。)所以在 ASCII-art 中,如果在同一系统上安装两个 netvmini 适配器会发生这种情况:

       TCPIP                       TCPIP                      TCPIP
| | |
Real physical miniport Your netvmini #1 Your netvmini #2
| \ /
[The Internet] [The netvmini virtual hub]

希望正如 ASCII 艺术所示,您的 netvmini 适配器没有任何到 Internet 的路径。因此,在您添加硬件详细信息之前,您的驱动程序不会获得可以路由到 Internet 的“真实”IP 地址。在此之前,Windows 将继续尝试发送永远不会到达任何地方的 ARP 和 HTTP 请求。

回答您的具体问题:

  1. 每次操作系统尝试发送数据包时,都会打印来自 MPSendNetBufferLists 的消息。因为操作系统认为你有一个真正的网络连接,所以操作系统会多次尝试使用它。最终,当一切都得出结论这不是一个有用的链接时,这应该会平静下来。

  2. 请求来自 TCPIP。如果您不希望 TCPIP 发送数据,则将其与适配器解除绑定(bind)。

  3. 您绝对可以向适配器发送数据。事实上,您已经观察到您已经在发送随机 HTTP 数据包等。但是数据实际上不会到达 Internet,直到您教会驱动程序如何与您的真实硬件对话。

如果您坐在那里思考“但我没有硬件!”,那么您可能想要创建某种虚拟微型端口。虚拟微型端口就像 netvmini,因为它们没有真正的硬件,但它们仍然有一些方法可以从机器上获取数据包。例如,在第 2 层(如 L2TP)运行的 VPN 微型端口通常会安装第二个驱动程序 - NDIS 协议(protocol)驱动程序 - 从“真实”物理微型端口发送和接收数据。然后,每当需要从机器上获取数据包时,虚拟微型端口就会与其协议(protocol)进行对话。结果是:

        TCPIP
|
Your virtual miniport
|
Your NDIS protocol
|
The real physical miniport
|
The Internet

有替代架构;例如,在第 4 层(如 SSTP)运行的 VPN 可能决定打开 WSK 套接字而不是实现 NDIS 协议(protocol)驱动程序:

        TCPIP
|
Your virtual miniport
|
WSK socket
|
TCPIP
|
The real physical miniport
|
The Internet

关于visual-studio - NDIS 和微型端口驱动程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11255311/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com