提交 0afbba13 编写于 作者: S Sunil Mushran

ocfs2/dlm: Cleanup up dlm_finish_local_lockres_recovery()

dlm_finish_local_lockres_recovery() needed a facelift.
Signed-off-by: NSunil Mushran <sunil.mushran@oracle.com>
上级 394eb3d3
...@@ -2093,6 +2093,9 @@ static void dlm_finish_local_lockres_recovery(struct dlm_ctxt *dlm, ...@@ -2093,6 +2093,9 @@ static void dlm_finish_local_lockres_recovery(struct dlm_ctxt *dlm,
list_for_each_entry_safe(res, next, &dlm->reco.resources, recovering) { list_for_each_entry_safe(res, next, &dlm->reco.resources, recovering) {
if (res->owner == dead_node) { if (res->owner == dead_node) {
mlog(0, "%s: res %.*s, Changing owner from %u to %u\n",
dlm->name, res->lockname.len, res->lockname.name,
res->owner, new_master);
list_del_init(&res->recovering); list_del_init(&res->recovering);
spin_lock(&res->spinlock); spin_lock(&res->spinlock);
/* new_master has our reference from /* new_master has our reference from
...@@ -2114,33 +2117,24 @@ static void dlm_finish_local_lockres_recovery(struct dlm_ctxt *dlm, ...@@ -2114,33 +2117,24 @@ static void dlm_finish_local_lockres_recovery(struct dlm_ctxt *dlm,
for (i = 0; i < DLM_HASH_BUCKETS; i++) { for (i = 0; i < DLM_HASH_BUCKETS; i++) {
bucket = dlm_lockres_hash(dlm, i); bucket = dlm_lockres_hash(dlm, i);
hlist_for_each_entry(res, hash_iter, bucket, hash_node) { hlist_for_each_entry(res, hash_iter, bucket, hash_node) {
if (res->state & DLM_LOCK_RES_RECOVERING) { if (!(res->state & DLM_LOCK_RES_RECOVERING))
if (res->owner == dead_node) { continue;
mlog(0, "(this=%u) res %.*s owner=%u "
"was not on recovering list, but " if (res->owner != dead_node &&
"clearing state anyway\n", res->owner != dlm->node_num)
dlm->node_num, res->lockname.len,
res->lockname.name, new_master);
} else if (res->owner == dlm->node_num) {
mlog(0, "(this=%u) res %.*s owner=%u "
"was not on recovering list, "
"owner is THIS node, clearing\n",
dlm->node_num, res->lockname.len,
res->lockname.name, new_master);
} else
continue; continue;
if (!list_empty(&res->recovering)) { if (!list_empty(&res->recovering)) {
mlog(0, "%s:%.*s: lockres was "
"marked RECOVERING, owner=%u\n",
dlm->name, res->lockname.len,
res->lockname.name, res->owner);
list_del_init(&res->recovering); list_del_init(&res->recovering);
dlm_lockres_put(res); dlm_lockres_put(res);
} }
spin_lock(&res->spinlock);
/* new_master has our reference from /* new_master has our reference from
* the lock state sent during recovery */ * the lock state sent during recovery */
mlog(0, "%s: res %.*s, Changing owner from %u to %u\n",
dlm->name, res->lockname.len, res->lockname.name,
res->owner, new_master);
spin_lock(&res->spinlock);
dlm_change_lockres_owner(dlm, res, new_master); dlm_change_lockres_owner(dlm, res, new_master);
res->state &= ~DLM_LOCK_RES_RECOVERING; res->state &= ~DLM_LOCK_RES_RECOVERING;
if (__dlm_lockres_has_locks(res)) if (__dlm_lockres_has_locks(res))
...@@ -2149,7 +2143,6 @@ static void dlm_finish_local_lockres_recovery(struct dlm_ctxt *dlm, ...@@ -2149,7 +2143,6 @@ static void dlm_finish_local_lockres_recovery(struct dlm_ctxt *dlm,
wake_up(&res->wq); wake_up(&res->wq);
} }
} }
}
} }
static inline int dlm_lvb_needs_invalidation(struct dlm_lock *lock, int local) static inline int dlm_lvb_needs_invalidation(struct dlm_lock *lock, int local)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册