mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 00b73d8d1b
			
		
	
	
		00b73d8d1b
		
	
	
	
	
		
			
			The version of futex.h in asm-generic should really be adapted to do the same thing so that this hideous code does not have to be duplicated per-arch. Signed-off-by: Rich Felker <dalias@libc.org>
		
			
				
	
	
		
			35 lines
		
	
	
		
			689 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
		
			689 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __ASM_SH_FUTEX_CAS_H
 | |
| #define __ASM_SH_FUTEX_CAS_H
 | |
| 
 | |
| static inline int atomic_futex_op_cmpxchg_inatomic(u32 *uval,
 | |
| 						   u32 __user *uaddr,
 | |
| 						   u32 oldval, u32 newval)
 | |
| {
 | |
| 	int err = 0;
 | |
| 	__asm__ __volatile__(
 | |
| 		"1:\n\t"
 | |
| 		"cas.l	%2, %1, @r0\n"
 | |
| 		"2:\n\t"
 | |
| #ifdef CONFIG_MMU
 | |
| 		".section	.fixup,\"ax\"\n"
 | |
| 		"3:\n\t"
 | |
| 		"mov.l	4f, %0\n\t"
 | |
| 		"jmp	@%0\n\t"
 | |
| 		" mov	%3, %0\n\t"
 | |
| 		".balign	4\n"
 | |
| 		"4:	.long	2b\n\t"
 | |
| 		".previous\n"
 | |
| 		".section	__ex_table,\"a\"\n\t"
 | |
| 		".long	1b, 3b\n\t"
 | |
| 		".previous"
 | |
| #endif
 | |
| 		:"+r" (err), "+r" (newval)
 | |
| 		:"r" (oldval), "i" (-EFAULT), "z" (uaddr)
 | |
| 		:"t", "memory");
 | |
| 	if (err) return err;
 | |
| 	*uval = newval;
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| #endif /* __ASM_SH_FUTEX_CAS_H */
 |