|
@@ -1288,13 +1288,16 @@ static void prepare_write_message(struct ceph_connection *con)
|
|
|
m->hdr.seq = cpu_to_le64(++con->out_seq);
|
|
|
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",
|
|
|
m, con->out_seq, le16_to_cpu(m->hdr.type),
|
|
|
le32_to_cpu(m->hdr.front_len), le32_to_cpu(m->hdr.middle_len),
|
|
|
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 */
|
|
|
con_out_kvec_add(con, sizeof (tag_msg), &tag_msg);
|