Commit 2394be1
committed
rbd: don't assume rbd_is_lock_owner() for exclusive mappings
jira LE-1907
Rebuild_History Non-Buildable kernel-5.14.0-427.35.1.el9_4
commit-author Ilya Dryomov <idryomov@gmail.com>
commit 3ceccb1
Expanding on the previous commit, assuming that rbd_is_lock_owner()
always returns true (i.e. that we are either in RBD_LOCK_STATE_LOCKED
or RBD_LOCK_STATE_QUIESCING) if the mapping is exclusive is wrong too.
In case ceph_cls_set_cookie() fails, the lock would be temporarily
released even if the mapping is exclusive, meaning that we can end up
even in RBD_LOCK_STATE_UNLOCKED.
IOW, exclusive mappings are really "just" about disabling automatic
lock transitions (as documented in the man page), not about grabbing
the lock and holding on to it whatever it takes.
Cc: stable@vger.kernel.org
Fixes: 637cd06 ("rbd: new exclusive lock wait/wake code")
Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
Reviewed-by: Dongsheng Yang <dongsheng.yang@easystack.cn>
(cherry picked from commit 3ceccb1)
Signed-off-by: Jonathan Maple <jmaple@ciq.com>1 parent 17df4fd commit 2394be1
1 file changed
+0
-5
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
6590 | 6590 | | |
6591 | 6591 | | |
6592 | 6592 | | |
6593 | | - | |
6594 | | - | |
6595 | | - | |
6596 | | - | |
6597 | | - | |
6598 | 6593 | | |
6599 | 6594 | | |
6600 | 6595 | | |
| |||
0 commit comments