为了安全起见,Windows XP及其以后的系统将一些重要的内存页设置为只读属性,这样就算有权力访问该表也不能随意对其修改,例如SSDT、IDT等。但这种方法很容易被绕过,我们只要将这些部分修改为可写属性就可以了,不过当我们的事情做完后记得把它们恢复为只读属性,不然会造成一些很难预料到的后果。
cr0是系统内的控制寄存器之一。控制寄存器是一些特殊的寄存器,它们可以控制CPU的一些重要特性。
控制寄存器最初出现于低级的286处理器中,以前称之为机器状态字(machine status word),在386以后它们被重命名为控制寄存器(control register)。
cr0寄存器直到486的处理器版本才被加入了“写保护”(Write Protect,WP)位,WP位控制是否允许处理器向标记为只读属性的内存页写入数据。
WP位0:禁用写保护的功能
WP位1:开启写保护的功能
cr0的第16位是WP位,只要将这一位置0就可以禁用写保护,置1则可将其恢复。

本文介绍了如何通过修改控制寄存器CR0中的WP位来绕过Windows系统的SSDT驱动保护。详细阐述了禁用和启用写保护的步骤,并提供了相关的内联汇编代码示例。请注意,此类操作属于特权指令,需在ring0权限下执行。
最低0.47元/天 解锁文章
1627

被折叠的 条评论
为什么被折叠?



