libceph: don't omit used_replica in target_copy()
authorIlya Dryomov <idryomov@gmail.com>
Tue, 9 Jun 2020 09:59:08 +0000 (11:59 +0200)
committerIlya Dryomov <idryomov@gmail.com>
Tue, 16 Jun 2020 14:02:08 +0000 (16:02 +0200)
Currently target_copy() is used only for sending linger pings, so
this doesn't come up, but generally omitting used_replica can hang
the client as we wouldn't notice the acting set change (legacy_change
in calc_target()) or trigger a warning in handle_reply().

Fixes: 117d96a04f00 ("libceph: support for balanced and localized reads")
Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
Reviewed-by: Jeff Layton <jlayton@kernel.org>
net/ceph/osd_client.c

index 8f7fbe861dffb611c377692b43e76a444dcef89f..2db8b44e70c27bbabfd69442bfdbf942c967747e 100644 (file)
@@ -448,6 +448,7 @@ static void target_copy(struct ceph_osd_request_target *dest,
        dest->recovery_deletes = src->recovery_deletes;
 
        dest->flags = src->flags;
+       dest->used_replica = src->used_replica;
        dest->paused = src->paused;
 
        dest->epoch = src->epoch;