gpt4 book ai didi

c++ - 修改 Windows 磁盘驱动程序以使用更新的控制代码,如 IOCTL_DISK_GET_DRIVE_GEOMETRY_EX

转载 作者:IT老高 更新时间:2023-10-28 23:02:42 29 4
gpt4 key购买 nike

我正在尝试修改 Windows 内核级磁盘驱动程序以正确响应更新的控制代码。例如,它只有一个过时的 IOCTL_DISK_GET_DRIVE_GEOMETRY 控制代码的处理程序,但没有更新的 IOCTL_DISK_GET_DRIVE_GEOMETRY_EX 控制代码,所以我添加了它。
当然,我也更新了驱动程序以使用所有新的 Windows 结构和函数,例如 IoReadPartitionTableEx() 函数和 DRIVE_LAYOUT_INFORMATION_EX 结构(我正在尝试添加 GPT 支持给司机)。问题是,当我使用磁盘驱动程序时,我可以看到(使用 DebugView)Windows(我认为是 Windows……也许是别的……)仍在发送旧的 IOCTL_DISK_GET_DRIVE_GEOMETRY 控制代码给我的司机。我希望 Windows 将更新的控制代码发送给我的驱动程序。发送这些控制代码的甚至是 Windows 吗? Windows 和驱动程序之间是否存在我还不知道的其他层?

驱动程序是否应该以某种方式向 Windows 识别其“类型”,以便 Windows 确切知道如何与它“对话”? Windows 如何准确知道将哪些控制代码发送到特定驱动程序?我在谷歌上搜索了这些(看似非常基本的)问题的答案,但没有找到明确的答案,这让我相信我在这里从根本上误解了一些关于 Windows 驱动程序的内容。我的问题还有意义吗?

最佳答案

OP 有 5 个问题(根据问号数计算)。以下每个问题的回答顺序与 OP 中的问题顺序相同。

  1. 要找出谁在使用 IOCTL_DISK_GET_DRIVE_GEOMETRY 调用您的驱动程序,请在您的驱动程序中为该 IOCTL 的处理程序设置一个断点。发生中断时,请查看调用堆栈。你会看到是谁打来的。

  2. 你实际上会有一组分层的调用者。这将回答您关于图层的问题。

  3. Windows 以几种不同的方式了解您的驱动程序功能。如果您有一个微型端口驱动程序,那么每种类型的微型端口都必须实现一组最少的功能。

    此外,StorPort 微型端口还可以使用 API 来指示可选功能。例如,StorPortInitializePerfOpts 用于通知 StorPort 有关 StorPort 微型端口中的各种性能优化。为了更好地回答这个问题,请提供您拥有的驱动程序类型。如果您不熟悉各种驱动程序类型,建议您阅读 this来自 MS 硬件开发中心。事实上,您可能还是想阅读它。

  4. 问题假设 Windows 基于某些假设的驱动程序属性向不同的驱动程序发送不同的控制代码。但是,Windows 使用的模型与上一个答案中提到的模型一样。有基于驱动程序模型的基本功能,在某些情况下还有用于通信功能的 API。 (在其他情况下,由驱动程序指示它不支持特定操作。)

    答案还有另一个方面,那就是 Windows 和非 Windows 组件可以自由选择他们想要的任何控制代码。因此,第 3 方磁盘分区程序可以使用较旧的几何 IOCTL,即使存在较新的几何 IOCTL,因为它希望与早期版本的 Windows 兼容。或者,Windows 组件(例如存储空间)可以使用更新的 IOCTL,因为它不具备向后兼容性。

  5. (这个问题是征求意见,所以这个答案是我的意见)。假设“问题”是指“问题”,那么我或多或少会说。但如果这是您第一次(或第二次)涉足 Windows 驱动程序,我再次建议您阅读相关的 MS 文档(如上链接)。

最后,尽管 OP 没有直接询问,但听起来好像有一个问题“如何测试我添加的 IOCTL_DISK_GET_DRIVE_GEOMETRY_EX 功能?”。 IMO 最简单的方法是编写一个 Win32 测试程序。调用和显示这个 IOCTL 只需要 20 行左右的代码。比如说,编写 DISKPART 或类似脚本会更容易、更快捷。

关于c++ - 修改 Windows 磁盘驱动程序以使用更新的控制代码,如 IOCTL_DISK_GET_DRIVE_GEOMETRY_EX,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27607856/

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