我想直接从具有root特权的C代码读取msr 0x19a(IA32_CLOCK_MODULATIOn)。但是,我收到以下segfault错误。
a.out[27843] general protection ip:40053b sp:7fffefc38020 error:0 in a.out[400000+1000]
有谁知道这种调用rdmsr的方式是否可行?
提前致谢!
#include <stdio.h>
#define __init
typedef unsigned uint32_t;
static int __init test3_init(void)
{
uint32_t hi,lo;
hi=0x0; lo=0x0;
asm volatile("mov $0x19a,%ecx");
asm volatile("rdmsr":"=a"(lo),"=d"(hi));
printf("exit_readmsr: hi=%08x lo=%08x\n",hi,lo);
return 0;
}
int main(void)
{
return test3_init();
}
顺便说一句,代码是从this答案中提取的。
最佳答案
该指令必须在特权级别0执行。换句话说,您必须在内核内部。
关于c - 根具有Segfault执行RDMSR汇编代码,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/26331730/