]> git.apps.os.sepia.ceph.com Git - ceph-ci.git/commit
librbd: update progress for non-existent objects on deep-copy
authorIlya Dryomov <idryomov@gmail.com>
Sun, 26 Jun 2022 11:05:09 +0000 (13:05 +0200)
committerIlya Dryomov <idryomov@gmail.com>
Mon, 27 Jun 2022 19:38:47 +0000 (21:38 +0200)
commit6813a7879146aec40f204a174b40a5a54e00b780
treeac7cd1afd5d4b9ffe2b4cbc8a22a00b4adee7228
parentd4d95949490e1db99efb5caca6e97c314e2364f5
librbd: update progress for non-existent objects on deep-copy

As a side effect of commit e5a21e904142 ("librbd: deep-copy image copy
state machine skips clean objects"), handle_object_copy() stopped being
called for non-existent objects.  This broke progress_object_no logic,
which expects to "see" all object numbers so that update_progress()
callback invocations can be ordered.  Currently update_progress() based
progress reporting gets stuck after encountering a hole in the image.

To fix, arrange for handle_object_copy() to be called for all object
numbers, even if ObjectCopyRequest isn't created.  Defer the extra call
to the image work queue to avoid locking issues.

Fixes: https://tracker.ceph.com/issues/56181
Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
src/librbd/deep_copy/ImageCopyRequest.cc
src/test/librbd/deep_copy/test_mock_ImageCopyRequest.cc