This pointer is in a register anyway, so let's use that instead of
reloading from memory everywhere.
Signed-off-by: Max Kellermann <max.kellermann@ionos.com>
---
include/linux/ceph/messenger.h | 4 +-
net/ceph/messenger.c | 4 +-
net/ceph/messenger_v1.c | 43 +++++----
net/ceph/messenger_v2.c | 158 ++++++++++++++++-----------------
4 files changed, 102 insertions(+), 107 deletions(-)
diff --git a/include/linux/ceph/messenger.h b/include/linux/ceph/messenger.h
index 57fa70c6edfb..585844a28237 100644
--- a/include/linux/ceph/messenger.h
+++ b/include/linux/ceph/messenger.h
@@ -553,7 +553,7 @@ struct ceph_msg *ceph_con_get_out_msg(struct ceph_connection *con);
/* messenger_v1.c */
int ceph_con_v1_try_read(struct ceph_connection *con);
int ceph_con_v1_try_write(struct ceph_connection *con);
-void ceph_con_v1_revoke(struct ceph_connection *con);
+void ceph_con_v1_revoke(struct ceph_connection *con, struct ceph_msg *msg);
void ceph_con_v1_revoke_incoming(struct ceph_connection *con);
bool ceph_con_v1_opened(struct ceph_connection *con);
void ceph_con_v1_reset_session(struct ceph_connection *con);
@@ -562,7 +562,7 @@ void ceph_con_v1_reset_protocol(struct ceph_connection *con);
/* messenger_v2.c */
int ceph_con_v2_try_read(struct ceph_connection *con);
int ceph_con_v2_try_write(struct ceph_connection *con);
-void ceph_con_v2_revoke(struct ceph_connection *con);
+void ceph_con_v2_revoke(struct ceph_connection *con, struct ceph_msg *msg);
void ceph_con_v2_revoke_incoming(struct ceph_connection *con);
bool ceph_con_v2_opened(struct ceph_connection *con);
void ceph_con_v2_reset_session(struct ceph_connection *con);
diff --git a/net/ceph/messenger.c b/net/ceph/messenger.c
index 7ab2176b977e..424fb2769b71 100644
--- a/net/ceph/messenger.c
+++ b/net/ceph/messenger.c
@@ -1792,9 +1792,9 @@ void ceph_msg_revoke(struct ceph_msg *msg)
WARN_ON(con->state != CEPH_CON_S_OPEN);
dout("%s con %p msg %p was sending\n", __func__, con, msg);
if (ceph_msgr2(from_msgr(con->msgr)))
- ceph_con_v2_revoke(con);
+ ceph_con_v2_revoke(con, msg);
else
- ceph_con_v1_revoke(con);
+ ceph_con_v1_revoke(con, msg);
ceph_msg_put(con->out_msg);
con->out_msg = NULL;
} else {
diff --git a/net/ceph/messenger_v1.c b/net/ceph/messenger_v1.c
index eebe4e19d75a..516f2eeb122a 100644
--- a/net/ceph/messenger_v1.c
+++ b/net/ceph/messenger_v1.c
@@ -169,10 +169,8 @@ static void prepare_message_data(struct ceph_msg *msg, u32 data_len)
* Prepare footer for currently outgoing message, and finish things
* off. Assumes out_kvec* are already valid.. we just add on to the end.
*/
-static void prepare_write_message_footer(struct ceph_connection *con)
+static void prepare_write_message_footer(struct ceph_connection *con, struct ceph_msg *m)
{
- struct ceph_msg *m = con->out_msg;
-
m->footer.flags |= CEPH_MSG_FOOTER_COMPLETE;
dout("prepare_write_message_footer %p\n", con);
@@ -230,31 +228,31 @@ static void prepare_write_message(struct ceph_connection *con)
/* fill in hdr crc and finalize hdr */
crc = crc32c(0, &m->hdr, offsetof(struct ceph_msg_header, crc));
- con->out_msg->hdr.crc = cpu_to_le32(crc);
- memcpy(&con->v1.out_hdr, &con->out_msg->hdr, sizeof(con->v1.out_hdr));
+ m->hdr.crc = cpu_to_le32(crc);
+ memcpy(&con->v1.out_hdr, &m->hdr, sizeof(con->v1.out_hdr));
/* fill in front and middle crc, footer */
crc = crc32c(0, m->front.iov_base, m->front.iov_len);
- con->out_msg->footer.front_crc = cpu_to_le32(crc);
+ m->footer.front_crc = cpu_to_le32(crc);
if (m->middle) {
crc = crc32c(0, m->middle->vec.iov_base,
m->middle->vec.iov_len);
- con->out_msg->footer.middle_crc = cpu_to_le32(crc);
+ m->footer.middle_crc = cpu_to_le32(crc);
} else
- con->out_msg->footer.middle_crc = 0;
+ m->footer.middle_crc = 0;
dout("%s front_crc %u middle_crc %u\n", __func__,
- le32_to_cpu(con->out_msg->footer.front_crc),
- le32_to_cpu(con->out_msg->footer.middle_crc));
- con->out_msg->footer.flags = 0;
+ le32_to_cpu(m->footer.front_crc),
+ le32_to_cpu(m->footer.middle_crc));
+ m->footer.flags = 0;
/* is there a data payload? */
- con->out_msg->footer.data_crc = 0;
+ m->footer.data_crc = 0;
if (m->data_length) {
- prepare_message_data(con->out_msg, m->data_length);
+ prepare_message_data(m, m->data_length);
con->v1.out_more = 1; /* data + footer will follow */
} else {
/* no, queue up footer too and be done */
- prepare_write_message_footer(con);
+ prepare_write_message_footer(con, m);
}
ceph_con_flag_set(con, CEPH_CON_F_WRITE_PENDING);
@@ -461,9 +459,8 @@ static int write_partial_kvec(struct ceph_connection *con)
* 0 -> socket full, but more to do
* <0 -> error
*/
-static int write_partial_message_data(struct ceph_connection *con)
+static int write_partial_message_data(struct ceph_connection *con, struct ceph_msg *msg)
{
- struct ceph_msg *msg = con->out_msg;
struct ceph_msg_data_cursor *cursor = &msg->cursor;
bool do_datacrc = !ceph_test_opt(from_msgr(con->msgr), NOCRC);
u32 crc;
@@ -515,7 +512,7 @@ static int write_partial_message_data(struct ceph_connection *con)
else
msg->footer.flags |= CEPH_MSG_FOOTER_NOCRC;
con_out_kvec_reset(con);
- prepare_write_message_footer(con);
+ prepare_write_message_footer(con, msg);
return 1; /* must return > 0 to indicate success */
}
@@ -1471,6 +1468,7 @@ int ceph_con_v1_try_read(struct ceph_connection *con)
*/
int ceph_con_v1_try_write(struct ceph_connection *con)
{
+ struct ceph_msg *msg;
int ret = 1;
dout("try_write start %p state %d\n", con, con->state);
@@ -1517,14 +1515,15 @@ int ceph_con_v1_try_write(struct ceph_connection *con)
}
/* msg pages? */
- if (con->out_msg) {
+ msg = con->out_msg;
+ if (msg) {
if (con->v1.out_msg_done) {
- ceph_msg_put(con->out_msg);
+ ceph_msg_put(msg);
con->out_msg = NULL; /* we're done with this one */
goto do_next;
}
- ret = write_partial_message_data(con);
+ ret = write_partial_message_data(con, msg);
if (ret == 1)
goto more; /* we need to send the footer, too! */
if (ret == 0)
@@ -1563,10 +1562,8 @@ int ceph_con_v1_try_write(struct ceph_connection *con)
return ret;
}
-void ceph_con_v1_revoke(struct ceph_connection *con)
+void ceph_con_v1_revoke(struct ceph_connection *con, struct ceph_msg *msg)
{
- struct ceph_msg *msg = con->out_msg;
-
WARN_ON(con->v1.out_skip);
/* footer */
if (con->v1.out_msg_done) {
diff --git a/net/ceph/messenger_v2.c b/net/ceph/messenger_v2.c
index 5483b4eed94e..90109fa0fe60 100644
--- a/net/ceph/messenger_v2.c
+++ b/net/ceph/messenger_v2.c
@@ -1589,10 +1589,10 @@ static int prepare_ack(struct ceph_connection *con)
return prepare_control(con, FRAME_TAG_ACK, con->v2.out_buf, 8);
}
-static void prepare_epilogue_plain(struct ceph_connection *con, bool aborted)
+static void prepare_epilogue_plain(struct ceph_connection *con, struct ceph_msg *msg, bool aborted)
{
dout("%s con %p msg %p aborted %d crcs %u %u %u\n", __func__, con,
- con->out_msg, aborted, con->v2.out_epil.front_crc,
+ msg, aborted, con->v2.out_epil.front_crc,
con->v2.out_epil.middle_crc, con->v2.out_epil.data_crc);
encode_epilogue_plain(con, aborted);
@@ -1603,10 +1603,8 @@ static void prepare_epilogue_plain(struct ceph_connection *con, bool aborted)
* For "used" empty segments, crc is -1. For unused (trailing)
* segments, crc is 0.
*/
-static void prepare_message_plain(struct ceph_connection *con)
+static void prepare_message_plain(struct ceph_connection *con, struct ceph_msg *msg)
{
- struct ceph_msg *msg = con->out_msg;
-
prepare_head_plain(con, con->v2.out_buf,
sizeof(struct ceph_msg_header2), NULL, 0, false);
@@ -1647,7 +1645,7 @@ static void prepare_message_plain(struct ceph_connection *con)
con->v2.out_state = OUT_S_QUEUE_DATA;
} else {
con->v2.out_epil.data_crc = 0;
- prepare_epilogue_plain(con, false);
+ prepare_epilogue_plain(con, msg, false);
con->v2.out_state = OUT_S_FINISH_MESSAGE;
}
}
@@ -1659,7 +1657,7 @@ static void prepare_message_plain(struct ceph_connection *con)
* allocate pages for the entire tail of the message (currently up
* to ~32M) and two sgs arrays (up to ~256K each)...
*/
-static int prepare_message_secure(struct ceph_connection *con)
+static int prepare_message_secure(struct ceph_connection *con, struct ceph_msg *msg)
{
void *zerop = page_address(ceph_zero_page);
struct sg_table enc_sgt = {};
@@ -1674,7 +1672,7 @@ static int prepare_message_secure(struct ceph_connection *con)
if (ret)
return ret;
- tail_len = tail_onwire_len(con->out_msg, true);
+ tail_len = tail_onwire_len(msg, true);
if (!tail_len) {
/*
* Empty message: once the head is written,
@@ -1685,7 +1683,7 @@ static int prepare_message_secure(struct ceph_connection *con)
}
encode_epilogue_secure(con, false);
- ret = setup_message_sgs(&sgt, con->out_msg, zerop, zerop, zerop,
+ ret = setup_message_sgs(&sgt, msg, zerop, zerop, zerop,
&con->v2.out_epil, NULL, 0, false);
if (ret)
goto out;
@@ -1714,7 +1712,7 @@ static int prepare_message_secure(struct ceph_connection *con)
goto out;
dout("%s con %p msg %p sg_cnt %d enc_page_cnt %d\n", __func__, con,
- con->out_msg, sgt.orig_nents, enc_page_cnt);
+ msg, sgt.orig_nents, enc_page_cnt);
con->v2.out_state = OUT_S_QUEUE_ENC_PAGE;
out:
@@ -1723,19 +1721,19 @@ static int prepare_message_secure(struct ceph_connection *con)
return ret;
}
-static int prepare_message(struct ceph_connection *con)
+static int prepare_message(struct ceph_connection *con, struct ceph_msg *msg)
{
int lens[] = {
sizeof(struct ceph_msg_header2),
- front_len(con->out_msg),
- middle_len(con->out_msg),
- data_len(con->out_msg)
+ front_len(msg),
+ middle_len(msg),
+ data_len(msg)
};
struct ceph_frame_desc desc;
int ret;
dout("%s con %p msg %p logical %d+%d+%d+%d\n", __func__, con,
- con->out_msg, lens[0], lens[1], lens[2], lens[3]);
+ msg, lens[0], lens[1], lens[2], lens[3]);
if (con->in_seq > con->in_seq_acked) {
dout("%s con %p in_seq_acked %llu -> %llu\n", __func__, con,
@@ -1746,15 +1744,15 @@ static int prepare_message(struct ceph_connection *con)
reset_out_kvecs(con);
init_frame_desc(&desc, FRAME_TAG_MESSAGE, lens, 4);
encode_preamble(&desc, con->v2.out_buf);
- fill_header2(CTRL_BODY(con->v2.out_buf), &con->out_msg->hdr,
+ fill_header2(CTRL_BODY(con->v2.out_buf), &msg->hdr,
con->in_seq_acked);
if (con_secure(con)) {
- ret = prepare_message_secure(con);
+ ret = prepare_message_secure(con, msg);
if (ret)
return ret;
} else {
- prepare_message_plain(con);
+ prepare_message_plain(con, msg);
}
ceph_con_flag_set(con, CEPH_CON_F_WRITE_PENDING);
@@ -3184,20 +3182,20 @@ int ceph_con_v2_try_read(struct ceph_connection *con)
}
}
-static void queue_data(struct ceph_connection *con)
+static void queue_data(struct ceph_connection *con, struct ceph_msg *msg)
{
struct bio_vec bv;
con->v2.out_epil.data_crc = -1;
- ceph_msg_data_cursor_init(&con->v2.out_cursor, con->out_msg,
- data_len(con->out_msg));
+ ceph_msg_data_cursor_init(&con->v2.out_cursor, msg,
+ data_len(msg));
get_bvec_at(&con->v2.out_cursor, &bv);
set_out_bvec(con, &bv, true);
con->v2.out_state = OUT_S_QUEUE_DATA_CONT;
}
-static void queue_data_cont(struct ceph_connection *con)
+static void queue_data_cont(struct ceph_connection *con, struct ceph_msg *msg)
{
struct bio_vec bv;
@@ -3218,7 +3216,7 @@ static void queue_data_cont(struct ceph_connection *con)
* we are done.
*/
reset_out_kvecs(con);
- prepare_epilogue_plain(con, false);
+ prepare_epilogue_plain(con, msg, false);
con->v2.out_state = OUT_S_FINISH_MESSAGE;
}
@@ -3250,7 +3248,7 @@ static void queue_enc_page(struct ceph_connection *con)
con->v2.out_state = OUT_S_FINISH_MESSAGE;
}
-static void queue_zeros(struct ceph_connection *con)
+static void queue_zeros(struct ceph_connection *con, struct ceph_msg *msg)
{
dout("%s con %p out_zero %d\n", __func__, con, con->v2.out_zero);
@@ -3267,7 +3265,7 @@ static void queue_zeros(struct ceph_connection *con)
* Once it's written, we are done patching up for the revoke.
*/
reset_out_kvecs(con);
- prepare_epilogue_plain(con, true);
+ prepare_epilogue_plain(con, msg, true);
con->v2.out_state = OUT_S_FINISH_MESSAGE;
}
@@ -3309,18 +3307,18 @@ static int populate_out_iter(struct ceph_connection *con)
switch (con->v2.out_state) {
case OUT_S_QUEUE_DATA:
WARN_ON(!con->out_msg);
- queue_data(con);
+ queue_data(con, con->out_msg);
goto populated;
case OUT_S_QUEUE_DATA_CONT:
WARN_ON(!con->out_msg);
- queue_data_cont(con);
+ queue_data_cont(con, con->out_msg);
goto populated;
case OUT_S_QUEUE_ENC_PAGE:
queue_enc_page(con);
goto populated;
case OUT_S_QUEUE_ZEROS:
WARN_ON(con->out_msg); /* revoked */
- queue_zeros(con);
+ queue_zeros(con, con->out_msg);
goto populated;
case OUT_S_FINISH_MESSAGE:
finish_message(con);
@@ -3340,8 +3338,8 @@ static int populate_out_iter(struct ceph_connection *con)
return ret;
}
} else if (!list_empty(&con->out_queue)) {
- ceph_con_get_out_msg(con);
- ret = prepare_message(con);
+ struct ceph_msg *msg = ceph_con_get_out_msg(con);
+ ret = prepare_message(con, msg);
if (ret) {
pr_err("prepare_message failed: %d\n", ret);
return ret;
@@ -3453,17 +3451,17 @@ static u32 crc32c_zeros(u32 crc, int zero_len)
return crc;
}
-static void prepare_zero_front(struct ceph_connection *con, int resid)
+static void prepare_zero_front(struct ceph_connection *con, struct ceph_msg *msg, int resid)
{
int sent;
- WARN_ON(!resid || resid > front_len(con->out_msg));
- sent = front_len(con->out_msg) - resid;
+ WARN_ON(!resid || resid > front_len(msg));
+ sent = front_len(msg) - resid;
dout("%s con %p sent %d resid %d\n", __func__, con, sent, resid);
if (sent) {
con->v2.out_epil.front_crc =
- crc32c(-1, con->out_msg->front.iov_base, sent);
+ crc32c(-1, msg->front.iov_base, sent);
con->v2.out_epil.front_crc =
crc32c_zeros(con->v2.out_epil.front_crc, resid);
} else {
@@ -3474,17 +3472,17 @@ static void prepare_zero_front(struct ceph_connection *con, int resid)
out_zero_add(con, resid);
}
-static void prepare_zero_middle(struct ceph_connection *con, int resid)
+static void prepare_zero_middle(struct ceph_connection *con, struct ceph_msg *msg, int resid)
{
int sent;
- WARN_ON(!resid || resid > middle_len(con->out_msg));
- sent = middle_len(con->out_msg) - resid;
+ WARN_ON(!resid || resid > middle_len(msg));
+ sent = middle_len(msg) - resid;
dout("%s con %p sent %d resid %d\n", __func__, con, sent, resid);
if (sent) {
con->v2.out_epil.middle_crc =
- crc32c(-1, con->out_msg->middle->vec.iov_base, sent);
+ crc32c(-1, msg->middle->vec.iov_base, sent);
con->v2.out_epil.middle_crc =
crc32c_zeros(con->v2.out_epil.middle_crc, resid);
} else {
@@ -3495,61 +3493,61 @@ static void prepare_zero_middle(struct ceph_connection *con, int resid)
out_zero_add(con, resid);
}
-static void prepare_zero_data(struct ceph_connection *con)
+static void prepare_zero_data(struct ceph_connection *con, struct ceph_msg *msg)
{
dout("%s con %p\n", __func__, con);
- con->v2.out_epil.data_crc = crc32c_zeros(-1, data_len(con->out_msg));
- out_zero_add(con, data_len(con->out_msg));
+ con->v2.out_epil.data_crc = crc32c_zeros(-1, data_len(msg));
+ out_zero_add(con, data_len(msg));
}
-static void revoke_at_queue_data(struct ceph_connection *con)
+static void revoke_at_queue_data(struct ceph_connection *con, struct ceph_msg *msg)
{
int boundary;
int resid;
- WARN_ON(!data_len(con->out_msg));
+ WARN_ON(!data_len(msg));
WARN_ON(!iov_iter_is_kvec(&con->v2.out_iter));
resid = iov_iter_count(&con->v2.out_iter);
- boundary = front_len(con->out_msg) + middle_len(con->out_msg);
+ boundary = front_len(msg) + middle_len(msg);
if (resid > boundary) {
resid -= boundary;
WARN_ON(resid > MESSAGE_HEAD_PLAIN_LEN);
dout("%s con %p was sending head\n", __func__, con);
- if (front_len(con->out_msg))
- prepare_zero_front(con, front_len(con->out_msg));
- if (middle_len(con->out_msg))
- prepare_zero_middle(con, middle_len(con->out_msg));
- prepare_zero_data(con);
+ if (front_len(msg))
+ prepare_zero_front(con, msg, front_len(msg));
+ if (middle_len(msg))
+ prepare_zero_middle(con, msg, middle_len(msg));
+ prepare_zero_data(con, msg);
WARN_ON(iov_iter_count(&con->v2.out_iter) != resid);
con->v2.out_state = OUT_S_QUEUE_ZEROS;
return;
}
- boundary = middle_len(con->out_msg);
+ boundary = middle_len(msg);
if (resid > boundary) {
resid -= boundary;
dout("%s con %p was sending front\n", __func__, con);
- prepare_zero_front(con, resid);
- if (middle_len(con->out_msg))
- prepare_zero_middle(con, middle_len(con->out_msg));
- prepare_zero_data(con);
- queue_zeros(con);
+ prepare_zero_front(con, msg, resid);
+ if (middle_len(msg))
+ prepare_zero_middle(con, msg, middle_len(msg));
+ prepare_zero_data(con, msg);
+ queue_zeros(con, msg);
return;
}
WARN_ON(!resid);
dout("%s con %p was sending middle\n", __func__, con);
- prepare_zero_middle(con, resid);
- prepare_zero_data(con);
- queue_zeros(con);
+ prepare_zero_middle(con, msg, resid);
+ prepare_zero_data(con, msg);
+ queue_zeros(con, msg);
}
-static void revoke_at_queue_data_cont(struct ceph_connection *con)
+static void revoke_at_queue_data_cont(struct ceph_connection *con, struct ceph_msg *msg)
{
int sent, resid; /* current piece of data */
- WARN_ON(!data_len(con->out_msg));
+ WARN_ON(!data_len(msg));
WARN_ON(!iov_iter_is_bvec(&con->v2.out_iter));
resid = iov_iter_count(&con->v2.out_iter);
WARN_ON(!resid || resid > con->v2.out_bvec.bv_len);
@@ -3568,10 +3566,10 @@ static void revoke_at_queue_data_cont(struct ceph_connection *con)
con->v2.out_iter.count -= resid;
out_zero_add(con, con->v2.out_cursor.total_resid);
- queue_zeros(con);
+ queue_zeros(con, msg);
}
-static void revoke_at_finish_message(struct ceph_connection *con)
+static void revoke_at_finish_message(struct ceph_connection *con, struct ceph_msg *msg)
{
int boundary;
int resid;
@@ -3579,39 +3577,39 @@ static void revoke_at_finish_message(struct ceph_connection *con)
WARN_ON(!iov_iter_is_kvec(&con->v2.out_iter));
resid = iov_iter_count(&con->v2.out_iter);
- if (!front_len(con->out_msg) && !middle_len(con->out_msg) &&
- !data_len(con->out_msg)) {
+ if (!front_len(msg) && !middle_len(msg) &&
+ !data_len(msg)) {
WARN_ON(!resid || resid > MESSAGE_HEAD_PLAIN_LEN);
dout("%s con %p was sending head (empty message) - noop\n",
__func__, con);
return;
}
- boundary = front_len(con->out_msg) + middle_len(con->out_msg) +
+ boundary = front_len(msg) + middle_len(msg) +
CEPH_EPILOGUE_PLAIN_LEN;
if (resid > boundary) {
resid -= boundary;
WARN_ON(resid > MESSAGE_HEAD_PLAIN_LEN);
dout("%s con %p was sending head\n", __func__, con);
- if (front_len(con->out_msg))
- prepare_zero_front(con, front_len(con->out_msg));
- if (middle_len(con->out_msg))
- prepare_zero_middle(con, middle_len(con->out_msg));
+ if (front_len(msg))
+ prepare_zero_front(con, msg, front_len(msg));
+ if (middle_len(msg))
+ prepare_zero_middle(con, msg, middle_len(msg));
con->v2.out_iter.count -= CEPH_EPILOGUE_PLAIN_LEN;
WARN_ON(iov_iter_count(&con->v2.out_iter) != resid);
con->v2.out_state = OUT_S_QUEUE_ZEROS;
return;
}
- boundary = middle_len(con->out_msg) + CEPH_EPILOGUE_PLAIN_LEN;
+ boundary = middle_len(msg) + CEPH_EPILOGUE_PLAIN_LEN;
if (resid > boundary) {
resid -= boundary;
dout("%s con %p was sending front\n", __func__, con);
- prepare_zero_front(con, resid);
- if (middle_len(con->out_msg))
- prepare_zero_middle(con, middle_len(con->out_msg));
+ prepare_zero_front(con, msg, resid);
+ if (middle_len(msg))
+ prepare_zero_middle(con, msg, middle_len(msg));
con->v2.out_iter.count -= CEPH_EPILOGUE_PLAIN_LEN;
- queue_zeros(con);
+ queue_zeros(con, msg);
return;
}
@@ -3619,9 +3617,9 @@ static void revoke_at_finish_message(struct ceph_connection *con)
if (resid > boundary) {
resid -= boundary;
dout("%s con %p was sending middle\n", __func__, con);
- prepare_zero_middle(con, resid);
+ prepare_zero_middle(con, msg, resid);
con->v2.out_iter.count -= CEPH_EPILOGUE_PLAIN_LEN;
- queue_zeros(con);
+ queue_zeros(con, msg);
return;
}
@@ -3629,7 +3627,7 @@ static void revoke_at_finish_message(struct ceph_connection *con)
dout("%s con %p was sending epilogue - noop\n", __func__, con);
}
-void ceph_con_v2_revoke(struct ceph_connection *con)
+void ceph_con_v2_revoke(struct ceph_connection *con, struct ceph_msg *msg)
{
WARN_ON(con->v2.out_zero);
@@ -3642,13 +3640,13 @@ void ceph_con_v2_revoke(struct ceph_connection *con)
switch (con->v2.out_state) {
case OUT_S_QUEUE_DATA:
- revoke_at_queue_data(con);
+ revoke_at_queue_data(con, msg);
break;
case OUT_S_QUEUE_DATA_CONT:
- revoke_at_queue_data_cont(con);
+ revoke_at_queue_data_cont(con, msg);
break;
case OUT_S_FINISH_MESSAGE:
- revoke_at_finish_message(con);
+ revoke_at_finish_message(con, msg);
break;
default:
WARN(1, "bad out_state %d", con->v2.out_state);
--
2.47.2
On Wed, 2025-08-06 at 11:48 +0200, Max Kellermann wrote: > This pointer is in a register anyway, so let's use that instead of > reloading from memory everywhere. > > Signed-off-by: Max Kellermann <max.kellermann@ionos.com> Looks good. Reviewed-by: Viacheslav Dubeyko <Slava.Dubeyko@ibm.com> Thanks, Slava. > --- > include/linux/ceph/messenger.h | 4 +- > net/ceph/messenger.c | 4 +- > net/ceph/messenger_v1.c | 43 +++++---- > net/ceph/messenger_v2.c | 158 ++++++++++++++++----------------- > 4 files changed, 102 insertions(+), 107 deletions(-) > > diff --git a/include/linux/ceph/messenger.h b/include/linux/ceph/messenger.h > index 57fa70c6edfb..585844a28237 100644 > --- a/include/linux/ceph/messenger.h > +++ b/include/linux/ceph/messenger.h > @@ -553,7 +553,7 @@ struct ceph_msg *ceph_con_get_out_msg(struct ceph_connection *con); > /* messenger_v1.c */ > int ceph_con_v1_try_read(struct ceph_connection *con); > int ceph_con_v1_try_write(struct ceph_connection *con); > -void ceph_con_v1_revoke(struct ceph_connection *con); > +void ceph_con_v1_revoke(struct ceph_connection *con, struct ceph_msg *msg); > void ceph_con_v1_revoke_incoming(struct ceph_connection *con); > bool ceph_con_v1_opened(struct ceph_connection *con); > void ceph_con_v1_reset_session(struct ceph_connection *con); > @@ -562,7 +562,7 @@ void ceph_con_v1_reset_protocol(struct ceph_connection *con); > /* messenger_v2.c */ > int ceph_con_v2_try_read(struct ceph_connection *con); > int ceph_con_v2_try_write(struct ceph_connection *con); > -void ceph_con_v2_revoke(struct ceph_connection *con); > +void ceph_con_v2_revoke(struct ceph_connection *con, struct ceph_msg *msg); > void ceph_con_v2_revoke_incoming(struct ceph_connection *con); > bool ceph_con_v2_opened(struct ceph_connection *con); > void ceph_con_v2_reset_session(struct ceph_connection *con); > diff --git a/net/ceph/messenger.c b/net/ceph/messenger.c > index 7ab2176b977e..424fb2769b71 100644 > --- a/net/ceph/messenger.c > +++ b/net/ceph/messenger.c > @@ -1792,9 +1792,9 @@ void ceph_msg_revoke(struct ceph_msg *msg) > WARN_ON(con->state != CEPH_CON_S_OPEN); > dout("%s con %p msg %p was sending\n", __func__, con, msg); > if (ceph_msgr2(from_msgr(con->msgr))) > - ceph_con_v2_revoke(con); > + ceph_con_v2_revoke(con, msg); > else > - ceph_con_v1_revoke(con); > + ceph_con_v1_revoke(con, msg); > ceph_msg_put(con->out_msg); > con->out_msg = NULL; > } else { > diff --git a/net/ceph/messenger_v1.c b/net/ceph/messenger_v1.c > index eebe4e19d75a..516f2eeb122a 100644 > --- a/net/ceph/messenger_v1.c > +++ b/net/ceph/messenger_v1.c > @@ -169,10 +169,8 @@ static void prepare_message_data(struct ceph_msg *msg, u32 data_len) > * Prepare footer for currently outgoing message, and finish things > * off. Assumes out_kvec* are already valid.. we just add on to the end. > */ > -static void prepare_write_message_footer(struct ceph_connection *con) > +static void prepare_write_message_footer(struct ceph_connection *con, struct ceph_msg *m) > { > - struct ceph_msg *m = con->out_msg; > - > m->footer.flags |= CEPH_MSG_FOOTER_COMPLETE; > > dout("prepare_write_message_footer %p\n", con); > @@ -230,31 +228,31 @@ static void prepare_write_message(struct ceph_connection *con) > > /* fill in hdr crc and finalize hdr */ > crc = crc32c(0, &m->hdr, offsetof(struct ceph_msg_header, crc)); > - con->out_msg->hdr.crc = cpu_to_le32(crc); > - memcpy(&con->v1.out_hdr, &con->out_msg->hdr, sizeof(con->v1.out_hdr)); > + m->hdr.crc = cpu_to_le32(crc); > + memcpy(&con->v1.out_hdr, &m->hdr, sizeof(con->v1.out_hdr)); > > /* fill in front and middle crc, footer */ > crc = crc32c(0, m->front.iov_base, m->front.iov_len); > - con->out_msg->footer.front_crc = cpu_to_le32(crc); > + m->footer.front_crc = cpu_to_le32(crc); > if (m->middle) { > crc = crc32c(0, m->middle->vec.iov_base, > m->middle->vec.iov_len); > - con->out_msg->footer.middle_crc = cpu_to_le32(crc); > + m->footer.middle_crc = cpu_to_le32(crc); > } else > - con->out_msg->footer.middle_crc = 0; > + m->footer.middle_crc = 0; > dout("%s front_crc %u middle_crc %u\n", __func__, > - le32_to_cpu(con->out_msg->footer.front_crc), > - le32_to_cpu(con->out_msg->footer.middle_crc)); > - con->out_msg->footer.flags = 0; > + le32_to_cpu(m->footer.front_crc), > + le32_to_cpu(m->footer.middle_crc)); > + m->footer.flags = 0; > > /* is there a data payload? */ > - con->out_msg->footer.data_crc = 0; > + m->footer.data_crc = 0; > if (m->data_length) { > - prepare_message_data(con->out_msg, m->data_length); > + prepare_message_data(m, m->data_length); > con->v1.out_more = 1; /* data + footer will follow */ > } else { > /* no, queue up footer too and be done */ > - prepare_write_message_footer(con); > + prepare_write_message_footer(con, m); > } > > ceph_con_flag_set(con, CEPH_CON_F_WRITE_PENDING); > @@ -461,9 +459,8 @@ static int write_partial_kvec(struct ceph_connection *con) > * 0 -> socket full, but more to do > * <0 -> error > */ > -static int write_partial_message_data(struct ceph_connection *con) > +static int write_partial_message_data(struct ceph_connection *con, struct ceph_msg *msg) > { > - struct ceph_msg *msg = con->out_msg; > struct ceph_msg_data_cursor *cursor = &msg->cursor; > bool do_datacrc = !ceph_test_opt(from_msgr(con->msgr), NOCRC); > u32 crc; > @@ -515,7 +512,7 @@ static int write_partial_message_data(struct ceph_connection *con) > else > msg->footer.flags |= CEPH_MSG_FOOTER_NOCRC; > con_out_kvec_reset(con); > - prepare_write_message_footer(con); > + prepare_write_message_footer(con, msg); > > return 1; /* must return > 0 to indicate success */ > } > @@ -1471,6 +1468,7 @@ int ceph_con_v1_try_read(struct ceph_connection *con) > */ > int ceph_con_v1_try_write(struct ceph_connection *con) > { > + struct ceph_msg *msg; > int ret = 1; > > dout("try_write start %p state %d\n", con, con->state); > @@ -1517,14 +1515,15 @@ int ceph_con_v1_try_write(struct ceph_connection *con) > } > > /* msg pages? */ > - if (con->out_msg) { > + msg = con->out_msg; > + if (msg) { > if (con->v1.out_msg_done) { > - ceph_msg_put(con->out_msg); > + ceph_msg_put(msg); > con->out_msg = NULL; /* we're done with this one */ > goto do_next; > } > > - ret = write_partial_message_data(con); > + ret = write_partial_message_data(con, msg); > if (ret == 1) > goto more; /* we need to send the footer, too! */ > if (ret == 0) > @@ -1563,10 +1562,8 @@ int ceph_con_v1_try_write(struct ceph_connection *con) > return ret; > } > > -void ceph_con_v1_revoke(struct ceph_connection *con) > +void ceph_con_v1_revoke(struct ceph_connection *con, struct ceph_msg *msg) > { > - struct ceph_msg *msg = con->out_msg; > - > WARN_ON(con->v1.out_skip); > /* footer */ > if (con->v1.out_msg_done) { > diff --git a/net/ceph/messenger_v2.c b/net/ceph/messenger_v2.c > index 5483b4eed94e..90109fa0fe60 100644 > --- a/net/ceph/messenger_v2.c > +++ b/net/ceph/messenger_v2.c > @@ -1589,10 +1589,10 @@ static int prepare_ack(struct ceph_connection *con) > return prepare_control(con, FRAME_TAG_ACK, con->v2.out_buf, 8); > } > > -static void prepare_epilogue_plain(struct ceph_connection *con, bool aborted) > +static void prepare_epilogue_plain(struct ceph_connection *con, struct ceph_msg *msg, bool aborted) > { > dout("%s con %p msg %p aborted %d crcs %u %u %u\n", __func__, con, > - con->out_msg, aborted, con->v2.out_epil.front_crc, > + msg, aborted, con->v2.out_epil.front_crc, > con->v2.out_epil.middle_crc, con->v2.out_epil.data_crc); > > encode_epilogue_plain(con, aborted); > @@ -1603,10 +1603,8 @@ static void prepare_epilogue_plain(struct ceph_connection *con, bool aborted) > * For "used" empty segments, crc is -1. For unused (trailing) > * segments, crc is 0. > */ > -static void prepare_message_plain(struct ceph_connection *con) > +static void prepare_message_plain(struct ceph_connection *con, struct ceph_msg *msg) > { > - struct ceph_msg *msg = con->out_msg; > - > prepare_head_plain(con, con->v2.out_buf, > sizeof(struct ceph_msg_header2), NULL, 0, false); > > @@ -1647,7 +1645,7 @@ static void prepare_message_plain(struct ceph_connection *con) > con->v2.out_state = OUT_S_QUEUE_DATA; > } else { > con->v2.out_epil.data_crc = 0; > - prepare_epilogue_plain(con, false); > + prepare_epilogue_plain(con, msg, false); > con->v2.out_state = OUT_S_FINISH_MESSAGE; > } > } > @@ -1659,7 +1657,7 @@ static void prepare_message_plain(struct ceph_connection *con) > * allocate pages for the entire tail of the message (currently up > * to ~32M) and two sgs arrays (up to ~256K each)... > */ > -static int prepare_message_secure(struct ceph_connection *con) > +static int prepare_message_secure(struct ceph_connection *con, struct ceph_msg *msg) > { > void *zerop = page_address(ceph_zero_page); > struct sg_table enc_sgt = {}; > @@ -1674,7 +1672,7 @@ static int prepare_message_secure(struct ceph_connection *con) > if (ret) > return ret; > > - tail_len = tail_onwire_len(con->out_msg, true); > + tail_len = tail_onwire_len(msg, true); > if (!tail_len) { > /* > * Empty message: once the head is written, > @@ -1685,7 +1683,7 @@ static int prepare_message_secure(struct ceph_connection *con) > } > > encode_epilogue_secure(con, false); > - ret = setup_message_sgs(&sgt, con->out_msg, zerop, zerop, zerop, > + ret = setup_message_sgs(&sgt, msg, zerop, zerop, zerop, > &con->v2.out_epil, NULL, 0, false); > if (ret) > goto out; > @@ -1714,7 +1712,7 @@ static int prepare_message_secure(struct ceph_connection *con) > goto out; > > dout("%s con %p msg %p sg_cnt %d enc_page_cnt %d\n", __func__, con, > - con->out_msg, sgt.orig_nents, enc_page_cnt); > + msg, sgt.orig_nents, enc_page_cnt); > con->v2.out_state = OUT_S_QUEUE_ENC_PAGE; > > out: > @@ -1723,19 +1721,19 @@ static int prepare_message_secure(struct ceph_connection *con) > return ret; > } > > -static int prepare_message(struct ceph_connection *con) > +static int prepare_message(struct ceph_connection *con, struct ceph_msg *msg) > { > int lens[] = { > sizeof(struct ceph_msg_header2), > - front_len(con->out_msg), > - middle_len(con->out_msg), > - data_len(con->out_msg) > + front_len(msg), > + middle_len(msg), > + data_len(msg) > }; > struct ceph_frame_desc desc; > int ret; > > dout("%s con %p msg %p logical %d+%d+%d+%d\n", __func__, con, > - con->out_msg, lens[0], lens[1], lens[2], lens[3]); > + msg, lens[0], lens[1], lens[2], lens[3]); > > if (con->in_seq > con->in_seq_acked) { > dout("%s con %p in_seq_acked %llu -> %llu\n", __func__, con, > @@ -1746,15 +1744,15 @@ static int prepare_message(struct ceph_connection *con) > reset_out_kvecs(con); > init_frame_desc(&desc, FRAME_TAG_MESSAGE, lens, 4); > encode_preamble(&desc, con->v2.out_buf); > - fill_header2(CTRL_BODY(con->v2.out_buf), &con->out_msg->hdr, > + fill_header2(CTRL_BODY(con->v2.out_buf), &msg->hdr, > con->in_seq_acked); > > if (con_secure(con)) { > - ret = prepare_message_secure(con); > + ret = prepare_message_secure(con, msg); > if (ret) > return ret; > } else { > - prepare_message_plain(con); > + prepare_message_plain(con, msg); > } > > ceph_con_flag_set(con, CEPH_CON_F_WRITE_PENDING); > @@ -3184,20 +3182,20 @@ int ceph_con_v2_try_read(struct ceph_connection *con) > } > } > > -static void queue_data(struct ceph_connection *con) > +static void queue_data(struct ceph_connection *con, struct ceph_msg *msg) > { > struct bio_vec bv; > > con->v2.out_epil.data_crc = -1; > - ceph_msg_data_cursor_init(&con->v2.out_cursor, con->out_msg, > - data_len(con->out_msg)); > + ceph_msg_data_cursor_init(&con->v2.out_cursor, msg, > + data_len(msg)); > > get_bvec_at(&con->v2.out_cursor, &bv); > set_out_bvec(con, &bv, true); > con->v2.out_state = OUT_S_QUEUE_DATA_CONT; > } > > -static void queue_data_cont(struct ceph_connection *con) > +static void queue_data_cont(struct ceph_connection *con, struct ceph_msg *msg) > { > struct bio_vec bv; > > @@ -3218,7 +3216,7 @@ static void queue_data_cont(struct ceph_connection *con) > * we are done. > */ > reset_out_kvecs(con); > - prepare_epilogue_plain(con, false); > + prepare_epilogue_plain(con, msg, false); > con->v2.out_state = OUT_S_FINISH_MESSAGE; > } > > @@ -3250,7 +3248,7 @@ static void queue_enc_page(struct ceph_connection *con) > con->v2.out_state = OUT_S_FINISH_MESSAGE; > } > > -static void queue_zeros(struct ceph_connection *con) > +static void queue_zeros(struct ceph_connection *con, struct ceph_msg *msg) > { > dout("%s con %p out_zero %d\n", __func__, con, con->v2.out_zero); > > @@ -3267,7 +3265,7 @@ static void queue_zeros(struct ceph_connection *con) > * Once it's written, we are done patching up for the revoke. > */ > reset_out_kvecs(con); > - prepare_epilogue_plain(con, true); > + prepare_epilogue_plain(con, msg, true); > con->v2.out_state = OUT_S_FINISH_MESSAGE; > } > > @@ -3309,18 +3307,18 @@ static int populate_out_iter(struct ceph_connection *con) > switch (con->v2.out_state) { > case OUT_S_QUEUE_DATA: > WARN_ON(!con->out_msg); > - queue_data(con); > + queue_data(con, con->out_msg); > goto populated; > case OUT_S_QUEUE_DATA_CONT: > WARN_ON(!con->out_msg); > - queue_data_cont(con); > + queue_data_cont(con, con->out_msg); > goto populated; > case OUT_S_QUEUE_ENC_PAGE: > queue_enc_page(con); > goto populated; > case OUT_S_QUEUE_ZEROS: > WARN_ON(con->out_msg); /* revoked */ > - queue_zeros(con); > + queue_zeros(con, con->out_msg); > goto populated; > case OUT_S_FINISH_MESSAGE: > finish_message(con); > @@ -3340,8 +3338,8 @@ static int populate_out_iter(struct ceph_connection *con) > return ret; > } > } else if (!list_empty(&con->out_queue)) { > - ceph_con_get_out_msg(con); > - ret = prepare_message(con); > + struct ceph_msg *msg = ceph_con_get_out_msg(con); > + ret = prepare_message(con, msg); > if (ret) { > pr_err("prepare_message failed: %d\n", ret); > return ret; > @@ -3453,17 +3451,17 @@ static u32 crc32c_zeros(u32 crc, int zero_len) > return crc; > } > > -static void prepare_zero_front(struct ceph_connection *con, int resid) > +static void prepare_zero_front(struct ceph_connection *con, struct ceph_msg *msg, int resid) > { > int sent; > > - WARN_ON(!resid || resid > front_len(con->out_msg)); > - sent = front_len(con->out_msg) - resid; > + WARN_ON(!resid || resid > front_len(msg)); > + sent = front_len(msg) - resid; > dout("%s con %p sent %d resid %d\n", __func__, con, sent, resid); > > if (sent) { > con->v2.out_epil.front_crc = > - crc32c(-1, con->out_msg->front.iov_base, sent); > + crc32c(-1, msg->front.iov_base, sent); > con->v2.out_epil.front_crc = > crc32c_zeros(con->v2.out_epil.front_crc, resid); > } else { > @@ -3474,17 +3472,17 @@ static void prepare_zero_front(struct ceph_connection *con, int resid) > out_zero_add(con, resid); > } > > -static void prepare_zero_middle(struct ceph_connection *con, int resid) > +static void prepare_zero_middle(struct ceph_connection *con, struct ceph_msg *msg, int resid) > { > int sent; > > - WARN_ON(!resid || resid > middle_len(con->out_msg)); > - sent = middle_len(con->out_msg) - resid; > + WARN_ON(!resid || resid > middle_len(msg)); > + sent = middle_len(msg) - resid; > dout("%s con %p sent %d resid %d\n", __func__, con, sent, resid); > > if (sent) { > con->v2.out_epil.middle_crc = > - crc32c(-1, con->out_msg->middle->vec.iov_base, sent); > + crc32c(-1, msg->middle->vec.iov_base, sent); > con->v2.out_epil.middle_crc = > crc32c_zeros(con->v2.out_epil.middle_crc, resid); > } else { > @@ -3495,61 +3493,61 @@ static void prepare_zero_middle(struct ceph_connection *con, int resid) > out_zero_add(con, resid); > } > > -static void prepare_zero_data(struct ceph_connection *con) > +static void prepare_zero_data(struct ceph_connection *con, struct ceph_msg *msg) > { > dout("%s con %p\n", __func__, con); > - con->v2.out_epil.data_crc = crc32c_zeros(-1, data_len(con->out_msg)); > - out_zero_add(con, data_len(con->out_msg)); > + con->v2.out_epil.data_crc = crc32c_zeros(-1, data_len(msg)); > + out_zero_add(con, data_len(msg)); > } > > -static void revoke_at_queue_data(struct ceph_connection *con) > +static void revoke_at_queue_data(struct ceph_connection *con, struct ceph_msg *msg) > { > int boundary; > int resid; > > - WARN_ON(!data_len(con->out_msg)); > + WARN_ON(!data_len(msg)); > WARN_ON(!iov_iter_is_kvec(&con->v2.out_iter)); > resid = iov_iter_count(&con->v2.out_iter); > > - boundary = front_len(con->out_msg) + middle_len(con->out_msg); > + boundary = front_len(msg) + middle_len(msg); > if (resid > boundary) { > resid -= boundary; > WARN_ON(resid > MESSAGE_HEAD_PLAIN_LEN); > dout("%s con %p was sending head\n", __func__, con); > - if (front_len(con->out_msg)) > - prepare_zero_front(con, front_len(con->out_msg)); > - if (middle_len(con->out_msg)) > - prepare_zero_middle(con, middle_len(con->out_msg)); > - prepare_zero_data(con); > + if (front_len(msg)) > + prepare_zero_front(con, msg, front_len(msg)); > + if (middle_len(msg)) > + prepare_zero_middle(con, msg, middle_len(msg)); > + prepare_zero_data(con, msg); > WARN_ON(iov_iter_count(&con->v2.out_iter) != resid); > con->v2.out_state = OUT_S_QUEUE_ZEROS; > return; > } > > - boundary = middle_len(con->out_msg); > + boundary = middle_len(msg); > if (resid > boundary) { > resid -= boundary; > dout("%s con %p was sending front\n", __func__, con); > - prepare_zero_front(con, resid); > - if (middle_len(con->out_msg)) > - prepare_zero_middle(con, middle_len(con->out_msg)); > - prepare_zero_data(con); > - queue_zeros(con); > + prepare_zero_front(con, msg, resid); > + if (middle_len(msg)) > + prepare_zero_middle(con, msg, middle_len(msg)); > + prepare_zero_data(con, msg); > + queue_zeros(con, msg); > return; > } > > WARN_ON(!resid); > dout("%s con %p was sending middle\n", __func__, con); > - prepare_zero_middle(con, resid); > - prepare_zero_data(con); > - queue_zeros(con); > + prepare_zero_middle(con, msg, resid); > + prepare_zero_data(con, msg); > + queue_zeros(con, msg); > } > > -static void revoke_at_queue_data_cont(struct ceph_connection *con) > +static void revoke_at_queue_data_cont(struct ceph_connection *con, struct ceph_msg *msg) > { > int sent, resid; /* current piece of data */ > > - WARN_ON(!data_len(con->out_msg)); > + WARN_ON(!data_len(msg)); > WARN_ON(!iov_iter_is_bvec(&con->v2.out_iter)); > resid = iov_iter_count(&con->v2.out_iter); > WARN_ON(!resid || resid > con->v2.out_bvec.bv_len); > @@ -3568,10 +3566,10 @@ static void revoke_at_queue_data_cont(struct ceph_connection *con) > > con->v2.out_iter.count -= resid; > out_zero_add(con, con->v2.out_cursor.total_resid); > - queue_zeros(con); > + queue_zeros(con, msg); > } > > -static void revoke_at_finish_message(struct ceph_connection *con) > +static void revoke_at_finish_message(struct ceph_connection *con, struct ceph_msg *msg) > { > int boundary; > int resid; > @@ -3579,39 +3577,39 @@ static void revoke_at_finish_message(struct ceph_connection *con) > WARN_ON(!iov_iter_is_kvec(&con->v2.out_iter)); > resid = iov_iter_count(&con->v2.out_iter); > > - if (!front_len(con->out_msg) && !middle_len(con->out_msg) && > - !data_len(con->out_msg)) { > + if (!front_len(msg) && !middle_len(msg) && > + !data_len(msg)) { > WARN_ON(!resid || resid > MESSAGE_HEAD_PLAIN_LEN); > dout("%s con %p was sending head (empty message) - noop\n", > __func__, con); > return; > } > > - boundary = front_len(con->out_msg) + middle_len(con->out_msg) + > + boundary = front_len(msg) + middle_len(msg) + > CEPH_EPILOGUE_PLAIN_LEN; > if (resid > boundary) { > resid -= boundary; > WARN_ON(resid > MESSAGE_HEAD_PLAIN_LEN); > dout("%s con %p was sending head\n", __func__, con); > - if (front_len(con->out_msg)) > - prepare_zero_front(con, front_len(con->out_msg)); > - if (middle_len(con->out_msg)) > - prepare_zero_middle(con, middle_len(con->out_msg)); > + if (front_len(msg)) > + prepare_zero_front(con, msg, front_len(msg)); > + if (middle_len(msg)) > + prepare_zero_middle(con, msg, middle_len(msg)); > con->v2.out_iter.count -= CEPH_EPILOGUE_PLAIN_LEN; > WARN_ON(iov_iter_count(&con->v2.out_iter) != resid); > con->v2.out_state = OUT_S_QUEUE_ZEROS; > return; > } > > - boundary = middle_len(con->out_msg) + CEPH_EPILOGUE_PLAIN_LEN; > + boundary = middle_len(msg) + CEPH_EPILOGUE_PLAIN_LEN; > if (resid > boundary) { > resid -= boundary; > dout("%s con %p was sending front\n", __func__, con); > - prepare_zero_front(con, resid); > - if (middle_len(con->out_msg)) > - prepare_zero_middle(con, middle_len(con->out_msg)); > + prepare_zero_front(con, msg, resid); > + if (middle_len(msg)) > + prepare_zero_middle(con, msg, middle_len(msg)); > con->v2.out_iter.count -= CEPH_EPILOGUE_PLAIN_LEN; > - queue_zeros(con); > + queue_zeros(con, msg); > return; > } > > @@ -3619,9 +3617,9 @@ static void revoke_at_finish_message(struct ceph_connection *con) > if (resid > boundary) { > resid -= boundary; > dout("%s con %p was sending middle\n", __func__, con); > - prepare_zero_middle(con, resid); > + prepare_zero_middle(con, msg, resid); > con->v2.out_iter.count -= CEPH_EPILOGUE_PLAIN_LEN; > - queue_zeros(con); > + queue_zeros(con, msg); > return; > } > > @@ -3629,7 +3627,7 @@ static void revoke_at_finish_message(struct ceph_connection *con) > dout("%s con %p was sending epilogue - noop\n", __func__, con); > } > > -void ceph_con_v2_revoke(struct ceph_connection *con) > +void ceph_con_v2_revoke(struct ceph_connection *con, struct ceph_msg *msg) > { > WARN_ON(con->v2.out_zero); > > @@ -3642,13 +3640,13 @@ void ceph_con_v2_revoke(struct ceph_connection *con) > > switch (con->v2.out_state) { > case OUT_S_QUEUE_DATA: > - revoke_at_queue_data(con); > + revoke_at_queue_data(con, msg); > break; > case OUT_S_QUEUE_DATA_CONT: > - revoke_at_queue_data_cont(con); > + revoke_at_queue_data_cont(con, msg); > break; > case OUT_S_FINISH_MESSAGE: > - revoke_at_finish_message(con); > + revoke_at_finish_message(con, msg); > break; > default: > WARN(1, "bad out_state %d", con->v2.out_state);
On Fri, 2025-08-08 at 17:41 +0000, Viacheslav Dubeyko wrote: > On Wed, 2025-08-06 at 11:48 +0200, Max Kellermann wrote: > > This pointer is in a register anyway, so let's use that instead of > > reloading from memory everywhere. > > > > Signed-off-by: Max Kellermann <max.kellermann@ionos.com> > > Looks good. > > Reviewed-by: Viacheslav Dubeyko <Slava.Dubeyko@ibm.com> > > Tested-by: Viacheslav Dubeyko <Slava.Dubeyko@ibm.com> Thanks, Slava.
© 2016 - 2025 Red Hat, Inc.