patch-2.4.19 linux-2.4.19/include/asm-s390/spinlock.h
Next file: linux-2.4.19/include/asm-s390/system.h
Previous file: linux-2.4.19/include/asm-s390/sigp.h
Back to the patch index
Back to the overall index
- Lines: 69
- Date:
Fri Aug 2 17:39:45 2002
- Orig file:
linux-2.4.18/include/asm-s390/spinlock.h
- Orig date:
Thu Oct 11 09:43:38 2001
diff -urN linux-2.4.18/include/asm-s390/spinlock.h linux-2.4.19/include/asm-s390/spinlock.h
@@ -29,22 +29,24 @@
extern inline void spin_lock(spinlock_t *lp)
{
- __asm__ __volatile(" bras 1,1f\n"
+ unsigned int reg1, reg2;
+ __asm__ __volatile(" bras %0,1f\n"
"0: diag 0,0,68\n"
- "1: slr 0,0\n"
- " cs 0,1,0(%0)\n"
+ "1: slr %1,%1\n"
+ " cs %1,%0,0(%2)\n"
" jl 0b\n"
- : : "a" (&lp->lock) : "0", "1", "cc", "memory" );
+ : "=&d" (reg1), "=&d" (reg2)
+ : "a" (&lp->lock) : "cc", "memory" );
}
extern inline int spin_trylock(spinlock_t *lp)
{
- unsigned long result;
+ unsigned long result, reg;
__asm__ __volatile(" slr %0,%0\n"
- " basr 1,0\n"
- "0: cs %0,1,0(%1)"
- : "=&d" (result)
- : "a" (&lp->lock) : "1", "cc", "memory" );
+ " basr %1,0\n"
+ "0: cs %0,%1,0(%2)"
+ : "=&d" (result), "=&d" (reg)
+ : "a" (&lp->lock) : "cc", "memory" );
return !result;
}
@@ -82,7 +84,7 @@
" la 3,1(2)\n" /* one more reader */ \
" cs 2,3,0(%0)\n" /* try to write new value */ \
" jl 0b" \
- : : "a" (&(rw)->lock) : "2", "3", "cc", "memory" );
+ : : "a" (&(rw)->lock) : "2", "3", "cc", "memory" )
#define read_unlock(rw) \
asm volatile(" l 2,0(%0)\n" \
@@ -92,7 +94,7 @@
" ahi 3,-1\n" /* one less reader */ \
" cs 2,3,0(%0)\n" \
" jl 0b" \
- : : "a" (&(rw)->lock) : "2", "3", "cc", "memory" );
+ : : "a" (&(rw)->lock) : "2", "3", "cc", "memory" )
#define write_lock(rw) \
asm volatile(" lhi 3,1\n" \
@@ -102,7 +104,7 @@
"1: slr 2,2\n" /* old lock value must be 0 */ \
" cs 2,3,0(%0)\n" \
" jl 0b" \
- : : "a" (&(rw)->lock) : "2", "3", "cc", "memory" );
+ : : "a" (&(rw)->lock) : "2", "3", "cc", "memory" )
#define write_unlock(rw) \
asm volatile(" slr 3,3\n" /* new lock value = 0 */ \
@@ -112,6 +114,6 @@
" sll 2,31\n" /* old lock value must be 0x80000000 */ \
" cs 2,3,0(%0)\n" \
" jl 0b" \
- : : "a" (&(rw)->lock) : "2", "3", "cc", "memory" );
+ : : "a" (&(rw)->lock) : "2", "3", "cc", "memory" )
#endif /* __ASM_SPINLOCK_H */
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)