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
d66c2508
Commit
d66c2508
authored
Apr 10, 2017
by
Luca Boccassi
Committed by
GitHub
Apr 10, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2519 from bjovke/master
Case found not covered in latest zmq::proxy() code.
parents
64807214
b6fb1f64
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
50 additions
and
18 deletions
+50
-18
JohanMabille.md
RELICENSE/JohanMabille.md
+0
-0
StoianIvanov.md
RELICENSE/StoianIvanov.md
+0
-0
eburkitt.md
RELICENSE/eburkitt.md
+0
-0
fidlej.md
RELICENSE/fidlej.md
+0
-0
michael-fox.md
RELICENSE/michael-fox.md
+0
-0
proxy.cpp
src/proxy.cpp
+50
-18
No files found.
RELICENSE/JohanMabille
→
RELICENSE/JohanMabille
.md
View file @
d66c2508
File moved
RELICENSE/StoianIvanov
→
RELICENSE/StoianIvanov
.md
View file @
d66c2508
File moved
RELICENSE/eburkitt.
txt
→
RELICENSE/eburkitt.
md
View file @
d66c2508
File moved
RELICENSE/fidlej.
txt
→
RELICENSE/fidlej.
md
View file @
d66c2508
File moved
RELICENSE/michael-fox.
txt
→
RELICENSE/michael-fox.
md
View file @
d66c2508
File moved
src/proxy.cpp
View file @
d66c2508
...
@@ -66,13 +66,17 @@
...
@@ -66,13 +66,17 @@
delete poller_receive_blocked;\
delete poller_receive_blocked;\
delete poller_send_blocked;\
delete poller_send_blocked;\
delete poller_both_blocked;\
delete poller_both_blocked;\
delete poller_frontend_only;\
delete poller_backend_only\
#define CHECK_RC_EXIT_ON_FAILURE()\
#define CHECK_RC_EXIT_ON_FAILURE()\
if (rc < 0) {\
do {\
PROXY_CLEANUP();\
if (rc < 0) {\
return close_and_return (&msg, -1);\
PROXY_CLEANUP();\
}
return close_and_return (&msg, -1);\
}\
} while(0)
#endif // ZMQ_HAVE_POLLER
#endif // ZMQ_HAVE_POLLER
...
@@ -173,14 +177,18 @@ int zmq::proxy (
...
@@ -173,14 +177,18 @@ int zmq::proxy (
// If frontend_==backend_ 'poller_send_blocked' and 'poller_receive_blocked' are the same, 'ZMQ_POLLIN' is ignored.
// If frontend_==backend_ 'poller_send_blocked' and 'poller_receive_blocked' are the same, 'ZMQ_POLLIN' is ignored.
// In that case 'poller_send_blocked' is not used. We need only 'poller_receive_blocked'.
// In that case 'poller_send_blocked' is not used. We need only 'poller_receive_blocked'.
// We also don't need 'poller_both_blocked', no need to initialize it.
// We also don't need 'poller_both_blocked',
'poller_backend_only' nor 'poller_frontend_only'
no need to initialize it.
// We save some RAM and time for initialization.
// We save some RAM and time for initialization.
zmq
::
socket_poller_t
*
poller_send_blocked
=
NULL
;
// All except 'ZMQ_POLLIN' on 'backend_'.
zmq
::
socket_poller_t
*
poller_send_blocked
=
NULL
;
// All except 'ZMQ_POLLIN' on 'backend_'.
zmq
::
socket_poller_t
*
poller_both_blocked
=
NULL
;
// All except 'ZMQ_POLLIN' on both 'frontend_' and 'backend_'.
zmq
::
socket_poller_t
*
poller_both_blocked
=
NULL
;
// All except 'ZMQ_POLLIN' on both 'frontend_' and 'backend_'.
zmq
::
socket_poller_t
*
poller_frontend_only
=
NULL
;
// Only 'ZMQ_POLLIN' and 'ZMQ_POLLOUT' on 'frontend_'.
zmq
::
socket_poller_t
*
poller_backend_only
=
NULL
;
// Only 'ZMQ_POLLIN' and 'ZMQ_POLLOUT' on 'backend_'.
if
(
frontend_
!=
backend_
)
{
if
(
frontend_
!=
backend_
)
{
poller_send_blocked
=
new
(
std
::
nothrow
)
zmq
::
socket_poller_t
;
// All except 'ZMQ_POLLIN' on 'backend_'.
poller_send_blocked
=
new
(
std
::
nothrow
)
zmq
::
socket_poller_t
;
// All except 'ZMQ_POLLIN' on 'backend_'.
poller_both_blocked
=
new
(
std
::
nothrow
)
zmq
::
socket_poller_t
;
// All except 'ZMQ_POLLIN' on both 'frontend_' and 'backend_'.
poller_both_blocked
=
new
(
std
::
nothrow
)
zmq
::
socket_poller_t
;
// All except 'ZMQ_POLLIN' on both 'frontend_' and 'backend_'.
poller_frontend_only
=
new
(
std
::
nothrow
)
zmq
::
socket_poller_t
;
// Only 'ZMQ_POLLIN' and 'ZMQ_POLLOUT' on 'frontend_'.
poller_backend_only
=
new
(
std
::
nothrow
)
zmq
::
socket_poller_t
;
// Only 'ZMQ_POLLIN' and 'ZMQ_POLLOUT' on 'backend_'.
frontend_equal_to_backend
=
false
;
frontend_equal_to_backend
=
false
;
}
else
}
else
frontend_equal_to_backend
=
true
;
frontend_equal_to_backend
=
true
;
...
@@ -222,6 +230,10 @@ int zmq::proxy (
...
@@ -222,6 +230,10 @@ int zmq::proxy (
CHECK_RC_EXIT_ON_FAILURE
();
CHECK_RC_EXIT_ON_FAILURE
();
rc
=
poller_receive_blocked
->
add
(
backend_
,
NULL
,
ZMQ_POLLIN
|
ZMQ_POLLOUT
);
// All except 'ZMQ_POLLIN' on 'frontend_'.
rc
=
poller_receive_blocked
->
add
(
backend_
,
NULL
,
ZMQ_POLLIN
|
ZMQ_POLLOUT
);
// All except 'ZMQ_POLLIN' on 'frontend_'.
CHECK_RC_EXIT_ON_FAILURE
();
CHECK_RC_EXIT_ON_FAILURE
();
rc
=
poller_frontend_only
->
add
(
frontend_
,
NULL
,
ZMQ_POLLIN
|
ZMQ_POLLOUT
);
CHECK_RC_EXIT_ON_FAILURE
();
rc
=
poller_backend_only
->
add
(
backend_
,
NULL
,
ZMQ_POLLIN
|
ZMQ_POLLOUT
);
CHECK_RC_EXIT_ON_FAILURE
();
}
}
// Register 'control_' with pollers.
// Register 'control_' with pollers.
...
@@ -239,6 +251,10 @@ int zmq::proxy (
...
@@ -239,6 +251,10 @@ int zmq::proxy (
CHECK_RC_EXIT_ON_FAILURE
();
CHECK_RC_EXIT_ON_FAILURE
();
rc
=
poller_both_blocked
->
add
(
control_
,
NULL
,
ZMQ_POLLIN
);
rc
=
poller_both_blocked
->
add
(
control_
,
NULL
,
ZMQ_POLLIN
);
CHECK_RC_EXIT_ON_FAILURE
();
CHECK_RC_EXIT_ON_FAILURE
();
rc
=
poller_frontend_only
->
add
(
control_
,
NULL
,
ZMQ_POLLIN
);
CHECK_RC_EXIT_ON_FAILURE
();
rc
=
poller_backend_only
->
add
(
control_
,
NULL
,
ZMQ_POLLIN
);
CHECK_RC_EXIT_ON_FAILURE
();
}
}
}
}
...
@@ -342,34 +358,50 @@ int zmq::proxy (
...
@@ -342,34 +358,50 @@ int zmq::proxy (
if
(
poller_wait
==
poller_both_blocked
)
if
(
poller_wait
==
poller_both_blocked
)
poller_wait
=
poller_send_blocked
;
poller_wait
=
poller_send_blocked
;
else
else
if
(
poller_wait
==
poller_receive_blocked
)
if
(
poller_wait
==
poller_receive_blocked
||
poller_wait
==
poller_frontend_only
)
poller_wait
=
poller_in
;
poller_wait
=
poller_in
;
}
}
if
(
reply_processed
)
{
// 'backend_' -> 'frontend_'
if
(
reply_processed
)
{
// 'backend_' -> 'frontend_'
if
(
poller_wait
==
poller_both_blocked
)
if
(
poller_wait
==
poller_both_blocked
)
poller_wait
=
poller_receive_blocked
;
poller_wait
=
poller_receive_blocked
;
else
else
if
(
poller_wait
==
poller_send_blocked
)
if
(
poller_wait
==
poller_send_blocked
||
poller_wait
==
poller_backend_only
)
poller_wait
=
poller_in
;
poller_wait
=
poller_in
;
}
}
}
}
}
else
{
}
else
{
// No requests have been processed, there were no 'ZMQ_POLLOUT' events.
// No requests have been processed, there were no 'ZMQ_POLLIN' with corresponding 'ZMQ_POLLOUT' events.
// That means that receiving end queue(s) is/are full.
// That means that out queue(s) is/are full or one out queue is full and second one has no messages to process.
// Disable receiving 'ZMQ_POLLIN' for sockets for which there's no 'ZMQ_POLLOUT'.
// Disable receiving 'ZMQ_POLLIN' for sockets for which there's no 'ZMQ_POLLOUT',
// or wait only on both 'backend_''s or 'frontend_''s 'ZMQ_POLLIN' and 'ZMQ_POLLOUT'.
if
(
frontend_in
)
{
if
(
frontend_in
)
{
if
(
poller_wait
==
poller_send_blocked
)
if
(
frontend_out
)
poller_wait
=
poller_both_blocked
;
// If frontend_in and frontend_out are true, obviously backend_in and backend_out are both false.
else
// In that case we need to wait for both 'ZMQ_POLLIN' and 'ZMQ_POLLOUT' only on 'backend_'.
poller_wait
=
poller_receive_blocked
;
// We'll never get here in case of frontend_==backend_ because then frontend_out will always be false.
poller_wait
=
poller_backend_only
;
else
{
if
(
poller_wait
==
poller_send_blocked
)
poller_wait
=
poller_both_blocked
;
else
if
(
poller_wait
==
poller_in
)
poller_wait
=
poller_receive_blocked
;
}
}
}
if
(
backend_in
)
{
if
(
backend_in
)
{
// Will never be reached if frontend_==backend_, 'backend_in' will
// Will never be reached if frontend_==backend_, 'backend_in' will
// always be false due to design in 'for' event processing loop.
// always be false due to design in 'for' event processing loop.
if
(
poller_wait
==
poller_receive_blocked
)
if
(
backend_out
)
poller_wait
=
poller_both_blocked
;
// If backend_in and backend_out are true, obviously frontend_in and frontend_out are both false.
else
// In that case we need to wait for both 'ZMQ_POLLIN' and 'ZMQ_POLLOUT' only on 'frontend_'.
poller_wait
=
poller_send_blocked
;
poller_wait
=
poller_frontend_only
;
else
{
if
(
poller_wait
==
poller_receive_blocked
)
poller_wait
=
poller_both_blocked
;
else
if
(
poller_wait
==
poller_in
)
poller_wait
=
poller_send_blocked
;
}
}
}
}
}
...
...
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