IRQL_NOT_LESS_OR_EQUAL错误

对于像我这样的windows驱动开发新手,对分页内存、非分页内存和IRQL这些只是有个概念印象,必须通过驱动中犯的错误总结才能真正领悟。

今天我的驱动遇到了IRQL_NOT_LESS_OR_EQUAL错误,导致蓝屏,查了一些资料,总结如下:

找到的例子和技巧,

    今天在调试驱动的时候,发现一个开始觉得很奇怪的问题,就是调用RtlStringCbPrintfW函数来格式化WCHAR字符串时,一定蓝屏,提示
IRQL_NOT_LESS_OR_EQUAL,并且比较郁闷的是,在虚拟机上有时不会出现,有时会出现,但在真正的主机上一定会出现(Windows xp sp2)。
一般出现IRQL_NOT_LESS_OR_EQUAL,是IRQL在级别高的地方调用了分页内存,所以,我就想到把当前的IRQL打出来看看,发现在进入函数
的时候,当前的IRQL是0(PASSIVE_LEVEL),而在执行这段代码的地方,IRQL是2(DISPATCH_LEVEL),是什么原因使得IRQL发生了变化呢?
仔细查看代码后,发现了原因,因为在执行这段代码之前,通过NdisAcquireSpinLock获取旋转锁,而在旋转锁释放之前,其中的代码是跑在
IRQL=2的,另外,RtlStringCbPrintfW需要处理分页内存(PagedPool),但在IRQL=2的情况下,是只能处理非分页内存的(NonpagedPool),所以,
就产生了上面的蓝屏现象。

这里给出驱动内存的分配细节:
驱动编程时,也有两种申请内存的方式:
(1).在核心栈中申请,在X86 R0级中,核心栈只有约两个页面的大小,所以DDK中提到,不能使用递归调用。
(2).在核心堆中申请,比如ExAllocatePoolWithTag函数就可以。不过核心堆分成两种:分页的、非分页的。

另外,获取当前IRQL级别方法:
 KIRQL uIrql = KeGetCurrentIrql();
 DEBUG_INFO(("%s is run on level: %x\n", __FUNCTION__, uIrql));


我的错误原因是在DPC例程中引用了分页内存。

### IRQL_NOT_LESS_OR_EQUAL 异常解析 IRQL_NOT_LESS_OR_EQUAL 是一种常见的 Windows 蓝屏错误,通常表明系统遇到了严重的硬件或驱动程序问题。此错误表示当前线程尝试访问的地址在低于所需中断请求级别 (IRQL) 的情况下被锁定[^1]。 #### 中断请求级别简介 中断请求级别(Interrupt Request Level, IRQL)是 Windows 内核用于管理不同类型的中断优先级的一种机制。较高的 IRQL 表示更高的优先权,在较高 IRQL 下运行的代码不允许等待较低级别的事件完成。当发生 IRQL_NOT_LESS_OR_EQUAL 错误时,意味着某个进程试图在一个不合适的 IRQL 上执行特定的操作,这违反了系统的调度原则。 #### 可能的原因 - **驱动程序冲突**:第三方设备驱动可能编写不当,未能正确处理资源释放或同步问题。 - **硬件故障**:特别是内存条、硬盘等存储设备可能出现物理损伤。 - **恶意软件感染**:某些病毒会篡改系统文件,影响正常工作流程。 - **操作系统文件损坏**:重要系统组件受损也可能引发此类错误。 对于上述提到的 `KERNEL_STACK_INPAGE_ERROR` (错误码 0x00000077),虽然不是直接与 IRQL 相关,但如果磁盘存在问题,则可能导致加载内核栈失败进而触发 IRQL_NOT_LESS_OR_EQUAL 错误。因此建议定期维护磁盘健康状态,及时更新驱动版本,并保持良好的安全防护措施[^2]。 ```powershell # 使用 chkdsk 工具检查并修复磁盘错误 chkdsk /f /r C: ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值