Lines Matching refs:addr
36 * bit 0 is the LSB of addr; bit 32 is the LSB of (addr+1).
42 #define ADDR RLONG_ADDR(addr)
48 #define CONST_MASK_ADDR(nr, addr) WBYTE_ADDR((void *)(addr) + ((nr)>>3))
52 arch_set_bit(long nr, volatile unsigned long *addr)
56 : CONST_MASK_ADDR(nr, addr)
61 : : RLONG_ADDR(addr), "Ir" (nr) : "memory");
66 arch___set_bit(long nr, volatile unsigned long *addr)
72 arch_clear_bit(long nr, volatile unsigned long *addr)
76 : CONST_MASK_ADDR(nr, addr)
80 : : RLONG_ADDR(addr), "Ir" (nr) : "memory");
85 arch_clear_bit_unlock(long nr, volatile unsigned long *addr)
88 arch_clear_bit(nr, addr);
92 arch___clear_bit(long nr, volatile unsigned long *addr)
98 arch_clear_bit_unlock_is_negative_byte(long nr, volatile unsigned long *addr)
103 : CC_OUT(s) (negative), WBYTE_ADDR(addr)
111 arch___clear_bit_unlock(long nr, volatile unsigned long *addr)
113 arch___clear_bit(nr, addr);
117 arch___change_bit(long nr, volatile unsigned long *addr)
123 arch_change_bit(long nr, volatile unsigned long *addr)
127 : CONST_MASK_ADDR(nr, addr)
131 : : RLONG_ADDR(addr), "Ir" (nr) : "memory");
136 arch_test_and_set_bit(long nr, volatile unsigned long *addr)
138 return GEN_BINARY_RMWcc(LOCK_PREFIX __ASM_SIZE(bts), *addr, c, "Ir", nr);
142 arch_test_and_set_bit_lock(long nr, volatile unsigned long *addr)
144 return arch_test_and_set_bit(nr, addr);
148 arch___test_and_set_bit(long nr, volatile unsigned long *addr)
160 arch_test_and_clear_bit(long nr, volatile unsigned long *addr)
162 return GEN_BINARY_RMWcc(LOCK_PREFIX __ASM_SIZE(btr), *addr, c, "Ir", nr);
174 arch___test_and_clear_bit(long nr, volatile unsigned long *addr)
186 arch___test_and_change_bit(long nr, volatile unsigned long *addr)
199 arch_test_and_change_bit(long nr, volatile unsigned long *addr)
201 return GEN_BINARY_RMWcc(LOCK_PREFIX __ASM_SIZE(btc), *addr, c, "Ir", nr);
204 static __always_inline bool constant_test_bit(long nr, const volatile unsigned long *addr)
207 (addr[nr >> _BITOPS_LONG_SHIFT])) != 0;
210 static __always_inline bool variable_test_bit(long nr, volatile const unsigned long *addr)
217 : "m" (*(unsigned long *)addr), "Ir" (nr) : "memory");
222 #define arch_test_bit(nr, addr) \
224 ? constant_test_bit((nr), (addr)) \
225 : variable_test_bit((nr), (addr)))