5 * 'Big Reader' read-write spinlocks. See linux/brlock.h for details.
7 * Copyright 2000, Ingo Molnar <mingo@redhat.com>
8 * Copyright 2000, David S. Miller <davem@redhat.com>
11 #include <linux/config.h>
15 #include <linux/sched.h>
16 #include <linux/brlock.h>
17 #include <linux/delay.h>
19 #ifdef __BRLOCK_USE_ATOMICS
21 brlock_read_lock_t __brlock_array[NR_CPUS][__BR_IDX_MAX] =
22 { [0 ... NR_CPUS-1] = { [0 ... __BR_IDX_MAX-1] = RW_LOCK_UNLOCKED } };
24 void __br_write_lock (enum brlock_indices idx)
28 for (i = 0; i < smp_num_cpus; i++)
29 write_lock(&__brlock_array[cpu_logical_map(i)][idx]);
32 void __br_write_unlock (enum brlock_indices idx)
36 for (i = 0; i < smp_num_cpus; i++)
37 write_unlock(&__brlock_array[cpu_logical_map(i)][idx]);
40 #else /* ! __BRLOCK_USE_ATOMICS */
42 brlock_read_lock_t __brlock_array[NR_CPUS][__BR_IDX_MAX] =
43 { [0 ... NR_CPUS-1] = { [0 ... __BR_IDX_MAX-1] = 0 } };
45 struct br_wrlock __br_write_locks[__BR_IDX_MAX] =
46 { [0 ... __BR_IDX_MAX-1] = { SPIN_LOCK_UNLOCKED } };
48 void __br_write_lock (enum brlock_indices idx)
53 spin_lock(&__br_write_locks[idx].lock);
54 for (i = 0; i < smp_num_cpus; i++)
55 if (__brlock_array[cpu_logical_map(i)][idx] != 0) {
56 spin_unlock(&__br_write_locks[idx].lock);
63 void __br_write_unlock (enum brlock_indices idx)
65 spin_unlock(&__br_write_locks[idx].lock);
68 #endif /* __BRLOCK_USE_ATOMICS */
70 #endif /* CONFIG_SMP */