libceph: don't omit recovery_deletes in target_copy()
authorIlya Dryomov <idryomov@gmail.com>
Tue, 9 Jun 2020 09:57:56 +0000 (11:57 +0200)
committerIlya Dryomov <idryomov@gmail.com>
Tue, 16 Jun 2020 14:02:04 +0000 (16:02 +0200)
Currently target_copy() is used only for sending linger pings, so
this doesn't come up, but generally omitting recovery_deletes can
result in unneeded resends (force_resend in calc_target()).

Fixes: ae78dd8139ce ("libceph: make RECOVERY_DELETES feature create a new interval")
Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
Reviewed-by: Jeff Layton <jlayton@kernel.org>
net/ceph/osd_client.c

index a37d159019a099b940310d08cccd8c59ad25b162..8f7fbe861dffb611c377692b43e76a444dcef89f 100644 (file)
@@ -445,6 +445,7 @@ static void target_copy(struct ceph_osd_request_target *dest,
        dest->size = src->size;
        dest->min_size = src->min_size;
        dest->sort_bitwise = src->sort_bitwise;
+       dest->recovery_deletes = src->recovery_deletes;
 
        dest->flags = src->flags;
        dest->paused = src->paused;