a201ef42f2ab7033618680fb6c9a3262c5dd57e2
[coreboot.git] / src / include / cpu / x86 / msr.h
1 #ifndef CPU_X86_MSR_H
2 #define CPU_X86_MSR_H
3
4 #if defined(__ROMCC__)
5
6 typedef __builtin_msr_t msr_t;
7
8 static msr_t rdmsr(unsigned long index)
9 {
10         return __builtin_rdmsr(index);
11 }
12
13 static void wrmsr(unsigned long index, msr_t msr)
14 {
15         __builtin_wrmsr(index, msr.lo, msr.hi);
16 }
17
18 #else
19
20 typedef struct msr_struct
21 {
22         unsigned lo;
23         unsigned hi;
24 } msr_t;
25
26 typedef struct msrinit_struct 
27 {
28         unsigned index;
29         msr_t msr;
30 } msrinit_t;
31
32 static inline msr_t rdmsr(unsigned index)
33 {
34         msr_t result;
35         __asm__ __volatile__ (
36                 "rdmsr"
37                 : "=a" (result.lo), "=d" (result.hi)
38                 : "c" (index)
39                 );
40         return result;
41 }
42
43 static inline void wrmsr(unsigned index, msr_t msr)
44 {
45         __asm__ __volatile__ (
46                 "wrmsr"
47                 : /* No outputs */
48                 : "c" (index), "a" (msr.lo), "d" (msr.hi)
49                 );
50 }
51
52 #endif /* __ROMCC__ */
53
54 #endif /* CPU_X86_MSR_H */