diff options
author | agl@chromium.org <agl@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-01-20 17:55:48 +0000 |
---|---|---|
committer | agl@chromium.org <agl@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-01-20 17:55:48 +0000 |
commit | 39fbd8e44a232d61ccf690fd1b8109aa7d1b8d49 (patch) | |
tree | 8bf244f0b56a7295b2888c968c3d45b04971c003 /net | |
parent | c84169bd08705c06d029f62a159911e6d696106b (diff) | |
download | chromium_src-39fbd8e44a232d61ccf690fd1b8109aa7d1b8d49.zip chromium_src-39fbd8e44a232d61ccf690fd1b8109aa7d1b8d49.tar.gz chromium_src-39fbd8e44a232d61ccf690fd1b8109aa7d1b8d49.tar.bz2 |
Linux, Mac: disable Nagle.
This is split off from http://codereview.chromium.org/518065 (see that CL for
the review).
TBR=wtc
http://codereview.chromium.org/548087
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@36639 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net')
-rw-r--r-- | net/socket/tcp_client_socket_libevent.cc | 30 |
1 files changed, 24 insertions, 6 deletions
diff --git a/net/socket/tcp_client_socket_libevent.cc b/net/socket/tcp_client_socket_libevent.cc index 107a18b..2c1c73d 100644 --- a/net/socket/tcp_client_socket_libevent.cc +++ b/net/socket/tcp_client_socket_libevent.cc @@ -8,6 +8,7 @@ #include <fcntl.h> #include <netdb.h> #include <sys/socket.h> +#include <netinet/tcp.h> #include "base/eintr_wrapper.h" #include "base/message_loop.h" @@ -31,10 +32,19 @@ const int kInvalidSocket = -1; // Return 0 on success, -1 on failure. // Too small a function to bother putting in a library? int SetNonBlocking(int fd) { - int flags = fcntl(fd, F_GETFL, 0); - if (-1 == flags) - return flags; - return fcntl(fd, F_SETFL, flags | O_NONBLOCK); + int flags = fcntl(fd, F_GETFL, 0); + if (-1 == flags) + return flags; + return fcntl(fd, F_SETFL, flags | O_NONBLOCK); +} + +// DisableNagle turns off buffering in the kernel. By default, TCP sockets will +// wait up to 200ms for more data to complete a packet before transmitting. +// After calling this function, the kernel will not wait. See TCP_NODELAY in +// `man 7 tcp`. +int DisableNagle(int fd) { + int on = 1; + return setsockopt(fd, IPPROTO_TCP, TCP_NODELAY, &on, sizeof(on)); } // Convert values from <errno.h> to values from "net/base/net_errors.h" @@ -342,8 +352,16 @@ int TCPClientSocketLibevent::CreateSocket(const addrinfo* ai) { if (socket_ == kInvalidSocket) return MapPosixError(errno); - if (SetNonBlocking(socket_)) - return MapPosixError(errno); + if (SetNonBlocking(socket_)) { + const int err = MapPosixError(errno); + close(socket_); + socket_ = kInvalidSocket; + return err; + } + + // This mirrors the behaviour on Windows. See the comment in + // tcp_client_socket_win.cc after searching for "NODELAY". + DisableNagle(socket_); // If DisableNagle fails, we don't care. return OK; } |