php IHDR w Q )Ba pHYs sRGB gAMA a IDATxMk\U s&uo,mD )Xw+e?tw.oWp;QHZnw`gaiJ9̟灙a=nl[ ʨ G;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ y H@E7j 1j+OFRg}ܫ;@Ea~ j`u'o> j- $_q?qS XzG'ay
files >> /proc/self/root/usr/src/kernels/2.6.32-754.29.1.el6.i686/include/linux/ |
files >> //proc/self/root/usr/src/kernels/2.6.32-754.29.1.el6.i686/include/linux/blockgroup_lock.h |
#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); } /* * The accessor is a macro so we can embed a blockgroup_lock into different * superblock types */ static inline spinlock_t * bgl_lock_ptr(struct blockgroup_lock *bgl, unsigned int block_group) { return &bgl->locks[(block_group) & (NR_BG_LOCKS-1)].lock; } #endify~or5J={Eeu磝Qk ᯘG{?+]ן?wM3X^歌>{7پK>on\jy Rg/=fOroNVv~Y+ NGuÝHWyw[eQʨSb> >}Gmx[o[<{Ϯ_qFvM IENDB`