#ifndef _LINUX_BLOCKGROUP_LOCK_H #define _LINUX_BLOCKGROUP_LOCK_H /* * Per-blockgroup locking for ext2 and ext3. * * Simple hashed spinlocking. */ #include <linux/spinlock.h> #include <linux/cache.h> #ifdef CONFIG_SMP /* * We want a power-of-two. Is there a better way than this? */ #if NR_CPUS >= 32 #define NR_BG_LOCKS 128 #elif NR_CPUS >= 16 #define NR_BG_LOCKS 64 #elif NR_CPUS >= 8 #define NR_BG_LOCKS 32 #elif NR_CPUS >= 4 #define NR_BG_LOCKS 16 #elif NR_CPUS >= 2 #define NR_BG_LOCKS 8 #else #define NR_BG_LOCKS 4 #endif #else /* CONFIG_SMP */ #define NR_BG_LOCKS 1 #endif /* CONFIG_SMP */ struct bgl_lock { spinlock_t lock; } ____cacheline_aligned_in_smp; struct blockgroup_lock { struct bgl_lock locks[NR_BG_LOCKS]; };
static inline void bgl_lock_init(struct blockgroup_lock *bgl) { int i; for (i = 0; i < NR_BG_LOCKS; i++) spin_lock_init(&bgl->locks[i].lock); }Contributors
Person | Tokens | Prop | Commits | CommitProp | |
andrew morton | andrew morton | 41 | 100.00% | 1 | 100.00% |
Total | 41 | 100.00% | 1 | 100.00% |
Person | Tokens | Prop | Commits | CommitProp | |
pekka j enberg | pekka j enberg | 32 | 88.89% | 1 | 50.00% |
andrew morton | andrew morton | 4 | 11.11% | 1 | 50.00% |
Total | 36 | 100.00% | 2 | 100.00% |
Person | Tokens | Prop | Commits | CommitProp | |
andrew morton | andrew morton | 141 | 77.90% | 1 | 33.33% |
pekka j enberg | pekka j enberg | 32 | 17.68% | 1 | 33.33% |
adrian bunk | adrian bunk | 8 | 4.42% | 1 | 33.33% |
Total | 181 | 100.00% | 3 | 100.00% |