From 840b347bb24bea09f9824891239929cdce84e47b Mon Sep 17 00:00:00 2001 From: Valentin Bartenev Date: Wed, 27 Aug 2014 20:51:01 +0400 Subject: Fixed counting of sent bytes in the send chain functions on EINTR. Previously, a value of the "send" variable wasn't properly adjusted in a rare case when syscall was interrupted by a signal. As a result, these functions could send less data than the limit allows. --- src/os/unix/ngx_linux_sendfile_chain.c | 1 + 1 file changed, 1 insertion(+) (limited to 'src/os/unix/ngx_linux_sendfile_chain.c') diff --git a/src/os/unix/ngx_linux_sendfile_chain.c b/src/os/unix/ngx_linux_sendfile_chain.c index 1060852a0..60867c51e 100644 --- a/src/os/unix/ngx_linux_sendfile_chain.c +++ b/src/os/unix/ngx_linux_sendfile_chain.c @@ -316,6 +316,7 @@ ngx_linux_sendfile_chain(ngx_connection_t *c, ngx_chain_t *in, off_t limit) in = ngx_handle_sent_chain(in, sent); if (eintr) { + send = prev_send; continue; } -- cgit v1.2.3