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
ca552d56
Commit
ca552d56
authored
Dec 06, 2019
by
Simon Giesecke
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Problem: listener socket uses TCP loopback connections which sometimes go awry
Solution: Use domain sockets instead if available
parent
bd4c2d60
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
86 additions
and
0 deletions
+86
-0
ip.cpp
src/ip.cpp
+86
-0
No files found.
src/ip.cpp
View file @
ca552d56
...
@@ -48,6 +48,9 @@
...
@@ -48,6 +48,9 @@
#include <vector>
#include <vector>
#else
#else
#include "tcp.hpp"
#include "tcp.hpp"
#ifdef ZMQ_HAVE_IPC
#include "ipc_address.hpp"
#endif
#include <direct.h>
#include <direct.h>
#endif
#endif
...
@@ -553,6 +556,89 @@ int zmq::make_fdpair (fd_t *r_, fd_t *w_)
...
@@ -553,6 +556,89 @@ int zmq::make_fdpair (fd_t *r_, fd_t *w_)
}
}
#elif defined ZMQ_HAVE_WINDOWS
#elif defined ZMQ_HAVE_WINDOWS
#ifdef ZMQ_HAVE_IPC
ipc_address_t
address
;
std
::
string
dirname
,
filename
;
// Create a listening socket.
SOCKET
listener
=
open_socket
(
AF_UNIX
,
SOCK_STREAM
,
0
);
if
(
listener
==
retired_fd
)
{
// This may happen if the library was built on a system supporting AF_UNIX, but the system running doesn't support it.
goto
try_tcpip
;
}
create_ipc_wildcard_address
(
dirname
,
filename
);
// Initialise the address structure.
int
rc
=
address
.
resolve
(
filename
.
c_str
());
if
(
rc
!=
0
)
{
goto
error_closelistener
;
}
// Bind the socket to the file path.
rc
=
bind
(
listener
,
const_cast
<
sockaddr
*>
(
address
.
addr
()),
address
.
addrlen
());
if
(
rc
!=
0
)
{
errno
=
wsa_error_to_errno
(
WSAGetLastError
());
goto
error_closelistener
;
}
// Listen for incoming connections.
rc
=
listen
(
listener
,
1
);
if
(
rc
!=
0
)
{
errno
=
wsa_error_to_errno
(
WSAGetLastError
());
goto
error_closelistener
;
}
sockaddr_un
lcladdr
;
socklen_t
lcladdr_len
=
sizeof
lcladdr
;
rc
=
getsockname
(
listener
,
reinterpret_cast
<
struct
sockaddr
*>
(
&
lcladdr
),
&
lcladdr_len
);
wsa_assert
(
rc
!=
-
1
);
// Create the client socket.
*
w_
=
open_socket
(
AF_UNIX
,
SOCK_STREAM
,
0
);
if
(
*
w_
==
-
1
)
{
errno
=
wsa_error_to_errno
(
WSAGetLastError
());
goto
error_closelistener
;
}
// Connect to the remote peer.
rc
=
::
connect
(
*
w_
,
reinterpret_cast
<
const
struct
sockaddr
*>
(
&
lcladdr
),
lcladdr_len
);
if
(
rc
==
-
1
)
{
goto
error_closeclient
;
}
*
r_
=
accept
(
listener
,
NULL
,
NULL
);
errno_assert
(
*
r_
!=
-
1
);
// Close the listener socket, we don't need it anymore.
rc
=
closesocket
(
listener
);
wsa_assert
(
rc
==
0
);
return
0
;
error_closeclient
:
int
saved_errno
=
errno
;
rc
=
closesocket
(
*
w_
);
wsa_assert
(
rc
==
0
);
errno
=
saved_errno
;
error_closelistener
:
saved_errno
=
errno
;
rc
=
closesocket
(
listener
);
wsa_assert
(
rc
==
0
);
errno
=
saved_errno
;
return
-
1
;
try_tcpip
:
// try to fallback to TCP/IP
// TODO: maybe remember this decision permanently?
#endif
return
make_fdpair_tcpip
(
r_
,
w_
);
return
make_fdpair_tcpip
(
r_
,
w_
);
#elif defined ZMQ_HAVE_OPENVMS
#elif defined ZMQ_HAVE_OPENVMS
...
...
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