| /* Slow paths of read/write spinlocks. */ | 
 |  | 
 | #include <linux/linkage.h> | 
 | #include <asm/alternative-asm.h> | 
 | #include <asm/frame.h> | 
 | #include <asm/rwlock.h> | 
 |  | 
 | #ifdef CONFIG_X86_32 | 
 | # define __lock_ptr eax | 
 | #else | 
 | # define __lock_ptr rdi | 
 | #endif | 
 |  | 
 | ENTRY(__write_lock_failed) | 
 | 	CFI_STARTPROC | 
 | 	FRAME | 
 | 0:	LOCK_PREFIX | 
 | 	WRITE_LOCK_ADD($RW_LOCK_BIAS) (%__lock_ptr) | 
 | 1:	rep; nop | 
 | 	cmpl	$WRITE_LOCK_CMP, (%__lock_ptr) | 
 | 	jne	1b | 
 | 	LOCK_PREFIX | 
 | 	WRITE_LOCK_SUB($RW_LOCK_BIAS) (%__lock_ptr) | 
 | 	jnz	0b | 
 | 	ENDFRAME | 
 | 	ret | 
 | 	CFI_ENDPROC | 
 | END(__write_lock_failed) | 
 |  | 
 | ENTRY(__read_lock_failed) | 
 | 	CFI_STARTPROC | 
 | 	FRAME | 
 | 0:	LOCK_PREFIX | 
 | 	READ_LOCK_SIZE(inc) (%__lock_ptr) | 
 | 1:	rep; nop | 
 | 	READ_LOCK_SIZE(cmp) $1, (%__lock_ptr) | 
 | 	js	1b | 
 | 	LOCK_PREFIX | 
 | 	READ_LOCK_SIZE(dec) (%__lock_ptr) | 
 | 	js	0b | 
 | 	ENDFRAME | 
 | 	ret | 
 | 	CFI_ENDPROC | 
 | END(__read_lock_failed) |