mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-15 16:53:54 +08:00
libceph: ceph_connection_operations::reencode_message() method
Give upper layers a chance to reencode the message after the connection is negotiated and ->peer_features is set. OSD client will use this to support both luminous and pre-luminous OSDs (in a single cluster): the former need MOSDOp v8; the latter will continue to be sent MOSDOp v4. Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
This commit is contained in:
parent
2e59ffd1df
commit
98ad5ebd15
@ -44,6 +44,8 @@ struct ceph_connection_operations {
|
|||||||
struct ceph_msg_header *hdr,
|
struct ceph_msg_header *hdr,
|
||||||
int *skip);
|
int *skip);
|
||||||
|
|
||||||
|
void (*reencode_message) (struct ceph_msg *msg);
|
||||||
|
|
||||||
int (*sign_message) (struct ceph_msg *msg);
|
int (*sign_message) (struct ceph_msg *msg);
|
||||||
int (*check_message_signature) (struct ceph_msg *msg);
|
int (*check_message_signature) (struct ceph_msg *msg);
|
||||||
};
|
};
|
||||||
|
@ -1288,13 +1288,16 @@ static void prepare_write_message(struct ceph_connection *con)
|
|||||||
m->hdr.seq = cpu_to_le64(++con->out_seq);
|
m->hdr.seq = cpu_to_le64(++con->out_seq);
|
||||||
m->needs_out_seq = false;
|
m->needs_out_seq = false;
|
||||||
}
|
}
|
||||||
WARN_ON(m->data_length != le32_to_cpu(m->hdr.data_len));
|
|
||||||
|
if (con->ops->reencode_message)
|
||||||
|
con->ops->reencode_message(m);
|
||||||
|
|
||||||
dout("prepare_write_message %p seq %lld type %d len %d+%d+%zd\n",
|
dout("prepare_write_message %p seq %lld type %d len %d+%d+%zd\n",
|
||||||
m, con->out_seq, le16_to_cpu(m->hdr.type),
|
m, con->out_seq, le16_to_cpu(m->hdr.type),
|
||||||
le32_to_cpu(m->hdr.front_len), le32_to_cpu(m->hdr.middle_len),
|
le32_to_cpu(m->hdr.front_len), le32_to_cpu(m->hdr.middle_len),
|
||||||
m->data_length);
|
m->data_length);
|
||||||
BUG_ON(le32_to_cpu(m->hdr.front_len) != m->front.iov_len);
|
WARN_ON(m->front.iov_len != le32_to_cpu(m->hdr.front_len));
|
||||||
|
WARN_ON(m->data_length != le32_to_cpu(m->hdr.data_len));
|
||||||
|
|
||||||
/* tag + hdr + front + middle */
|
/* tag + hdr + front + middle */
|
||||||
con_out_kvec_add(con, sizeof (tag_msg), &tag_msg);
|
con_out_kvec_add(con, sizeof (tag_msg), &tag_msg);
|
||||||
|
Loading…
Reference in New Issue
Block a user