关于WinDbg + Vmware 调试DDK程序

本文记录了作者在调试自定义驱动程序时遇到的问题及解决过程。主要问题是在应用程序首次执行时无法从驱动读取数据,并且在某些情况下会导致系统蓝屏。通过设置断点并逐步调试,最终定位到了代码中的逻辑错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

几经周折 终于学会了如何利用上述工具调试驱动程序了

刚刚解决了一个自己的程序的蓝屏问题

下面把过程记录下来

问题代码如下

 

 

编译没有问题 下面是我在虚拟机上执行的应用程序代码

 

BUG重现   但是执行改程序的时候  不知道为什么 第一次执行 总是无数据返回 必须要将驱动重启一遍

而驱动重启了之后 如果再停止  就会直接蓝屏

 

测试了两次之后 确定无余  就是会出现上述情况

 

于是 准备解决第一个问题   就是程序拿不到数据   在机器重启后  发现驱动已经加载了 而程序打不开设备

肯定是创建设备有问题  于是  重启 在程序的入口点下一个断点

bu MyDDK!DrierEntry(驱动未加载之前)

不放心 又在CreateDevice前面再下一个断点

程序进来之后  在Watch窗口 添加一个Status   发现一切都没有什么问题

但是执行到 创建链接符号的时候

if (NT_SUCCESS(status))
    {
        IoDeleteDevice(pDeviceObject);
        return status;
    }

发现运行到里面去了...

晕  恍然大悟 原来少了一个!   

而此时 删除了设备...

后面的Unload函数再删除设备肯定就会报错  导致蓝屏

 

第一次调试过程结束...

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值