diff options
Diffstat (limited to 'arch/x86/include/asm/bitops.h')
| -rw-r--r-- | arch/x86/include/asm/bitops.h | 29 | 
1 files changed, 16 insertions, 13 deletions
| diff --git a/arch/x86/include/asm/bitops.h b/arch/x86/include/asm/bitops.h index 3fa039855b8f..9f645ba57dbb 100644 --- a/arch/x86/include/asm/bitops.h +++ b/arch/x86/include/asm/bitops.h @@ -78,7 +78,7 @@ set_bit(long nr, volatile unsigned long *addr)  			: "iq" ((u8)CONST_MASK(nr))  			: "memory");  	} else { -		asm volatile(LOCK_PREFIX "bts %1,%0" +		asm volatile(LOCK_PREFIX __ASM_SIZE(bts) " %1,%0"  			: BITOP_ADDR(addr) : "Ir" (nr) : "memory");  	}  } @@ -94,7 +94,7 @@ set_bit(long nr, volatile unsigned long *addr)   */  static __always_inline void __set_bit(long nr, volatile unsigned long *addr)  { -	asm volatile("bts %1,%0" : ADDR : "Ir" (nr) : "memory"); +	asm volatile(__ASM_SIZE(bts) " %1,%0" : ADDR : "Ir" (nr) : "memory");  }  /** @@ -115,7 +115,7 @@ clear_bit(long nr, volatile unsigned long *addr)  			: CONST_MASK_ADDR(nr, addr)  			: "iq" ((u8)~CONST_MASK(nr)));  	} else { -		asm volatile(LOCK_PREFIX "btr %1,%0" +		asm volatile(LOCK_PREFIX __ASM_SIZE(btr) " %1,%0"  			: BITOP_ADDR(addr)  			: "Ir" (nr));  	} @@ -137,7 +137,7 @@ static __always_inline void clear_bit_unlock(long nr, volatile unsigned long *ad  static __always_inline void __clear_bit(long nr, volatile unsigned long *addr)  { -	asm volatile("btr %1,%0" : ADDR : "Ir" (nr)); +	asm volatile(__ASM_SIZE(btr) " %1,%0" : ADDR : "Ir" (nr));  }  static __always_inline bool clear_bit_unlock_is_negative_byte(long nr, volatile unsigned long *addr) @@ -182,7 +182,7 @@ static __always_inline void __clear_bit_unlock(long nr, volatile unsigned long *   */  static __always_inline void __change_bit(long nr, volatile unsigned long *addr)  { -	asm volatile("btc %1,%0" : ADDR : "Ir" (nr)); +	asm volatile(__ASM_SIZE(btc) " %1,%0" : ADDR : "Ir" (nr));  }  /** @@ -201,7 +201,7 @@ static __always_inline void change_bit(long nr, volatile unsigned long *addr)  			: CONST_MASK_ADDR(nr, addr)  			: "iq" ((u8)CONST_MASK(nr)));  	} else { -		asm volatile(LOCK_PREFIX "btc %1,%0" +		asm volatile(LOCK_PREFIX __ASM_SIZE(btc) " %1,%0"  			: BITOP_ADDR(addr)  			: "Ir" (nr));  	} @@ -217,7 +217,8 @@ static __always_inline void change_bit(long nr, volatile unsigned long *addr)   */  static __always_inline bool test_and_set_bit(long nr, volatile unsigned long *addr)  { -	GEN_BINARY_RMWcc(LOCK_PREFIX "bts", *addr, "Ir", nr, "%0", c); +	GEN_BINARY_RMWcc(LOCK_PREFIX __ASM_SIZE(bts), +	                 *addr, "Ir", nr, "%0", c);  }  /** @@ -246,7 +247,7 @@ static __always_inline bool __test_and_set_bit(long nr, volatile unsigned long *  {  	bool oldbit; -	asm("bts %2,%1" +	asm(__ASM_SIZE(bts) " %2,%1"  	    CC_SET(c)  	    : CC_OUT(c) (oldbit), ADDR  	    : "Ir" (nr)); @@ -263,7 +264,8 @@ static __always_inline bool __test_and_set_bit(long nr, volatile unsigned long *   */  static __always_inline bool test_and_clear_bit(long nr, volatile unsigned long *addr)  { -	GEN_BINARY_RMWcc(LOCK_PREFIX "btr", *addr, "Ir", nr, "%0", c); +	GEN_BINARY_RMWcc(LOCK_PREFIX __ASM_SIZE(btr), +	                 *addr, "Ir", nr, "%0", c);  }  /** @@ -286,7 +288,7 @@ static __always_inline bool __test_and_clear_bit(long nr, volatile unsigned long  {  	bool oldbit; -	asm volatile("btr %2,%1" +	asm volatile(__ASM_SIZE(btr) " %2,%1"  		     CC_SET(c)  		     : CC_OUT(c) (oldbit), ADDR  		     : "Ir" (nr)); @@ -298,7 +300,7 @@ static __always_inline bool __test_and_change_bit(long nr, volatile unsigned lon  {  	bool oldbit; -	asm volatile("btc %2,%1" +	asm volatile(__ASM_SIZE(btc) " %2,%1"  		     CC_SET(c)  		     : CC_OUT(c) (oldbit), ADDR  		     : "Ir" (nr) : "memory"); @@ -316,7 +318,8 @@ static __always_inline bool __test_and_change_bit(long nr, volatile unsigned lon   */  static __always_inline bool test_and_change_bit(long nr, volatile unsigned long *addr)  { -	GEN_BINARY_RMWcc(LOCK_PREFIX "btc", *addr, "Ir", nr, "%0", c); +	GEN_BINARY_RMWcc(LOCK_PREFIX __ASM_SIZE(btc), +	                 *addr, "Ir", nr, "%0", c);  }  static __always_inline bool constant_test_bit(long nr, const volatile unsigned long *addr) @@ -329,7 +332,7 @@ static __always_inline bool variable_test_bit(long nr, volatile const unsigned l  {  	bool oldbit; -	asm volatile("bt %2,%1" +	asm volatile(__ASM_SIZE(bt) " %2,%1"  		     CC_SET(c)  		     : CC_OUT(c) (oldbit)  		     : "m" (*(unsigned long *)addr), "Ir" (nr)); | 
