It was resulting in build errors for some configurations.
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
#define _ASM_ATOMIC_H
#include <asm/cpu-features.h>
#define _ASM_ATOMIC_H
#include <asm/cpu-features.h>
+#include <asm/interrupt.h>
-extern spinlock_t atomic_lock;
-
typedef struct { volatile int counter; } atomic_t;
#define ATOMIC_INIT(i) { (i) }
typedef struct { volatile int counter; } atomic_t;
#define ATOMIC_INIT(i) { (i) }
} else {
unsigned long flags;
} else {
unsigned long flags;
- spin_lock_irqsave(&atomic_lock, flags);
- spin_unlock_irqrestore(&atomic_lock, flags);
+ local_irq_restore(flags);
} else {
unsigned long flags;
} else {
unsigned long flags;
- spin_lock_irqsave(&atomic_lock, flags);
- spin_unlock_irqrestore(&atomic_lock, flags);
+ local_irq_restore(flags);
} else {
unsigned long flags;
} else {
unsigned long flags;
- spin_lock_irqsave(&atomic_lock, flags);
result = v->counter;
result += i;
v->counter = result;
result = v->counter;
result += i;
v->counter = result;
- spin_unlock_irqrestore(&atomic_lock, flags);
+ local_irq_restore(flags);
} else {
unsigned long flags;
} else {
unsigned long flags;
- spin_lock_irqsave(&atomic_lock, flags);
result = v->counter;
result -= i;
v->counter = result;
result = v->counter;
result -= i;
v->counter = result;
- spin_unlock_irqrestore(&atomic_lock, flags);
+ local_irq_restore(flags);
} else {
unsigned long flags;
} else {
unsigned long flags;
- spin_lock_irqsave(&atomic_lock, flags);
result = v->counter;
result -= i;
if (result >= 0)
v->counter = result;
result = v->counter;
result -= i;
if (result >= 0)
v->counter = result;
- spin_unlock_irqrestore(&atomic_lock, flags);
+ local_irq_restore(flags);
} else {
unsigned long flags;
} else {
unsigned long flags;
- spin_lock_irqsave(&atomic_lock, flags);
- spin_unlock_irqrestore(&atomic_lock, flags);
+ local_irq_restore(flags);
} else {
unsigned long flags;
} else {
unsigned long flags;
- spin_lock_irqsave(&atomic_lock, flags);
- spin_unlock_irqrestore(&atomic_lock, flags);
+ local_irq_restore(flags);
} else {
unsigned long flags;
} else {
unsigned long flags;
- spin_lock_irqsave(&atomic_lock, flags);
result = v->counter;
result += i;
v->counter = result;
result = v->counter;
result += i;
v->counter = result;
- spin_unlock_irqrestore(&atomic_lock, flags);
+ local_irq_restore(flags);
} else {
unsigned long flags;
} else {
unsigned long flags;
- spin_lock_irqsave(&atomic_lock, flags);
result = v->counter;
result -= i;
v->counter = result;
result = v->counter;
result -= i;
v->counter = result;
- spin_unlock_irqrestore(&atomic_lock, flags);
+ local_irq_restore(flags);
} else {
unsigned long flags;
} else {
unsigned long flags;
- spin_lock_irqsave(&atomic_lock, flags);
result = v->counter;
result -= i;
if (result >= 0)
v->counter = result;
result = v->counter;
result -= i;
if (result >= 0)
v->counter = result;
- spin_unlock_irqrestore(&atomic_lock, flags);
+ local_irq_restore(flags);