Commit 89f08173 authored by Ilya Dryomov's avatar Ilya Dryomov

libceph: use sizeof_footer() more

Don't open-code sizeof_footer() in read_partial_message() and
ceph_msg_revoke().  Also, after switching to sizeof_footer(), it's now
possible to use con_out_kvec_add() in prepare_write_message_footer().
Signed-off-by: default avatarIlya Dryomov <idryomov@gmail.com>
Reviewed-by: default avatarAlex Elder <elder@linaro.org>
parent 34b759b4
...@@ -1221,25 +1221,19 @@ static void prepare_message_data(struct ceph_msg *msg, u32 data_len) ...@@ -1221,25 +1221,19 @@ static void prepare_message_data(struct ceph_msg *msg, u32 data_len)
static void prepare_write_message_footer(struct ceph_connection *con) static void prepare_write_message_footer(struct ceph_connection *con)
{ {
struct ceph_msg *m = con->out_msg; struct ceph_msg *m = con->out_msg;
int v = con->out_kvec_left;
m->footer.flags |= CEPH_MSG_FOOTER_COMPLETE; m->footer.flags |= CEPH_MSG_FOOTER_COMPLETE;
dout("prepare_write_message_footer %p\n", con); dout("prepare_write_message_footer %p\n", con);
con->out_kvec[v].iov_base = &m->footer; con_out_kvec_add(con, sizeof_footer(con), &m->footer);
if (con->peer_features & CEPH_FEATURE_MSG_AUTH) { if (con->peer_features & CEPH_FEATURE_MSG_AUTH) {
if (con->ops->sign_message) if (con->ops->sign_message)
con->ops->sign_message(m); con->ops->sign_message(m);
else else
m->footer.sig = 0; m->footer.sig = 0;
con->out_kvec[v].iov_len = sizeof(m->footer);
con->out_kvec_bytes += sizeof(m->footer);
} else { } else {
m->old_footer.flags = m->footer.flags; m->old_footer.flags = m->footer.flags;
con->out_kvec[v].iov_len = sizeof(m->old_footer);
con->out_kvec_bytes += sizeof(m->old_footer);
} }
con->out_kvec_left++;
con->out_more = m->more_to_follow; con->out_more = m->more_to_follow;
con->out_msg_done = true; con->out_msg_done = true;
} }
...@@ -2409,11 +2403,7 @@ static int read_partial_message(struct ceph_connection *con) ...@@ -2409,11 +2403,7 @@ static int read_partial_message(struct ceph_connection *con)
} }
/* footer */ /* footer */
if (need_sign) size = sizeof_footer(con);
size = sizeof(m->footer);
else
size = sizeof(m->old_footer);
end += size; end += size;
ret = read_partial(con, end, size, &m->footer); ret = read_partial(con, end, size, &m->footer);
if (ret <= 0) if (ret <= 0)
...@@ -3089,10 +3079,7 @@ void ceph_msg_revoke(struct ceph_msg *msg) ...@@ -3089,10 +3079,7 @@ void ceph_msg_revoke(struct ceph_msg *msg)
con->out_skip += con_out_kvec_skip(con); con->out_skip += con_out_kvec_skip(con);
} else { } else {
BUG_ON(!msg->data_length); BUG_ON(!msg->data_length);
if (con->peer_features & CEPH_FEATURE_MSG_AUTH) con->out_skip += sizeof_footer(con);
con->out_skip += sizeof(msg->footer);
else
con->out_skip += sizeof(msg->old_footer);
} }
/* data, middle, front */ /* data, middle, front */
if (msg->data_length) if (msg->data_length)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment