aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMartin Willi <martin@revosec.ch>2013-07-17 16:03:23 +0200
committerMartin Willi <martin@revosec.ch>2013-07-18 16:00:31 +0200
commitd0c25a3f23285a1ed17a82d22459a012e53dbae3 (patch)
treefb7cfd3d47185940614d2c018acd734213b5575b /src
parent8fc89db7b6cd9d0c23dd96d5312ddc92aae16eb4 (diff)
downloadstrongswan-d0c25a3f23285a1ed17a82d22459a012e53dbae3.tar.bz2
strongswan-d0c25a3f23285a1ed17a82d22459a012e53dbae3.tar.xz
watcher: read multiple notifications if available
Use non-blocking I/O on the read end of the notify pipe. This also makes sure the read does not block should select() signal data while there is none.
Diffstat (limited to 'src')
-rw-r--r--src/libstrongswan/processing/watcher.c17
1 files changed, 15 insertions, 2 deletions
diff --git a/src/libstrongswan/processing/watcher.c b/src/libstrongswan/processing/watcher.c
index ee7053396..da7ba759a 100644
--- a/src/libstrongswan/processing/watcher.c
+++ b/src/libstrongswan/processing/watcher.c
@@ -25,6 +25,7 @@
#include <unistd.h>
#include <errno.h>
#include <sys/select.h>
+#include <fcntl.h>
typedef struct private_watcher_t private_watcher_t;
@@ -286,7 +287,7 @@ static job_requeue_t watch(private_watcher_t *this)
if (this->notify[0] != -1 && FD_ISSET(this->notify[0], &rd))
{
DBG2(DBG_JOB, "watcher got notification, rebuilding");
- ignore_result(read(this->notify[0], buf, sizeof(buf)));
+ while (read(this->notify[0], buf, sizeof(buf)) > 0);
return JOB_REQUEUE_DIRECT;
}
@@ -430,6 +431,7 @@ METHOD(watcher_t, destroy, void,
watcher_t *watcher_create()
{
private_watcher_t *this;
+ int flags;
INIT(this,
.public = {
@@ -444,7 +446,18 @@ watcher_t *watcher_create()
.notify[1] = -1,
);
- if (pipe(this->notify) != 0)
+ if (pipe(this->notify) == 0)
+ {
+ /* use non-blocking I/O on read-end of notify pipe */
+ flags = fcntl(this->notify[0], F_GETFL);
+ if (flags == -1 ||
+ fcntl(this->notify[0], F_SETFL, flags | O_NONBLOCK) == -1)
+ {
+ DBG1(DBG_LIB, "setting watcher notify pipe read-end non-blocking "
+ "failed: %s", strerror(errno));
+ }
+ }
+ else
{
DBG1(DBG_LIB, "creating watcher notify pipe failed: %s",
strerror(errno));