Commit 5d923111 authored by Andreas Gruenbacher's avatar Andreas Gruenbacher

gfs2: Fix "ignore unlock failures after withdraw"

Commit 3e11e530 tries to suppress dlm_lock() lock conversion errors
that occur when the lockspace has already been released.

It does that by setting and checking the SDF_SKIP_DLM_UNLOCK flag.  This
conflicts with the intended meaning of the SDF_SKIP_DLM_UNLOCK flag, so
check whether the lockspace is still allocated instead.

(Given the current DLM API, checking for this kind of error after the
fact seems easier that than to make sure that the lockspace is still
allocated before calling dlm_lock().  Changing the DLM API so that users
maintain the lockspace references themselves would be an option.)

Fixes: 3e11e530 ("GFS2: ignore unlock failures after withdraw")
Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
parent 262ee3a0
...@@ -810,11 +810,13 @@ __acquires(&gl->gl_lockref.lock) ...@@ -810,11 +810,13 @@ __acquires(&gl->gl_lockref.lock)
} }
if (sdp->sd_lockstruct.ls_ops->lm_lock) { if (sdp->sd_lockstruct.ls_ops->lm_lock) {
struct lm_lockstruct *ls = &sdp->sd_lockstruct;
/* lock_dlm */ /* lock_dlm */
ret = sdp->sd_lockstruct.ls_ops->lm_lock(gl, target, lck_flags); ret = sdp->sd_lockstruct.ls_ops->lm_lock(gl, target, lck_flags);
if (ret == -EINVAL && gl->gl_target == LM_ST_UNLOCKED && if (ret == -EINVAL && gl->gl_target == LM_ST_UNLOCKED &&
target == LM_ST_UNLOCKED && target == LM_ST_UNLOCKED &&
test_bit(SDF_SKIP_DLM_UNLOCK, &sdp->sd_flags)) { test_bit(DFL_UNMOUNT, &ls->ls_recover_flags)) {
finish_xmote(gl, target); finish_xmote(gl, target);
gfs2_glock_queue_work(gl, 0); gfs2_glock_queue_work(gl, 0);
} else if (ret) { } else if (ret) {
......
...@@ -350,7 +350,6 @@ int gfs2_withdraw(struct gfs2_sbd *sdp) ...@@ -350,7 +350,6 @@ int gfs2_withdraw(struct gfs2_sbd *sdp)
fs_err(sdp, "telling LM to unmount\n"); fs_err(sdp, "telling LM to unmount\n");
lm->lm_unmount(sdp); lm->lm_unmount(sdp);
} }
set_bit(SDF_SKIP_DLM_UNLOCK, &sdp->sd_flags);
fs_err(sdp, "File system withdrawn\n"); fs_err(sdp, "File system withdrawn\n");
dump_stack(); dump_stack();
clear_bit(SDF_WITHDRAW_IN_PROG, &sdp->sd_flags); clear_bit(SDF_WITHDRAW_IN_PROG, &sdp->sd_flags);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment