diff options
author | H. Peter Anvin <hpa@zytor.com> | 2008-01-30 07:33:02 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-01-30 07:33:02 -0500 |
commit | 811a0fff5d6e80e18e06be88e0fb685f3924bf8f (patch) | |
tree | 93e10b51ccdf51244794cdd5f3750a0a01561d2a /arch/x86 | |
parent | 1cac5004e953506166e980da5776d5cc1c176d79 (diff) |
x86 setup: fix constraints in segment accessor functions
Fix the operand constraints for the segment accessor functions,
{rd,wr}{fs,gs}*. In particular, the 8-bit functions used "r"
constraints instead of "q" constraints.
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'arch/x86')
-rw-r--r-- | arch/x86/boot/boot.h | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/arch/x86/boot/boot.h b/arch/x86/boot/boot.h index d2b5adf46512..8ec575249aa9 100644 --- a/arch/x86/boot/boot.h +++ b/arch/x86/boot/boot.h | |||
@@ -109,7 +109,7 @@ typedef unsigned int addr_t; | |||
109 | static inline u8 rdfs8(addr_t addr) | 109 | static inline u8 rdfs8(addr_t addr) |
110 | { | 110 | { |
111 | u8 v; | 111 | u8 v; |
112 | asm volatile("movb %%fs:%1,%0" : "=r" (v) : "m" (*(u8 *)addr)); | 112 | asm volatile("movb %%fs:%1,%0" : "=q" (v) : "m" (*(u8 *)addr)); |
113 | return v; | 113 | return v; |
114 | } | 114 | } |
115 | static inline u16 rdfs16(addr_t addr) | 115 | static inline u16 rdfs16(addr_t addr) |
@@ -127,21 +127,21 @@ static inline u32 rdfs32(addr_t addr) | |||
127 | 127 | ||
128 | static inline void wrfs8(u8 v, addr_t addr) | 128 | static inline void wrfs8(u8 v, addr_t addr) |
129 | { | 129 | { |
130 | asm volatile("movb %1,%%fs:%0" : "+m" (*(u8 *)addr) : "r" (v)); | 130 | asm volatile("movb %1,%%fs:%0" : "+m" (*(u8 *)addr) : "qi" (v)); |
131 | } | 131 | } |
132 | static inline void wrfs16(u16 v, addr_t addr) | 132 | static inline void wrfs16(u16 v, addr_t addr) |
133 | { | 133 | { |
134 | asm volatile("movw %1,%%fs:%0" : "+m" (*(u16 *)addr) : "r" (v)); | 134 | asm volatile("movw %1,%%fs:%0" : "+m" (*(u16 *)addr) : "ri" (v)); |
135 | } | 135 | } |
136 | static inline void wrfs32(u32 v, addr_t addr) | 136 | static inline void wrfs32(u32 v, addr_t addr) |
137 | { | 137 | { |
138 | asm volatile("movl %1,%%fs:%0" : "+m" (*(u32 *)addr) : "r" (v)); | 138 | asm volatile("movl %1,%%fs:%0" : "+m" (*(u32 *)addr) : "ri" (v)); |
139 | } | 139 | } |
140 | 140 | ||
141 | static inline u8 rdgs8(addr_t addr) | 141 | static inline u8 rdgs8(addr_t addr) |
142 | { | 142 | { |
143 | u8 v; | 143 | u8 v; |
144 | asm volatile("movb %%gs:%1,%0" : "=r" (v) : "m" (*(u8 *)addr)); | 144 | asm volatile("movb %%gs:%1,%0" : "=q" (v) : "m" (*(u8 *)addr)); |
145 | return v; | 145 | return v; |
146 | } | 146 | } |
147 | static inline u16 rdgs16(addr_t addr) | 147 | static inline u16 rdgs16(addr_t addr) |
@@ -159,15 +159,15 @@ static inline u32 rdgs32(addr_t addr) | |||
159 | 159 | ||
160 | static inline void wrgs8(u8 v, addr_t addr) | 160 | static inline void wrgs8(u8 v, addr_t addr) |
161 | { | 161 | { |
162 | asm volatile("movb %1,%%gs:%0" : "+m" (*(u8 *)addr) : "r" (v)); | 162 | asm volatile("movb %1,%%gs:%0" : "+m" (*(u8 *)addr) : "qi" (v)); |
163 | } | 163 | } |
164 | static inline void wrgs16(u16 v, addr_t addr) | 164 | static inline void wrgs16(u16 v, addr_t addr) |
165 | { | 165 | { |
166 | asm volatile("movw %1,%%gs:%0" : "+m" (*(u16 *)addr) : "r" (v)); | 166 | asm volatile("movw %1,%%gs:%0" : "+m" (*(u16 *)addr) : "ri" (v)); |
167 | } | 167 | } |
168 | static inline void wrgs32(u32 v, addr_t addr) | 168 | static inline void wrgs32(u32 v, addr_t addr) |
169 | { | 169 | { |
170 | asm volatile("movl %1,%%gs:%0" : "+m" (*(u32 *)addr) : "r" (v)); | 170 | asm volatile("movl %1,%%gs:%0" : "+m" (*(u32 *)addr) : "ri" (v)); |
171 | } | 171 | } |
172 | 172 | ||
173 | /* Note: these only return true/false, not a signed return value! */ | 173 | /* Note: these only return true/false, not a signed return value! */ |