summaryrefslogtreecommitdiff
path: root/arch/powerpc/atomic_arch.h
blob: f014e3b816f05b41eb0ce3b47ca186f6c828f5bd (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#define a_cas a_cas
static inline int a_cas(volatile int *p, int t, int s)
{
	__asm__("\n"
		"	sync\n"
		"1:	lwarx %0, 0, %4\n"
		"	cmpw %0, %2\n"
		"	bne 1f\n"
		"	stwcx. %3, 0, %4\n"
		"	bne- 1b\n"
		"	isync\n"
		"1:	\n"
		: "=&r"(t), "+m"(*p) : "r"(t), "r"(s), "r"(p) : "cc", "memory" );
        return t;
}