summaryrefslogtreecommitdiff
path: root/kernel/src/cpu/msr.c
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) :);
}