From: William A. Rowe Jr Date: Mon, 10 Oct 2011 19:02:09 +0000 (+0000) Subject: Resolve server and remote IP's in the AcceptFilter 'none' path. X-Git-Tag: 2.3.15~131 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e1d2cbab6560526a5fed516449257e43c33e6fd2;p=apache Resolve server and remote IP's in the AcceptFilter 'none' path. Lower the volume on a number of debug messages (and omit errno where we have no errno). git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1181140 13f79535-47bb-0310-9956-ffa450edef68 --- diff --git a/CHANGES b/CHANGES index 28db55e03e..5830cc5cb7 100644 --- a/CHANGES +++ b/CHANGES @@ -12,6 +12,9 @@ Changes with Apache 2.3.15 PR 51714. [Stefan Fritsch, Jim Jagielski, Ruediger Pluem, Eric Covener, ] + *) mpm_winnt: Handle AcceptFilter 'none' mode correctly; resolve specific + server IP endpoint and remote client IP upon connection. [William Rowe] + *) mod_setenvif: Remove OID match which is obsoleted by SetEnvIfExpr with PeerExtList(). [Stefan Fritsch] diff --git a/server/mpm/winnt/child.c b/server/mpm/winnt/child.c index 3a99291d2b..5716d3bb6d 100644 --- a/server/mpm/winnt/child.c +++ b/server/mpm/winnt/child.c @@ -305,8 +305,7 @@ static unsigned int __stdcall winnt_accept(void *lr_) else { accf = 0; accf_name = "none"; - ap_log_error(APLOG_MARK, APLOG_WARNING, apr_get_netos_error(), - ap_server_conf, + ap_log_error(APLOG_MARK, APLOG_WARNING, 0, ap_server_conf, "winnt_accept: unrecognized AcceptFilter '%s', " "only 'data', 'connect' or 'none' are valid. " "Using 'none' instead", accf_name); @@ -352,7 +351,7 @@ reinit: /* target of data or connect upon too many AcceptEx failures */ } } - ap_log_error(APLOG_MARK, APLOG_INFO, 0, ap_server_conf, + ap_log_error(APLOG_MARK, APLOG_DEBUG, 0, ap_server_conf, "Child: Accept thread listening on %s:%d using AcceptFilter %s", lr->bind_addr->hostname ? lr->bind_addr->hostname : "*", lr->bind_addr->port, accf_name); @@ -412,10 +411,10 @@ reinit: /* target of data or connect upon too many AcceptEx failures */ if (accf == 2) { /* 'data' */ len = APR_BUCKET_BUFF_SIZE; - buf = apr_bucket_alloc(len, context->ba); /* XXX: check for failure? */ + buf = apr_bucket_alloc(len, context->ba); len -= PADDED_ADDR_SIZE * 2; } - else { + else /* (accf == 1) 'connect' */ { len = 0; buf = context->buff; } @@ -586,9 +585,12 @@ reinit: /* target of data or connect upon too many AcceptEx failures */ break; } - context->sa_client = NULL; context->sa_server = (void *) context->buff; - context->sa_server_len = sizeof(context->buff); + context->sa_server_len = sizeof(context->buff) / 2; + context->sa_client_len = context->sa_server_len; + context->sa_client = (void *) (context->buff + + context->sa_server_len); + context->accept_socket = accept(nlsd, context->sa_server, &context->sa_server_len); @@ -632,6 +634,20 @@ reinit: /* target of data or connect upon too many AcceptEx failures */ WSAEventSelect(context->accept_socket, 0, 0); context->overlapped.Pointer = NULL; err_count = 0; + + context->sa_server_len = sizeof(context->buff) / 2; + if (getsockname(context->accept_socket, context->sa_server, + &context->sa_server_len) == SOCKET_ERROR) { + ap_log_error(APLOG_MARK, APLOG_WARNING, apr_get_netos_error(), ap_server_conf, + "getsockname failed"); + continue; + } + if ((getpeername(context->accept_socket, context->sa_client, + &context->sa_client_len)) == SOCKET_ERROR) { + ap_log_error(APLOG_MARK, APLOG_WARNING, apr_get_netos_error(), ap_server_conf, + "getpeername failed"); + memset(&context->sa_client, '\0', sizeof(context->sa_client)); + } } sockinfo.os_sock = &context->accept_socket; @@ -667,7 +683,7 @@ reinit: /* target of data or connect upon too many AcceptEx failures */ SetEvent(exit_event); } - ap_log_error(APLOG_MARK, APLOG_INFO, APR_SUCCESS, ap_server_conf, + ap_log_error(APLOG_MARK, APLOG_DEBUG, APR_SUCCESS, ap_server_conf, "Child: Accept thread exiting."); return 0; } @@ -1130,7 +1146,7 @@ void child_main(apr_pool_t *pconf) * Post worker threads blocked on the ThreadDispatch IOCompletion port */ while (g_blocked_threads > 0) { - ap_log_error(APLOG_MARK, APLOG_INFO, APR_SUCCESS, ap_server_conf, + ap_log_error(APLOG_MARK, APLOG_DEBUG, APR_SUCCESS, ap_server_conf, "Child: %d threads blocked on the completion port", g_blocked_threads); for (i=g_blocked_threads; i > 0; i--) { diff --git a/server/mpm/winnt/mpm_winnt.c b/server/mpm/winnt/mpm_winnt.c index e15d186ca9..d050d63dbd 100644 --- a/server/mpm/winnt/mpm_winnt.c +++ b/server/mpm/winnt/mpm_winnt.c @@ -505,7 +505,7 @@ static int send_listeners_to_child(apr_pool_t *p, DWORD dwProcessId, apr_os_sock_t nsd; lpWSAProtocolInfo = apr_pcalloc(p, sizeof(WSAPROTOCOL_INFO)); apr_os_sock_get(&nsd, lr->sd); - ap_log_error(APLOG_MARK, APLOG_INFO, APR_SUCCESS, ap_server_conf, + ap_log_error(APLOG_MARK, APLOG_DEBUG, APR_SUCCESS, ap_server_conf, "Parent: Duplicating socket %d (%pI) and sending it to child process %lu", nsd, lr->bind_addr, dwProcessId); if (WSADuplicateSocket(nsd, dwProcessId,