Root具有执行RDMSR汇编代码的Segfault

时间:2014-10-13 01:24:14

标签: c msr

我想直接从C代码 WITH root权限读取msr 0x19a(IA32_CLOCK_MODULATIOn)。但是,我收到以下段错误。

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();                      
 }

BTW,代码摘自this

1 个答案:

答案 0 :(得分:0)

该指令必须在特权级别0执行。换句话说,您必须在内核中。