提交 703e1f0f 编写于 作者: E Eric Sandeen 提交者: Lachlan McIlroy

[XFS] Unwrap xfs_dabuf_global_lock

Un-obfuscate dabuf_global_lock, remove mutex_lock->spin_lock macros, call
spin_lock directly, remove extraneous cookie holdover from old xfs code,
and change lock type to spinlock_t.

SGI-PV: 970382
SGI-Modid: xfs-linux-melb:xfs-kern:29744a
Signed-off-by: NEric Sandeen <sandeen@sandeen.net>
Signed-off-by: NDonald Douwsma <donaldd@sgi.com>
Signed-off-by: NTim Shimmin <tes@sgi.com>
上级 64137e56
...@@ -2218,7 +2218,7 @@ xfs_da_state_free(xfs_da_state_t *state) ...@@ -2218,7 +2218,7 @@ xfs_da_state_free(xfs_da_state_t *state)
#ifdef XFS_DABUF_DEBUG #ifdef XFS_DABUF_DEBUG
xfs_dabuf_t *xfs_dabuf_global_list; xfs_dabuf_t *xfs_dabuf_global_list;
lock_t xfs_dabuf_global_lock; spinlock_t xfs_dabuf_global_lock;
#endif #endif
/* /*
...@@ -2264,10 +2264,9 @@ xfs_da_buf_make(int nbuf, xfs_buf_t **bps, inst_t *ra) ...@@ -2264,10 +2264,9 @@ xfs_da_buf_make(int nbuf, xfs_buf_t **bps, inst_t *ra)
} }
#ifdef XFS_DABUF_DEBUG #ifdef XFS_DABUF_DEBUG
{ {
SPLDECL(s);
xfs_dabuf_t *p; xfs_dabuf_t *p;
s = mutex_spinlock(&xfs_dabuf_global_lock); spin_lock(&xfs_dabuf_global_lock);
for (p = xfs_dabuf_global_list; p; p = p->next) { for (p = xfs_dabuf_global_list; p; p = p->next) {
ASSERT(p->blkno != dabuf->blkno || ASSERT(p->blkno != dabuf->blkno ||
p->target != dabuf->target); p->target != dabuf->target);
...@@ -2277,7 +2276,7 @@ xfs_da_buf_make(int nbuf, xfs_buf_t **bps, inst_t *ra) ...@@ -2277,7 +2276,7 @@ xfs_da_buf_make(int nbuf, xfs_buf_t **bps, inst_t *ra)
xfs_dabuf_global_list->prev = dabuf; xfs_dabuf_global_list->prev = dabuf;
dabuf->next = xfs_dabuf_global_list; dabuf->next = xfs_dabuf_global_list;
xfs_dabuf_global_list = dabuf; xfs_dabuf_global_list = dabuf;
mutex_spinunlock(&xfs_dabuf_global_lock, s); spin_unlock(&xfs_dabuf_global_lock);
} }
#endif #endif
return dabuf; return dabuf;
...@@ -2319,16 +2318,14 @@ xfs_da_buf_done(xfs_dabuf_t *dabuf) ...@@ -2319,16 +2318,14 @@ xfs_da_buf_done(xfs_dabuf_t *dabuf)
kmem_free(dabuf->data, BBTOB(dabuf->bbcount)); kmem_free(dabuf->data, BBTOB(dabuf->bbcount));
#ifdef XFS_DABUF_DEBUG #ifdef XFS_DABUF_DEBUG
{ {
SPLDECL(s); spin_lock(&xfs_dabuf_global_lock);
s = mutex_spinlock(&xfs_dabuf_global_lock);
if (dabuf->prev) if (dabuf->prev)
dabuf->prev->next = dabuf->next; dabuf->prev->next = dabuf->next;
else else
xfs_dabuf_global_list = dabuf->next; xfs_dabuf_global_list = dabuf->next;
if (dabuf->next) if (dabuf->next)
dabuf->next->prev = dabuf->prev; dabuf->next->prev = dabuf->prev;
mutex_spinunlock(&xfs_dabuf_global_lock, s); spin_unlock(&xfs_dabuf_global_lock);
} }
memset(dabuf, 0, XFS_DA_BUF_SIZE(dabuf->nbuf)); memset(dabuf, 0, XFS_DA_BUF_SIZE(dabuf->nbuf));
#endif #endif
......
...@@ -67,7 +67,7 @@ xfs_init(void) ...@@ -67,7 +67,7 @@ xfs_init(void)
extern kmem_zone_t *xfs_buf_item_zone; extern kmem_zone_t *xfs_buf_item_zone;
extern kmem_zone_t *xfs_dabuf_zone; extern kmem_zone_t *xfs_dabuf_zone;
#ifdef XFS_DABUF_DEBUG #ifdef XFS_DABUF_DEBUG
extern lock_t xfs_dabuf_global_lock; extern spinlock_t xfs_dabuf_global_lock;
spinlock_init(&xfs_dabuf_global_lock, "xfsda"); spinlock_init(&xfs_dabuf_global_lock, "xfsda");
#endif #endif
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册