当写入特定地址时是否可以使x86 cpu中断?
我想要一个硬件机制来监视某些地址的变化。
我想知道在写入特定地址时是否可以使x86 cpu中断?
有可能的。
您可以设置调试寄存器之一(DR0
to DR4
) 到你想要监控的地址,然后在中配置相应的标志DR7
作为“全局断点,仅在数据写入时中断,1 字节大小”。一旦完成,该 CPU 完成的任何正常数据写入都会触发调试异常(中断 1),并且调试异常处理程序可以弄清楚发生了什么并执行您想要的任何操作(例如,向用户报告写入?)。
但是,存在一些限制 - 您不能在用户空间中自己执行此操作,并且需要依赖内核的支持;并且内核的支持希望包括在任务切换期间保存/恢复调试寄存器(以便当您的任务在另一个CPU上运行时您的断点不会停止工作,并且您的断点不会给其他任务带来问题)。因此(除非您完全控制计算机/CPU - 例如您正在编写自己的内核),通常您必须依赖操作系统提供的任何 API。
如果其他东西修改了内存(例如磁盘控制器或网卡),它也将不起作用。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)