summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/mgmt_msg.c12
-rw-r--r--lib/mgmt_msg.h2
2 files changed, 9 insertions, 5 deletions
diff --git a/lib/mgmt_msg.c b/lib/mgmt_msg.c
index ba69c20aba..ee5c1008bd 100644
--- a/lib/mgmt_msg.c
+++ b/lib/mgmt_msg.c
@@ -548,20 +548,26 @@ int msg_conn_send_msg(struct msg_conn *conn, uint8_t version, void *msg,
if (conn->remote_conn && short_circuit_ok) {
uint8_t *buf = msg;
size_t n = mlen;
+ bool old;
if (packf) {
buf = XMALLOC(MTYPE_TMP, mlen);
n = packf(msg, buf);
}
+ ++conn->short_circuit_depth;
MGMT_MSG_DBG(dbgtag, "SC send: depth %u msg: %p",
- ++conn->short_circuit_depth, msg);
+ conn->short_circuit_depth, msg);
+ old = conn->remote_conn->is_short_circuit;
+ conn->remote_conn->is_short_circuit = true;
conn->remote_conn->handle_msg(version, buf, n,
conn->remote_conn);
+ conn->remote_conn->is_short_circuit = old;
+ --conn->short_circuit_depth;
MGMT_MSG_DBG(dbgtag, "SC return from depth: %u msg: %p",
- conn->short_circuit_depth--, msg);
+ conn->short_circuit_depth, msg);
if (packf)
XFREE(MTYPE_TMP, buf);
@@ -661,12 +667,10 @@ static bool msg_client_connect_short_circuit(struct msg_client *client)
set_nonblocking(sockets[0]);
setsockopt_so_sendbuf(sockets[0], client->conn.mstate.max_write_buf);
setsockopt_so_recvbuf(sockets[0], client->conn.mstate.max_read_buf);
- client->conn.is_short_circuit = true;
/* server side */
memset(&su, 0, sizeof(union sockunion));
server_conn = server->create(sockets[1], &su);
- server_conn->is_short_circuit = true;
client->conn.remote_conn = server_conn;
server_conn->remote_conn = &client->conn;
diff --git a/lib/mgmt_msg.h b/lib/mgmt_msg.h
index 9fdcb9ecd3..dd7ae59f91 100644
--- a/lib/mgmt_msg.h
+++ b/lib/mgmt_msg.h
@@ -98,8 +98,8 @@ struct msg_conn {
struct msg_conn *conn);
void *user;
uint short_circuit_depth;
+ bool is_short_circuit; /* true when the message being handled is SC */
bool is_client;
- bool is_short_circuit;
bool debug;
};