]> git.apps.os.sepia.ceph.com Git - ceph-ci.git/commit
rbd-nbd: fix stuck with disable request
authorPrasanna Kumar Kalever <prasanna.kalever@redhat.com>
Tue, 12 Sep 2023 12:15:05 +0000 (17:45 +0530)
committerPrasanna Kumar Kalever <prasanna.kalever@redhat.com>
Thu, 21 Sep 2023 05:48:03 +0000 (11:18 +0530)
commitdbb4daff404c5d2da32c33f4e852e84a257c0b8d
tree70c736ce82340780e501d5025cd2f1c6b9e0a924
parent81e092f333f4f906aab32e2f999e54d2ed6e388f
rbd-nbd: fix stuck with disable request

Problem:
-------
Trying to disable any feature on an rbd image mapped with nbd leads to stuck
in rbd-nbd.

The rbd-nbd registers a watcher callback to detect image resize in
NBDWatchCtx::handle_notify(). The handle_notify calls image info method, which
calls refresh_if_required and it got stuck there.

It is getting stuck in ImageState::refresh_if_required() because
DisableFeaturesRequest issues update notifications while still holding onto
the exclusive lock with everything that has to do with it blocked.

Solution:
--------
Set only notify flag as part of NBDWatchCtx::handle_notify() and handle
the resize detection part as part of a different thread.

Fixes: https://tracker.ceph.com/issues/58740
Signed-off-by: Prasanna Kumar Kalever <prasanna.kalever@redhat.com>
qa/workunits/rbd/rbd-nbd.sh
src/tools/rbd_nbd/rbd-nbd.cc