blob: 75fc60243bcb4fa5942a9fefb053e2873e7b485f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
#include <msr.h>
uint64_t read_msr(uint32_t addr)
{
uint64_t eax;
uint64_t edx;
uint64_t ecx = addr;
__asm__ volatile ("rdmsr;" : "=a"(eax), "=d"(edx) : "c"(ecx) :);
return (edx << 32) | eax;
}
void write_msr(uint32_t addr, uint64_t value)
{
uint64_t eax = value & 0xFFFFFFFF;
uint64_t edx = value >> 32;
uint64_t ecx = addr;
__asm__ volatile ("wrmsr;" : : "a"(eax), "d"(edx), "c"(ecx) :);
}
|