Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
L
libzmq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
libzmq
Commits
3730833f
Unverified
Commit
3730833f
authored
May 23, 2018
by
Luca Boccassi
Committed by
GitHub
May 23, 2018
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #3125 from sigiesec/improve-socket-inheritance
Improve socket inheritance handling
parents
44b0753c
2d9a8955
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
48 additions
and
81 deletions
+48
-81
ip.cpp
src/ip.cpp
+36
-32
ip.hpp
src/ip.hpp
+4
-0
ipc_listener.cpp
src/ipc_listener.cpp
+1
-7
socks_connecter.cpp
src/socks_connecter.cpp
+1
-6
tcp_connecter.cpp
src/tcp_connecter.cpp
+1
-7
tcp_listener.cpp
src/tcp_listener.cpp
+5
-29
No files found.
src/ip.cpp
View file @
3730833f
...
@@ -80,28 +80,22 @@ zmq::fd_t zmq::open_socket (int domain_, int type_, int protocol_)
...
@@ -80,28 +80,22 @@ zmq::fd_t zmq::open_socket (int domain_, int type_, int protocol_)
type_
|=
SOCK_CLOEXEC
;
type_
|=
SOCK_CLOEXEC
;
#endif
#endif
fd_t
s
=
socket
(
domain_
,
type_
,
protocol_
);
#if defined ZMQ_HAVE_WINDOWS && defined WSA_FLAG_NO_HANDLE_INHERIT
#ifdef ZMQ_HAVE_WINDOWS
// if supported, create socket with WSA_FLAG_NO_HANDLE_INHERIT, such that
if
(
s
==
INVALID_SOCKET
)
// the race condition in making it non-inheritable later is avoided
return
INVALID_SOCKET
;
const
fd_t
s
=
WSASocket
(
domain_
,
type_
,
protocol_
,
NULL
,
0
,
WSA_FLAG_NO_HANDLE_INHERIT
);
#else
#else
if
(
s
==
-
1
)
const
fd_t
s
=
socket
(
domain_
,
type_
,
protocol_
);
return
-
1
;
#endif
#endif
if
(
s
==
retired_fd
)
{
// If there's no SOCK_CLOEXEC, let's try the second best option. Note that
#ifdef ZMQ_HAVE_WINDOWS
// race condition can cause socket not to be closed (if fork happens
errno
=
wsa_error_to_errno
(
WSAGetLastError
());
// between socket creation and this point).
#if !defined ZMQ_HAVE_SOCK_CLOEXEC && defined FD_CLOEXEC
rc
=
fcntl
(
s
,
F_SETFD
,
FD_CLOEXEC
);
errno_assert
(
rc
!=
-
1
);
#endif
#endif
return
retired_fd
;
}
// On Windows, preventing sockets to be inherited by child processes.
make_socket_noninheritable
(
s
);
#if defined ZMQ_HAVE_WINDOWS && defined HANDLE_FLAG_INHERIT
BOOL
brc
=
SetHandleInformation
((
HANDLE
)
s
,
HANDLE_FLAG_INHERIT
,
0
);
win_assert
(
brc
);
#endif
// Socket is not yet connected so EINVAL is not a valid networking error
// Socket is not yet connected so EINVAL is not a valid networking error
rc
=
zmq
::
set_nosigpipe
(
s
);
rc
=
zmq
::
set_nosigpipe
(
s
);
...
@@ -530,11 +524,7 @@ int zmq::make_fdpair (fd_t *r_, fd_t *w_)
...
@@ -530,11 +524,7 @@ int zmq::make_fdpair (fd_t *r_, fd_t *w_)
}
}
if
(
*
r_
!=
INVALID_SOCKET
)
{
if
(
*
r_
!=
INVALID_SOCKET
)
{
#if !defined _WIN32_WCE && !defined ZMQ_HAVE_WINDOWS_UWP
make_socket_noninheritable
(
*
r_
);
// On Windows, preventing sockets to be inherited by child processes.
BOOL
brc
=
SetHandleInformation
((
HANDLE
)
*
r_
,
HANDLE_FLAG_INHERIT
,
0
);
win_assert
(
brc
);
#endif
return
0
;
return
0
;
}
else
{
}
else
{
// Cleanup writer if connection failed
// Cleanup writer if connection failed
...
@@ -659,18 +649,32 @@ int zmq::make_fdpair (fd_t *r_, fd_t *w_)
...
@@ -659,18 +649,32 @@ int zmq::make_fdpair (fd_t *r_, fd_t *w_)
*
w_
=
*
r_
=
-
1
;
*
w_
=
*
r_
=
-
1
;
return
-
1
;
return
-
1
;
}
else
{
}
else
{
// If there's no SOCK_CLOEXEC, let's try the second best option. Note that
make_socket_noninheritable
(
sv
[
0
]);
// race condition can cause socket not to be closed (if fork happens
make_socket_noninheritable
(
sv
[
1
]);
// between socket creation and this point).
#if !defined ZMQ_HAVE_SOCK_CLOEXEC && defined FD_CLOEXEC
rc
=
fcntl
(
sv
[
0
],
F_SETFD
,
FD_CLOEXEC
);
errno_assert
(
rc
!=
-
1
);
rc
=
fcntl
(
sv
[
1
],
F_SETFD
,
FD_CLOEXEC
);
errno_assert
(
rc
!=
-
1
);
#endif
*
w_
=
sv
[
0
];
*
w_
=
sv
[
0
];
*
r_
=
sv
[
1
];
*
r_
=
sv
[
1
];
return
0
;
return
0
;
}
}
#endif
#endif
}
}
void
zmq
::
make_socket_noninheritable
(
fd_t
sock
)
{
#if defined ZMQ_HAVE_WINDOWS && !defined _WIN32_WCE \
&& !defined ZMQ_HAVE_WINDOWS_UWP
// On Windows, preventing sockets to be inherited by child processes.
const
BOOL
brc
=
SetHandleInformation
(
reinterpret_cast
<
HANDLE
>
(
sock
),
HANDLE_FLAG_INHERIT
,
0
);
win_assert
(
brc
);
#endif
#if (!defined ZMQ_HAVE_SOCK_CLOEXEC || !defined HAVE_ACCEPT4) \
&& defined FD_CLOEXEC
// If there 's no SOCK_CLOEXEC, let's try the second best option.
// Race condition can cause socket not to be closed (if fork happens
// between accept and this point).
const
int
rc
=
fcntl
(
sock
,
F_SETFD
,
FD_CLOEXEC
);
errno_assert
(
rc
!=
-
1
);
#endif
}
src/ip.hpp
View file @
3730833f
...
@@ -67,6 +67,10 @@ void shutdown_network ();
...
@@ -67,6 +67,10 @@ void shutdown_network ();
// Creates a pair of sockets (using signaler_port on OS using TCP sockets).
// Creates a pair of sockets (using signaler_port on OS using TCP sockets).
// Returns -1 if we could not make the socket pair successfully
// Returns -1 if we could not make the socket pair successfully
int
make_fdpair
(
fd_t
*
r_
,
fd_t
*
w_
);
int
make_fdpair
(
fd_t
*
r_
,
fd_t
*
w_
);
// Makes a socket non-inheritable to child processes.
// Asserts on any failure.
void
make_socket_noninheritable
(
fd_t
sock
);
}
}
#endif
#endif
src/ipc_listener.cpp
View file @
3730833f
...
@@ -403,13 +403,7 @@ zmq::fd_t zmq::ipc_listener_t::accept ()
...
@@ -403,13 +403,7 @@ zmq::fd_t zmq::ipc_listener_t::accept ()
return
retired_fd
;
return
retired_fd
;
}
}
#if (!defined ZMQ_HAVE_SOCK_CLOEXEC || !defined HAVE_ACCEPT4) \
make_socket_noninheritable
(
sock
);
&& defined FD_CLOEXEC
// Race condition can cause socket not to be closed (if fork happens
// between accept and this point).
int
rc
=
fcntl
(
sock
,
F_SETFD
,
FD_CLOEXEC
);
errno_assert
(
rc
!=
-
1
);
#endif
// IPC accept() filters
// IPC accept() filters
#if defined ZMQ_HAVE_SO_PEERCRED || defined ZMQ_HAVE_LOCAL_PEERCRED
#if defined ZMQ_HAVE_SO_PEERCRED || defined ZMQ_HAVE_LOCAL_PEERCRED
...
...
src/socks_connecter.cpp
View file @
3730833f
...
@@ -309,13 +309,8 @@ int zmq::socks_connecter_t::connect_to_proxy ()
...
@@ -309,13 +309,8 @@ int zmq::socks_connecter_t::connect_to_proxy ()
// Create the socket.
// Create the socket.
s
=
open_socket
(
tcp_addr
->
family
(),
SOCK_STREAM
,
IPPROTO_TCP
);
s
=
open_socket
(
tcp_addr
->
family
(),
SOCK_STREAM
,
IPPROTO_TCP
);
#ifdef ZMQ_HAVE_WINDOWS
if
(
s
==
retired_fd
)
if
(
s
==
INVALID_SOCKET
)
return
-
1
;
#else
if
(
s
==
-
1
)
return
-
1
;
return
-
1
;
#endif
// On some systems, IPv4 mapping in IPv6 sockets is disabled by default.
// On some systems, IPv4 mapping in IPv6 sockets is disabled by default.
// Switch it on in such cases.
// Switch it on in such cases.
...
...
src/tcp_connecter.cpp
View file @
3730833f
...
@@ -283,15 +283,9 @@ int zmq::tcp_connecter_t::open ()
...
@@ -283,15 +283,9 @@ int zmq::tcp_connecter_t::open ()
s
=
open_socket
(
AF_INET
,
SOCK_STREAM
,
IPPROTO_TCP
);
s
=
open_socket
(
AF_INET
,
SOCK_STREAM
,
IPPROTO_TCP
);
}
}
#ifdef ZMQ_HAVE_WINDOWS
if
(
s
==
retired_fd
)
{
if
(
s
==
INVALID_SOCKET
)
{
errno
=
wsa_error_to_errno
(
WSAGetLastError
());
return
-
1
;
return
-
1
;
}
}
#else
if
(
s
==
-
1
)
return
-
1
;
#endif
// On some systems, IPv4 mapping in IPv6 sockets is disabled by default.
// On some systems, IPv4 mapping in IPv6 sockets is disabled by default.
// Switch it on in such cases.
// Switch it on in such cases.
...
...
src/tcp_listener.cpp
View file @
3730833f
...
@@ -195,20 +195,10 @@ int zmq::tcp_listener_t::set_address (const char *addr_)
...
@@ -195,20 +195,10 @@ int zmq::tcp_listener_t::set_address (const char *addr_)
s
=
open_socket
(
AF_INET
,
SOCK_STREAM
,
IPPROTO_TCP
);
s
=
open_socket
(
AF_INET
,
SOCK_STREAM
,
IPPROTO_TCP
);
}
}
#ifdef ZMQ_HAVE_WINDOWS
if
(
s
==
retired_fd
)
{
if
(
s
==
INVALID_SOCKET
)
{
errno
=
wsa_error_to_errno
(
WSAGetLastError
());
return
-
1
;
return
-
1
;
}
}
#if !defined _WIN32_WCE && !defined ZMQ_HAVE_WINDOWS_UWP
make_socket_noninheritable
(
s
);
// On Windows, preventing sockets to be inherited by child processes.
BOOL
brc
=
SetHandleInformation
((
HANDLE
)
s
,
HANDLE_FLAG_INHERIT
,
0
);
win_assert
(
brc
);
#endif
#else
if
(
s
==
-
1
)
return
-
1
;
#endif
// On some systems, IPv4 mapping in IPv6 sockets is disabled by default.
// On some systems, IPv4 mapping in IPv6 sockets is disabled by default.
// Switch it on in such cases.
// Switch it on in such cases.
...
@@ -306,35 +296,21 @@ zmq::fd_t zmq::tcp_listener_t::accept ()
...
@@ -306,35 +296,21 @@ zmq::fd_t zmq::tcp_listener_t::accept ()
::
accept
(
s
,
reinterpret_cast
<
struct
sockaddr
*>
(
&
ss
),
&
ss_len
);
::
accept
(
s
,
reinterpret_cast
<
struct
sockaddr
*>
(
&
ss
),
&
ss_len
);
#endif
#endif
if
(
sock
==
retired_fd
)
{
#ifdef ZMQ_HAVE_WINDOWS
#ifdef ZMQ_HAVE_WINDOWS
if
(
sock
==
INVALID_SOCKET
)
{
const
int
last_error
=
WSAGetLastError
();
const
int
last_error
=
WSAGetLastError
();
wsa_assert
(
last_error
==
WSAEWOULDBLOCK
||
last_error
==
WSAECONNRESET
wsa_assert
(
last_error
==
WSAEWOULDBLOCK
||
last_error
==
WSAECONNRESET
||
last_error
==
WSAEMFILE
||
last_error
==
WSAENOBUFS
);
||
last_error
==
WSAEMFILE
||
last_error
==
WSAENOBUFS
);
return
retired_fd
;
}
#if !defined _WIN32_WCE && !defined ZMQ_HAVE_WINDOWS_UWP
// On Windows, preventing sockets to be inherited by child processes.
BOOL
brc
=
SetHandleInformation
((
HANDLE
)
sock
,
HANDLE_FLAG_INHERIT
,
0
);
win_assert
(
brc
);
#endif
#else
#else
if
(
sock
==
-
1
)
{
errno_assert
(
errno
==
EAGAIN
||
errno
==
EWOULDBLOCK
||
errno
==
EINTR
errno_assert
(
errno
==
EAGAIN
||
errno
==
EWOULDBLOCK
||
errno
==
EINTR
||
errno
==
ECONNABORTED
||
errno
==
EPROTO
||
errno
==
ECONNABORTED
||
errno
==
EPROTO
||
errno
==
ENOBUFS
||
errno
==
ENOMEM
||
errno
==
EMFILE
||
errno
==
ENOBUFS
||
errno
==
ENOMEM
||
errno
==
EMFILE
||
errno
==
ENFILE
);
||
errno
==
ENFILE
);
#endif
return
retired_fd
;
return
retired_fd
;
}
}
#endif
#if (!defined ZMQ_HAVE_SOCK_CLOEXEC || !defined HAVE_ACCEPT4) \
make_socket_noninheritable
(
sock
);
&& defined FD_CLOEXEC
// Race condition can cause socket not to be closed (if fork happens
// between accept and this point).
int
rc
=
fcntl
(
sock
,
F_SETFD
,
FD_CLOEXEC
);
errno_assert
(
rc
!=
-
1
);
#endif
if
(
!
options
.
tcp_accept_filters
.
empty
())
{
if
(
!
options
.
tcp_accept_filters
.
empty
())
{
bool
matched
=
false
;
bool
matched
=
false
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment