2010-09-15 16:09:52 +02:00
|
|
|
#ifndef __SPINLOCK_H__
|
|
|
|
#define __SPINLOCK_H__
|
|
|
|
|
|
|
|
#include "kernel.h"
|
|
|
|
|
|
|
|
typedef struct spinlock {
|
|
|
|
atomic_t val;
|
|
|
|
} spinlock_t;
|
|
|
|
|
|
|
|
#ifndef CONFIG_SMP
|
|
|
|
|
|
|
|
#define SPINLOCK_DEFINE(name)
|
|
|
|
#define PRIVATE_SPINLOCK_DEFINE(name)
|
|
|
|
#define SPINLOCK_DECLARE(name)
|
|
|
|
#define spinlock_init(sl)
|
|
|
|
#define spinlock_lock(sl)
|
|
|
|
#define spinlock_unlock(sl)
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
/* SMP */
|
|
|
|
#define SPINLOCK_DEFINE(name) spinlock_t name;
|
|
|
|
#define PRIVATE_SPINLOCK_DEFINE(name) PRIVATE SPINLOCK_DEFINE(name)
|
|
|
|
#define SPINLOCK_DECLARE(name) extern SPINLOCK_DEFINE(name)
|
|
|
|
#define spinlock_init(sl) do { (sl)->val = 0; } while (0)
|
2010-09-15 16:10:03 +02:00
|
|
|
|
2010-09-15 16:09:52 +02:00
|
|
|
#if CONFIG_MAX_CPUS == 1
|
|
|
|
#define spinlock_lock(sl)
|
|
|
|
#define spinlock_unlock(sl)
|
|
|
|
#else
|
2011-12-15 10:56:08 +01:00
|
|
|
void arch_spinlock_lock(atomic_t * sl);
|
|
|
|
void arch_spinlock_unlock(atomic_t * sl);
|
2010-09-15 16:09:52 +02:00
|
|
|
#define spinlock_lock(sl) arch_spinlock_lock((atomic_t*) sl)
|
|
|
|
#define spinlock_unlock(sl) arch_spinlock_unlock((atomic_t*) sl)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2010-09-15 16:10:03 +02:00
|
|
|
#endif /* CONFIG_SMP */
|
|
|
|
|
|
|
|
#define BKL_LOCK() spinlock_lock(&big_kernel_lock)
|
|
|
|
#define BKL_UNLOCK() spinlock_unlock(&big_kernel_lock)
|
2010-09-15 16:09:52 +02:00
|
|
|
|
|
|
|
#endif /* __SPINLOCK_H__ */
|