diff options
author | Max Romanov <max.romanov@nginx.com> | 2018-03-21 16:55:09 +0300 |
---|---|---|
committer | Max Romanov <max.romanov@nginx.com> | 2018-03-21 16:55:09 +0300 |
commit | 778a90c319e47f688b749e43df33f3eb9dce3e72 (patch) | |
tree | 115b9ddb324332619f051c0ebe07472f1838fdf7 /src/nxt_port_rpc.c | |
parent | b865db1bb74e821ff413a62089d699ed30905dd6 (diff) | |
download | unit-778a90c319e47f688b749e43df33f3eb9dce3e72.tar.gz unit-778a90c319e47f688b749e43df33f3eb9dce3e72.tar.bz2 |
Triggering RPC error for all handlers on port close.
This is required to avoid crashes and memory leaks on Unit exit.
Diffstat (limited to 'src/nxt_port_rpc.c')
-rw-r--r-- | src/nxt_port_rpc.c | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/src/nxt_port_rpc.c b/src/nxt_port_rpc.c index b53fbb78..d5ec289c 100644 --- a/src/nxt_port_rpc.c +++ b/src/nxt_port_rpc.c @@ -461,3 +461,41 @@ nxt_port_rpc_cancel(nxt_task_t *task, nxt_port_t *port, uint32_t stream) nxt_port_use(task, port, -1); } + +static nxt_buf_t nxt_port_close_dummy_buf; + +void +nxt_port_rpc_close(nxt_task_t *task, nxt_port_t *port) +{ + nxt_lvlhsh_each_t lhe; + nxt_port_rpc_reg_t *reg; + nxt_port_recv_msg_t msg; + + for ( ;; ) { + nxt_memzero(&lhe, sizeof(nxt_lvlhsh_each_t)); + + lhe.proto = &lvlhsh_rpc_reg_proto; + + reg = nxt_lvlhsh_each(&port->rpc_streams, &lhe); + if (reg == NULL) { + return; + } + + msg.fd = -1; + msg.buf = &nxt_port_close_dummy_buf; + msg.port = port; + msg.port_msg.stream = reg->stream; + msg.port_msg.pid = nxt_pid; + msg.port_msg.type = _NXT_PORT_MSG_RPC_ERROR; + msg.port_msg.last = 1; + msg.port_msg.mmap = 0; + msg.port_msg.nf = 0; + msg.port_msg.mf = 0; + msg.port_msg.tracking = 0; + msg.size = sizeof(msg.port_msg); + msg.cancelled = 0; + msg.u.data = NULL; + + nxt_port_rpc_handler(task, &msg); + } +} |