diff options
Diffstat (limited to 'include/asm-x86/msr.h')
-rw-r--r-- | include/asm-x86/msr.h | 19 |
1 files changed, 10 insertions, 9 deletions
diff --git a/include/asm-x86/msr.h b/include/asm-x86/msr.h index effb7319c0a5..cb7222358897 100644 --- a/include/asm-x86/msr.h +++ b/include/asm-x86/msr.h | |||
@@ -63,13 +63,14 @@ static inline unsigned long long native_read_msr_safe(unsigned int msr, | |||
63 | return val; | 63 | return val; |
64 | } | 64 | } |
65 | 65 | ||
66 | static inline void native_write_msr(unsigned int msr, unsigned long long val) | 66 | static inline void native_write_msr(unsigned int msr, |
67 | unsigned low, unsigned high) | ||
67 | { | 68 | { |
68 | asm volatile("wrmsr" : : "c" (msr), "A"(val)); | 69 | asm volatile("wrmsr" : : "c" (msr), "a"(low), "d" (high)); |
69 | } | 70 | } |
70 | 71 | ||
71 | static inline int native_write_msr_safe(unsigned int msr, | 72 | static inline int native_write_msr_safe(unsigned int msr, |
72 | unsigned long long val) | 73 | unsigned low, unsigned high) |
73 | { | 74 | { |
74 | int err; | 75 | int err; |
75 | asm volatile("2: wrmsr ; xorl %0,%0\n" | 76 | asm volatile("2: wrmsr ; xorl %0,%0\n" |
@@ -82,7 +83,7 @@ static inline int native_write_msr_safe(unsigned int msr, | |||
82 | " .long 2b,3b\n\t" | 83 | " .long 2b,3b\n\t" |
83 | ".previous" | 84 | ".previous" |
84 | : "=a" (err) | 85 | : "=a" (err) |
85 | : "c" (msr), "0" ((u32)val), "d" ((u32)(val>>32)), | 86 | : "c" (msr), "0" (low), "d" (high), |
86 | "i" (-EFAULT)); | 87 | "i" (-EFAULT)); |
87 | return err; | 88 | return err; |
88 | } | 89 | } |
@@ -118,20 +119,20 @@ static inline unsigned long long native_read_pmc(int counter) | |||
118 | (val2) = (u32)(__val >> 32); \ | 119 | (val2) = (u32)(__val >> 32); \ |
119 | } while(0) | 120 | } while(0) |
120 | 121 | ||
121 | static inline void wrmsr(u32 __msr, u32 __low, u32 __high) | 122 | static inline void wrmsr(unsigned msr, unsigned low, unsigned high) |
122 | { | 123 | { |
123 | native_write_msr(__msr, ((u64)__high << 32) | __low); | 124 | native_write_msr(msr, low, high); |
124 | } | 125 | } |
125 | 126 | ||
126 | #define rdmsrl(msr,val) \ | 127 | #define rdmsrl(msr,val) \ |
127 | ((val) = native_read_msr(msr)) | 128 | ((val) = native_read_msr(msr)) |
128 | 129 | ||
129 | #define wrmsrl(msr,val) native_write_msr(msr, val) | 130 | #define wrmsrl(msr, val) native_write_msr(msr, (u32)val, (u32)(val >> 32)) |
130 | 131 | ||
131 | /* wrmsr with exception handling */ | 132 | /* wrmsr with exception handling */ |
132 | static inline int wrmsr_safe(u32 __msr, u32 __low, u32 __high) | 133 | static inline int wrmsr_safe(unsigned msr, unsigned low, unsigned high) |
133 | { | 134 | { |
134 | return native_write_msr_safe(__msr, ((u64)__high << 32) | __low); | 135 | return native_write_msr_safe(msr, low, high); |
135 | } | 136 | } |
136 | 137 | ||
137 | /* rdmsr with exception handling */ | 138 | /* rdmsr with exception handling */ |