Commit 2989ea10 authored by David S. Miller's avatar David S. Miller

[SPARC64]: Implement _raw_spin_lock_flags().

parent 1d16702f
...@@ -133,6 +133,8 @@ EXPORT_SYMBOL(__read_unlock); ...@@ -133,6 +133,8 @@ EXPORT_SYMBOL(__read_unlock);
EXPORT_SYMBOL(__write_lock); EXPORT_SYMBOL(__write_lock);
EXPORT_SYMBOL(__write_unlock); EXPORT_SYMBOL(__write_unlock);
EXPORT_SYMBOL(__write_trylock); EXPORT_SYMBOL(__write_trylock);
/* Out of line spin-locking implementation. */
EXPORT_SYMBOL(_raw_spin_lock_flags);
#endif #endif
/* Hard IRQ locking */ /* Hard IRQ locking */
......
...@@ -10,7 +10,7 @@ lib-y := PeeCeeI.o blockops.o strlen.o strncmp.o \ ...@@ -10,7 +10,7 @@ lib-y := PeeCeeI.o blockops.o strlen.o strncmp.o \
VIScopy.o VISbzero.o VISmemset.o VIScsum.o VIScsumcopy.o \ VIScopy.o VISbzero.o VISmemset.o VIScsum.o VIScsumcopy.o \
VIScsumcopyusr.o VISsave.o atomic.o rwlock.o bitops.o \ VIScsumcopyusr.o VISsave.o atomic.o rwlock.o bitops.o \
U3memcpy.o U3copy_from_user.o U3copy_to_user.o \ U3memcpy.o U3copy_from_user.o U3copy_to_user.o \
U3copy_in_user.o mcount.o ipcsum.o rwsem.o xor.o U3copy_in_user.o mcount.o ipcsum.o rwsem.o xor.o splock.o
lib-$(CONFIG_DEBUG_SPINLOCK) += debuglocks.o lib-$(CONFIG_DEBUG_SPINLOCK) += debuglocks.o
lib-$(CONFIG_HAVE_DEC_LOCK) += dec_and_lock.o lib-$(CONFIG_HAVE_DEC_LOCK) += dec_and_lock.o
/* splock.S: Spinlock primitives too large to inline.
*
* Copyright (C) 2004 David S. Miller (davem@redhat.com)
*/
.text
.align 64
.globl _raw_spin_lock_flags
_raw_spin_lock_flags: /* %o0 = lock_ptr, %o1 = irq_flags */
1: ldstub [%o0], %g7
brnz,pn %g7, 2f
membar #StoreLoad | #StoreStore
retl
nop
2: rdpr %pil, %g2 ! Save PIL
wrpr %o1, %pil ! Set previous PIL
3: ldub [%o0], %g7 ! Spin on lock set
brnz,pt %g7, 3b
membar #LoadLoad
ba,pt %xcc, 1b ! Retry lock acquire
wrpr %g2, %pil ! Restore PIL
...@@ -78,6 +78,8 @@ static __inline__ void _raw_spin_unlock(spinlock_t *lock) ...@@ -78,6 +78,8 @@ static __inline__ void _raw_spin_unlock(spinlock_t *lock)
: "memory"); : "memory");
} }
extern void _raw_spin_lock_flags(spinlock_t *lock, unsigned long flags);
#else /* !(CONFIG_DEBUG_SPINLOCK) */ #else /* !(CONFIG_DEBUG_SPINLOCK) */
typedef struct { typedef struct {
...@@ -103,11 +105,10 @@ extern int _spin_trylock (spinlock_t *lock); ...@@ -103,11 +105,10 @@ extern int _spin_trylock (spinlock_t *lock);
#define _raw_spin_trylock(lp) _spin_trylock(lp) #define _raw_spin_trylock(lp) _spin_trylock(lp)
#define _raw_spin_lock(lock) _do_spin_lock(lock, "spin_lock") #define _raw_spin_lock(lock) _do_spin_lock(lock, "spin_lock")
#define _raw_spin_unlock(lock) _do_spin_unlock(lock) #define _raw_spin_unlock(lock) _do_spin_unlock(lock)
#define _raw_spin_lock_flags(lock, flags) _raw_spin_lock(lock)
#endif /* CONFIG_DEBUG_SPINLOCK */ #endif /* CONFIG_DEBUG_SPINLOCK */
#define _raw_spin_lock_flags(lock, flags) _raw_spin_lock(lock)
/* Multi-reader locks, these are much saner than the 32-bit Sparc ones... */ /* Multi-reader locks, these are much saner than the 32-bit Sparc ones... */
#ifndef CONFIG_DEBUG_SPINLOCK #ifndef CONFIG_DEBUG_SPINLOCK
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment