diff options
author | Igor Sysoev <igor@sysoev.ru> | 2017-06-29 15:52:47 +0300 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2017-06-29 15:52:47 +0300 |
commit | 499a8f9ac87765252dc3656c7aac900825475a51 (patch) | |
tree | 5667d1128e4d736ffc110e11444f789694b88e94 /src/nxt_conn_close.c | |
parent | 52f79c3e531ec64ddd81e2467e0081616e71a7c8 (diff) | |
download | unit-499a8f9ac87765252dc3656c7aac900825475a51.tar.gz unit-499a8f9ac87765252dc3656c7aac900825475a51.tar.bz2 |
Using static and constant linger structure.
Diffstat (limited to 'src/nxt_conn_close.c')
-rw-r--r-- | src/nxt_conn_close.c | 14 |
1 files changed, 7 insertions, 7 deletions
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, |