mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-24 20:54:10 +08:00
[DLM] fix lost flags in stub replies
When the dlm fakes an unlock/cancel reply from a failed node using a stub message struct, it wasn't setting the flags in the stub message. So, in the process of receiving the fake message the lkb flags would be updated and cleared from the zero flags in the message. The problem observed in tests was the loss of the USER flag which caused the dlm to think a user lock was a kernel lock and subsequently fail an assertion checking the validity of the ast/callback field. Signed-off-by: David Teigland <teigland@redhat.com> Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
This commit is contained in:
parent
8d07fd509e
commit
075529b5e1
@ -3148,6 +3148,7 @@ static void recover_convert_waiter(struct dlm_ls *ls, struct dlm_lkb *lkb)
|
||||
if (middle_conversion(lkb)) {
|
||||
hold_lkb(lkb);
|
||||
ls->ls_stub_ms.m_result = -EINPROGRESS;
|
||||
ls->ls_stub_ms.m_flags = lkb->lkb_flags;
|
||||
_remove_from_waiters(lkb);
|
||||
_receive_convert_reply(lkb, &ls->ls_stub_ms);
|
||||
|
||||
@ -3221,6 +3222,7 @@ void dlm_recover_waiters_pre(struct dlm_ls *ls)
|
||||
case DLM_MSG_UNLOCK:
|
||||
hold_lkb(lkb);
|
||||
ls->ls_stub_ms.m_result = -DLM_EUNLOCK;
|
||||
ls->ls_stub_ms.m_flags = lkb->lkb_flags;
|
||||
_remove_from_waiters(lkb);
|
||||
_receive_unlock_reply(lkb, &ls->ls_stub_ms);
|
||||
dlm_put_lkb(lkb);
|
||||
@ -3229,6 +3231,7 @@ void dlm_recover_waiters_pre(struct dlm_ls *ls)
|
||||
case DLM_MSG_CANCEL:
|
||||
hold_lkb(lkb);
|
||||
ls->ls_stub_ms.m_result = -DLM_ECANCEL;
|
||||
ls->ls_stub_ms.m_flags = lkb->lkb_flags;
|
||||
_remove_from_waiters(lkb);
|
||||
_receive_cancel_reply(lkb, &ls->ls_stub_ms);
|
||||
dlm_put_lkb(lkb);
|
||||
|
Loading…
Reference in New Issue
Block a user