我在操作系统内核中编写了一些函数来发出指令计数器溢出上的性能监视中断(PMI)。它在我的机器(英特尔核心i5)上工作得很好。但是当我在qemu上运行它时
系统-x86_64-启用-kvm -cpu主机-m 256 -serial mon:stdio -cdrom var/run/hypervisor.iso
中断从不开火。我遗漏了什么吗?在qemu上启动PMI是否需要特殊的配置?我记得指令计数在qemu中运行得很好。msr寄存器以激活PMI
Msr::write(Msr::MSR_PERF_GLOBAL_CTRL, 0x700000003);
Msr::write(Msr::MSR_PERF_FIXED_CTRL, 0xa);
Msr::write(Msr::IA32_PERFEVTSEL0, 0x004100c5);为0x1000指令编写PMI程序
Msr::write(Msr::IA32_PERF_GLOBAL_OVF_CTRL, 1ull << 32);
Msr::write(Msr::MSR_PERF_FIXED_CTR0, 0xFFFFEFFF | 0xFFFF00000000);发布于 2018-05-03 20:21:21
在讨论这里中,您可以看到kvm只在写入PERF_FIXED_CTR_CTRL (0x38d)时才更新虚拟计数器。
因此,要获得pmi,您最好在最后位置设置这个寄存器,当然是在设置了计数器值之后。
为了完整起见,必须按以下顺序发出指示:
; set counter value.
mov edx, 0xffff
mov eax, 0xffff0000
mov ecx, 0x309
wrmsr
; set counting mode
xor edx, edx
mov eax, 0xa
mov ecx, 0x38d
wrmsrhttps://stackoverflow.com/questions/42073038
复制相似问题