summaryrefslogtreecommitdiff
path: root/lib/latch-unix.c
diff options
context:
space:
mode:
authorGurucharan Shetty <gshetty@nicira.com>2014-06-27 13:30:49 -0700
committerGurucharan Shetty <gshetty@nicira.com>2014-06-30 08:47:33 -0700
commit1ca3348ed42ad7fed55c2418fecf8c8eac18de66 (patch)
tree3418d2d0cf10b09b6f8844e79b58ff055f111c3a /lib/latch-unix.c
parent1547f8e33c2e67408dfec0ee48c2a81f8cec498e (diff)
downloadopenvswitch-1ca3348ed42ad7fed55c2418fecf8c8eac18de66.tar.gz
poll-loop: Create Windows event handles for sockets automatically.
We currently have a poll_fd_wait_event(fd, wevent, events) function that is used at places common to Windows and Linux where we have to wait on sockets. On Linux, 'wevent' is always set as zero. On Windows, for sockets, when we send both 'fd' and 'wevent', we associate them with each other for 'events' and then wait on 'wevent'. Also on Windows, when we only send 'wevent' to this function, we would simply wait for all events for that 'wevent'. There is a disadvantage with this approach. * Windows clients need to create a 'wevent' and then pass it along. This means that at a lot of places where we create sockets, we also are forced to create a 'wevent'. With this commit, we pass the responsibility of creating a 'wevent' to poll_fd_wait() in case of sockets. That way, a client using poll_fd_wait() is only concerned about sockets and not about 'wevents'. There is a potential disadvantage with this change in that we create events more often and that may have a performance penalty. If that turns out to be the case, we will eventually need to create a pool of wevents that can be re-used. In Windows, there are cases where we want to wait on a event (not associated with any sockets) and then control it using functions like SetEvent() etc. For that purpose, introduce a new function poll_wevent_wait(). For this function, the client needs to create a event and then pass it along as an argument. Signed-off-by: Gurucharan Shetty <gshetty@nicira.com> Acked-By: Ben Pfaff <blp@nicira.com>
Diffstat (limited to 'lib/latch-unix.c')
-rw-r--r--lib/latch-unix.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/lib/latch-unix.c b/lib/latch-unix.c
index 20a6575e7..bf518b9ca 100644
--- a/lib/latch-unix.c
+++ b/lib/latch-unix.c
@@ -83,5 +83,5 @@ latch_is_set(const struct latch *latch)
void
latch_wait_at(const struct latch *latch, const char *where)
{
- poll_fd_wait_at(latch->fds[0], 0, POLLIN, where);
+ poll_fd_wait_at(latch->fds[0], POLLIN, where);
}