diff options
-rw-r--r-- | src/nxt_conn.c | 18 | ||||
-rw-r--r-- | src/nxt_conn_close.c | 14 |
2 files changed, 16 insertions, 16 deletions
diff --git a/src/nxt_conn.c b/src/nxt_conn.c index 0cc052e8..5d84cbb4 100644 --- a/src/nxt_conn.c +++ b/src/nxt_conn.c @@ -96,10 +96,13 @@ nxt_conn_create(nxt_mp_t *mp, nxt_task_t *task) void nxt_conn_io_shutdown(nxt_task_t *task, void *obj, void *data) { - int ret; - socklen_t len; - nxt_conn_t *c; - struct linger linger; + int ret; + nxt_conn_t *c; + + static const struct linger linger_off = { + .l_onoff = 1, + .l_linger = 0, + }; c = obj; @@ -111,11 +114,8 @@ nxt_conn_io_shutdown(nxt_task_t *task, void *obj, void *data) * releases kernel memory associated with socket. * This also causes sending TCP/IP RST to a peer. */ - linger.l_onoff = 1; - linger.l_linger = 0; - len = sizeof(struct linger); - - ret = setsockopt(c->socket.fd, SOL_SOCKET, SO_LINGER, &linger, len); + ret = setsockopt(c->socket.fd, SOL_SOCKET, SO_LINGER, &linger_off, + sizeof(struct linger)); if (nxt_slow_path(ret != 0)) { nxt_log(task, NXT_LOG_CRIT, "setsockopt(%d, SO_LINGER) failed %E", diff --git a/src/nxt_conn_close.c b/src/nxt_conn_close.c index fb86d052..dc4a19c8 100644 --- a/src/nxt_conn_close.c +++ b/src/nxt_conn_close.c @@ -19,11 +19,14 @@ void nxt_conn_close(nxt_event_engine_t *engine, nxt_conn_t *c) { int ret; - socklen_t len; - struct linger linger; nxt_work_queue_t *wq; nxt_work_handler_t handler; + static const struct linger linger_off = { + .l_onoff = 1, + .l_linger = 0, + }; + nxt_debug(c->socket.task, "conn close fd:%d, to:%d", c->socket.fd, c->socket.timedout); @@ -33,11 +36,8 @@ nxt_conn_close(nxt_event_engine_t *engine, nxt_conn_t *c) * releases kernel memory associated with socket. * This also causes sending TCP/IP RST to a peer. */ - linger.l_onoff = 1; - linger.l_linger = 0; - len = sizeof(struct linger); - - ret = setsockopt(c->socket.fd, SOL_SOCKET, SO_LINGER, &linger, len); + ret = setsockopt(c->socket.fd, SOL_SOCKET, SO_LINGER, &linger_off, + sizeof(struct linger)); if (nxt_slow_path(ret != 0)) { nxt_log(c->socket.task, NXT_LOG_CRIT, |