mirror of
https://github.com/openvswitch/ovs
synced 2025-10-23 14:57:06 +00:00
netlink-socket: Do not make flow_dump block on netlink socket.
Commit 93295354
(netlink-socket: Simplify multithreaded dumping
to match Linux reality.) makes the call to recvmsg() block if no
messages are available. This can cause revalidator threads hanging
for long time or even deadlock when main thread tries to stop the
revalidator threads.
This commit fixes the issue by enabling the MSG_DONTWAIT flag in
the call to recvmsg().
Signed-off-by: Alex Wang <alexw@nicira.com>
Acked-by: Ben Pfaff <blp@nicira.com>
This commit is contained in:
@@ -724,9 +724,15 @@ nl_dump_refill(struct nl_dump *dump, struct ofpbuf *buffer)
|
|||||||
int error;
|
int error;
|
||||||
|
|
||||||
while (!ofpbuf_size(buffer)) {
|
while (!ofpbuf_size(buffer)) {
|
||||||
error = nl_sock_recv__(dump->sock, buffer, true);
|
error = nl_sock_recv__(dump->sock, buffer, false);
|
||||||
if (error) {
|
if (error) {
|
||||||
/* The kernel shouldn't return EAGAIN while there's data left. */
|
/* The kernel never blocks providing the results of a dump, so
|
||||||
|
* error == EAGAIN means that we've read the whole thing, and
|
||||||
|
* therefore transform it into EOF. (The kernel always provides
|
||||||
|
* NLMSG_DONE as a sentinel. Some other thread must have received
|
||||||
|
* that already but not yet signaled it in 'status'.)
|
||||||
|
*
|
||||||
|
* Any other error is just an error. */
|
||||||
return error == EAGAIN ? EOF : error;
|
return error == EAGAIN ? EOF : error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user