diff options
Diffstat (limited to 'arch/s390/include/asm/percpu.h')
| -rw-r--r-- | arch/s390/include/asm/percpu.h | 50 | 
1 files changed, 47 insertions, 3 deletions
diff --git a/arch/s390/include/asm/percpu.h b/arch/s390/include/asm/percpu.h index 6537e72e085..86fe0ee2cee 100644 --- a/arch/s390/include/asm/percpu.h +++ b/arch/s390/include/asm/percpu.h @@ -20,7 +20,7 @@  #endif  #define arch_this_cpu_to_op(pcp, val, op)				\ -do {									\ +({									\  	typedef typeof(pcp) pcp_op_T__;					\  	pcp_op_T__ old__, new__, prev__;				\  	pcp_op_T__ *ptr__;						\ @@ -39,13 +39,19 @@ do {									\  		}							\  	} while (prev__ != old__);					\  	preempt_enable();						\ -} while (0) +	new__;								\ +})  #define this_cpu_add_1(pcp, val) arch_this_cpu_to_op(pcp, val, +)  #define this_cpu_add_2(pcp, val) arch_this_cpu_to_op(pcp, val, +)  #define this_cpu_add_4(pcp, val) arch_this_cpu_to_op(pcp, val, +)  #define this_cpu_add_8(pcp, val) arch_this_cpu_to_op(pcp, val, +) +#define this_cpu_add_return_1(pcp, val) arch_this_cpu_to_op(pcp, val, +) +#define this_cpu_add_return_2(pcp, val) arch_this_cpu_to_op(pcp, val, +) +#define this_cpu_add_return_4(pcp, val) arch_this_cpu_to_op(pcp, val, +) +#define this_cpu_add_return_8(pcp, val) arch_this_cpu_to_op(pcp, val, +) +  #define this_cpu_and_1(pcp, val) arch_this_cpu_to_op(pcp, val, &)  #define this_cpu_and_2(pcp, val) arch_this_cpu_to_op(pcp, val, &)  #define this_cpu_and_4(pcp, val) arch_this_cpu_to_op(pcp, val, &) @@ -61,7 +67,7 @@ do {									\  #define this_cpu_xor_4(pcp, val) arch_this_cpu_to_op(pcp, val, ^)  #define this_cpu_xor_8(pcp, val) arch_this_cpu_to_op(pcp, val, ^) -#define arch_this_cpu_cmpxchg(pcp, oval, nval)			\ +#define arch_this_cpu_cmpxchg(pcp, oval, nval)				\  ({									\  	typedef typeof(pcp) pcp_op_T__;					\  	pcp_op_T__ ret__;						\ @@ -84,6 +90,44 @@ do {									\  #define this_cpu_cmpxchg_4(pcp, oval, nval) arch_this_cpu_cmpxchg(pcp, oval, nval)  #define this_cpu_cmpxchg_8(pcp, oval, nval) arch_this_cpu_cmpxchg(pcp, oval, nval) +#define arch_this_cpu_xchg(pcp, nval)					\ +({									\ +	typeof(pcp) *ptr__;						\ +	typeof(pcp) ret__;						\ +	preempt_disable();						\ +	ptr__ = __this_cpu_ptr(&(pcp));					\ +	ret__ = xchg(ptr__, nval);					\ +	preempt_enable();						\ +	ret__;								\ +}) + +#define this_cpu_xchg_1(pcp, nval) arch_this_cpu_xchg(pcp, nval) +#define this_cpu_xchg_2(pcp, nval) arch_this_cpu_xchg(pcp, nval) +#define this_cpu_xchg_4(pcp, nval) arch_this_cpu_xchg(pcp, nval) +#ifdef CONFIG_64BIT +#define this_cpu_xchg_8(pcp, nval) arch_this_cpu_xchg(pcp, nval) +#endif + +#define arch_this_cpu_cmpxchg_double(pcp1, pcp2, o1, o2, n1, n2)	\ +({									\ +	typeof(pcp1) o1__ = (o1), n1__ = (n1);				\ +	typeof(pcp2) o2__ = (o2), n2__ = (n2);				\ +	typeof(pcp1) *p1__;						\ +	typeof(pcp2) *p2__;						\ +	int ret__;							\ +	preempt_disable();						\ +	p1__ = __this_cpu_ptr(&(pcp1));					\ +	p2__ = __this_cpu_ptr(&(pcp2));					\ +	ret__ = __cmpxchg_double(p1__, p2__, o1__, o2__, n1__, n2__);	\ +	preempt_enable();						\ +	ret__;								\ +}) + +#define this_cpu_cmpxchg_double_4 arch_this_cpu_cmpxchg_double +#ifdef CONFIG_64BIT +#define this_cpu_cmpxchg_double_8 arch_this_cpu_cmpxchg_double +#endif +  #include <asm-generic/percpu.h>  #endif /* __ARCH_S390_PERCPU__ */  |