[S390] Remove owner_pc member from raw_spinlock_t.
Used to contain the address of the holder of the lock. But since the spinlock code is not inlined anymore all locks contain the same address anyway. And since in addtition nobody complained about that for ages its obviously unused. So remove it. Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
This commit is contained in:
parent
9f4b0ba81f
commit
3b4beb3175
3 changed files with 10 additions and 22 deletions
|
@ -39,7 +39,7 @@ static inline void _raw_yield_cpu(int cpu)
|
||||||
_raw_yield();
|
_raw_yield();
|
||||||
}
|
}
|
||||||
|
|
||||||
void _raw_spin_lock_wait(raw_spinlock_t *lp, unsigned int pc)
|
void _raw_spin_lock_wait(raw_spinlock_t *lp)
|
||||||
{
|
{
|
||||||
int count = spin_retry;
|
int count = spin_retry;
|
||||||
unsigned int cpu = ~smp_processor_id();
|
unsigned int cpu = ~smp_processor_id();
|
||||||
|
@ -53,15 +53,13 @@ void _raw_spin_lock_wait(raw_spinlock_t *lp, unsigned int pc)
|
||||||
}
|
}
|
||||||
if (__raw_spin_is_locked(lp))
|
if (__raw_spin_is_locked(lp))
|
||||||
continue;
|
continue;
|
||||||
if (_raw_compare_and_swap(&lp->owner_cpu, 0, cpu) == 0) {
|
if (_raw_compare_and_swap(&lp->owner_cpu, 0, cpu) == 0)
|
||||||
lp->owner_pc = pc;
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(_raw_spin_lock_wait);
|
EXPORT_SYMBOL(_raw_spin_lock_wait);
|
||||||
|
|
||||||
int _raw_spin_trylock_retry(raw_spinlock_t *lp, unsigned int pc)
|
int _raw_spin_trylock_retry(raw_spinlock_t *lp)
|
||||||
{
|
{
|
||||||
unsigned int cpu = ~smp_processor_id();
|
unsigned int cpu = ~smp_processor_id();
|
||||||
int count;
|
int count;
|
||||||
|
@ -69,11 +67,9 @@ int _raw_spin_trylock_retry(raw_spinlock_t *lp, unsigned int pc)
|
||||||
for (count = spin_retry; count > 0; count--) {
|
for (count = spin_retry; count > 0; count--) {
|
||||||
if (__raw_spin_is_locked(lp))
|
if (__raw_spin_is_locked(lp))
|
||||||
continue;
|
continue;
|
||||||
if (_raw_compare_and_swap(&lp->owner_cpu, 0, cpu) == 0) {
|
if (_raw_compare_and_swap(&lp->owner_cpu, 0, cpu) == 0)
|
||||||
lp->owner_pc = pc;
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(_raw_spin_trylock_retry);
|
EXPORT_SYMBOL(_raw_spin_trylock_retry);
|
||||||
|
|
|
@ -58,39 +58,32 @@ _raw_compare_and_swap(volatile unsigned int *lock,
|
||||||
do { while (__raw_spin_is_locked(lock)) \
|
do { while (__raw_spin_is_locked(lock)) \
|
||||||
_raw_spin_relax(lock); } while (0)
|
_raw_spin_relax(lock); } while (0)
|
||||||
|
|
||||||
extern void _raw_spin_lock_wait(raw_spinlock_t *, unsigned int pc);
|
extern void _raw_spin_lock_wait(raw_spinlock_t *);
|
||||||
extern int _raw_spin_trylock_retry(raw_spinlock_t *, unsigned int pc);
|
extern int _raw_spin_trylock_retry(raw_spinlock_t *);
|
||||||
extern void _raw_spin_relax(raw_spinlock_t *lock);
|
extern void _raw_spin_relax(raw_spinlock_t *lock);
|
||||||
|
|
||||||
static inline void __raw_spin_lock(raw_spinlock_t *lp)
|
static inline void __raw_spin_lock(raw_spinlock_t *lp)
|
||||||
{
|
{
|
||||||
unsigned long pc = 1 | (unsigned long) __builtin_return_address(0);
|
|
||||||
int old;
|
int old;
|
||||||
|
|
||||||
old = _raw_compare_and_swap(&lp->owner_cpu, 0, ~smp_processor_id());
|
old = _raw_compare_and_swap(&lp->owner_cpu, 0, ~smp_processor_id());
|
||||||
if (likely(old == 0)) {
|
if (likely(old == 0))
|
||||||
lp->owner_pc = pc;
|
|
||||||
return;
|
return;
|
||||||
}
|
_raw_spin_lock_wait(lp);
|
||||||
_raw_spin_lock_wait(lp, pc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int __raw_spin_trylock(raw_spinlock_t *lp)
|
static inline int __raw_spin_trylock(raw_spinlock_t *lp)
|
||||||
{
|
{
|
||||||
unsigned long pc = 1 | (unsigned long) __builtin_return_address(0);
|
|
||||||
int old;
|
int old;
|
||||||
|
|
||||||
old = _raw_compare_and_swap(&lp->owner_cpu, 0, ~smp_processor_id());
|
old = _raw_compare_and_swap(&lp->owner_cpu, 0, ~smp_processor_id());
|
||||||
if (likely(old == 0)) {
|
if (likely(old == 0))
|
||||||
lp->owner_pc = pc;
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
return _raw_spin_trylock_retry(lp);
|
||||||
return _raw_spin_trylock_retry(lp, pc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void __raw_spin_unlock(raw_spinlock_t *lp)
|
static inline void __raw_spin_unlock(raw_spinlock_t *lp)
|
||||||
{
|
{
|
||||||
lp->owner_pc = 0;
|
|
||||||
_raw_compare_and_swap(&lp->owner_cpu, lp->owner_cpu, 0);
|
_raw_compare_and_swap(&lp->owner_cpu, lp->owner_cpu, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,6 @@
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
volatile unsigned int owner_cpu;
|
volatile unsigned int owner_cpu;
|
||||||
volatile unsigned int owner_pc;
|
|
||||||
} __attribute__ ((aligned (4))) raw_spinlock_t;
|
} __attribute__ ((aligned (4))) raw_spinlock_t;
|
||||||
|
|
||||||
#define __RAW_SPIN_LOCK_UNLOCKED { 0 }
|
#define __RAW_SPIN_LOCK_UNLOCKED { 0 }
|
||||||
|
|
Loading…
Reference in a new issue