mirror of
https://github.com/dashpay/dash.git
synced 2024-12-28 05:23:01 +01:00
Merge #10061: [net] Added SetSocketNoDelay() utility function
ad415bc
[net] Added SetSocketNoDelay() utility function (Thomas Snider)
Tree-SHA512: c19e3c9910b3fc2ef86f2434f3e91d343e9cd9e2116153941de9789e2a6fc0389bffe762d21b55cda4a4b1de993afee0564c6946e65d05cef9e866b58896f9af
This commit is contained in:
commit
ae786098bc
@ -1071,12 +1071,7 @@ void CConnman::AcceptConnection(const ListenSocket& hListenSocket) {
|
|||||||
|
|
||||||
// According to the internet TCP_NODELAY is not carried into accepted sockets
|
// According to the internet TCP_NODELAY is not carried into accepted sockets
|
||||||
// on all platforms. Set it again here just to be sure.
|
// on all platforms. Set it again here just to be sure.
|
||||||
int set = 1;
|
SetSocketNoDelay(hSocket);
|
||||||
#ifdef WIN32
|
|
||||||
setsockopt(hSocket, IPPROTO_TCP, TCP_NODELAY, (const char*)&set, sizeof(int));
|
|
||||||
#else
|
|
||||||
setsockopt(hSocket, IPPROTO_TCP, TCP_NODELAY, (void*)&set, sizeof(int));
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (IsBanned(addr) && !whitelisted)
|
if (IsBanned(addr) && !whitelisted)
|
||||||
{
|
{
|
||||||
|
@ -428,18 +428,14 @@ bool static ConnectSocketDirectly(const CService &addrConnect, SOCKET& hSocketRe
|
|||||||
if (hSocket == INVALID_SOCKET)
|
if (hSocket == INVALID_SOCKET)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
int set = 1;
|
|
||||||
#ifdef SO_NOSIGPIPE
|
#ifdef SO_NOSIGPIPE
|
||||||
|
int set = 1;
|
||||||
// Different way of disabling SIGPIPE on BSD
|
// Different way of disabling SIGPIPE on BSD
|
||||||
setsockopt(hSocket, SOL_SOCKET, SO_NOSIGPIPE, (void*)&set, sizeof(int));
|
setsockopt(hSocket, SOL_SOCKET, SO_NOSIGPIPE, (void*)&set, sizeof(int));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//Disable Nagle's algorithm
|
//Disable Nagle's algorithm
|
||||||
#ifdef WIN32
|
SetSocketNoDelay(hSocket);
|
||||||
setsockopt(hSocket, IPPROTO_TCP, TCP_NODELAY, (const char*)&set, sizeof(int));
|
|
||||||
#else
|
|
||||||
setsockopt(hSocket, IPPROTO_TCP, TCP_NODELAY, (void*)&set, sizeof(int));
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Set to non-blocking
|
// Set to non-blocking
|
||||||
if (!SetSocketNonBlocking(hSocket, true))
|
if (!SetSocketNonBlocking(hSocket, true))
|
||||||
@ -728,6 +724,13 @@ bool SetSocketNonBlocking(SOCKET& hSocket, bool fNonBlocking)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool SetSocketNoDelay(SOCKET& hSocket)
|
||||||
|
{
|
||||||
|
int set = 1;
|
||||||
|
int rc = setsockopt(hSocket, IPPROTO_TCP, TCP_NODELAY, (const char*)&set, sizeof(int));
|
||||||
|
return rc == 0;
|
||||||
|
}
|
||||||
|
|
||||||
void InterruptSocks5(bool interrupt)
|
void InterruptSocks5(bool interrupt)
|
||||||
{
|
{
|
||||||
interruptSocks5Recv = interrupt;
|
interruptSocks5Recv = interrupt;
|
||||||
|
@ -59,6 +59,8 @@ std::string NetworkErrorString(int err);
|
|||||||
bool CloseSocket(SOCKET& hSocket);
|
bool CloseSocket(SOCKET& hSocket);
|
||||||
/** Disable or enable blocking-mode for a socket */
|
/** Disable or enable blocking-mode for a socket */
|
||||||
bool SetSocketNonBlocking(SOCKET& hSocket, bool fNonBlocking);
|
bool SetSocketNonBlocking(SOCKET& hSocket, bool fNonBlocking);
|
||||||
|
/** Set the TCP_NODELAY flag on a socket */
|
||||||
|
bool SetSocketNoDelay(SOCKET& hSocket);
|
||||||
/**
|
/**
|
||||||
* Convert milliseconds to a struct timeval for e.g. select.
|
* Convert milliseconds to a struct timeval for e.g. select.
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user