吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1112|回复: 0
收起左侧

[讨论] 为啥提高IRQL就能禁止线程切换?

[复制链接]
aswcy815174418 发表于 2022-4-16 14:27
本帖最后由 aswcy815174418 于 2022-4-16 14:29 编辑

最近看了一篇文章:文章链接
文章说的是提高IRQL到DISPATCH_LEVEL,就可以防止线程切换,在这里忽略主动切换
我所理解发生顺序是:IRQL提升到了DISPATCH_LEVEL->发生时钟中断->HalRequestSoftwareInterrupt(DISPATCH_LEVEL)->向自己发送的IPI被忽略

我的问题就在向自己发送的IPI被忽略

文章明确指出由于vector 41对应的tpr等于当前apic的tpr值,所以 被block,即hal!HalpDispatchInterrupt不会响应,也就不会发生线程切换。

时钟中断的函数调用顺序:HalBeginSystemInterrupt()->KeUpdateSystemTime()->KeUpdateRunTime()->HalEndSystemInterrupt()

从时钟中断调用HalBeginSystemInterrupt()HalEndSystemInterrupt()之间,TPR一直都是0xC1(时钟中断向量号),文章为什么会说当前APIC的TPR会是0x41呢?

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-23 14:56

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表