Commit 7b862e07 authored by Sage Weil's avatar Sage Weil
Browse files

libceph: verify state after retaking con lock after dispatch

We drop the con mutex when delivering a message.  When we retake the
lock, we need to verify we are still in the OPEN state before
preparing to read the next tag, or else we risk stepping on a
connection that has been closed.
Signed-off-by: default avatarSage Weil <>
Reviewed-by: default avatarAlex Elder <>
parent 4f471e4a
......@@ -2003,7 +2003,6 @@ static void process_message(struct ceph_connection *con)
con->ops->dispatch(con, msg);
......@@ -2213,6 +2212,8 @@ more:
if (con->in_tag == CEPH_MSGR_TAG_READY)
goto more;
if (con->state == CON_STATE_OPEN)
goto more;
if (con->in_tag == CEPH_MSGR_TAG_ACK) {
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