summaryrefslogtreecommitdiff
path: root/src/sync-mode.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/sync-mode.c')
-rw-r--r--src/sync-mode.c19
1 files changed, 17 insertions, 2 deletions
diff --git a/src/sync-mode.c b/src/sync-mode.c
index 7853d91..8cf7aa3 100644
--- a/src/sync-mode.c
+++ b/src/sync-mode.c
@@ -36,6 +36,7 @@
#include <stdlib.h>
#include <limits.h>
#include <net/if.h>
+#include <fcntl.h>
static void
do_channel_handler_step(int i, struct nethdr *net, size_t remain)
@@ -118,7 +119,7 @@ retry:
}
/* handler for messages received */
-static void channel_handler(struct channel *m, int i)
+static int channel_handler_routine(struct channel *m, int i)
{
ssize_t numbytes;
ssize_t remain;
@@ -126,7 +127,7 @@ static void channel_handler(struct channel *m, int i)
numbytes = channel_recv(m, __net, sizeof(__net));
if (numbytes <= 0)
- return;
+ return -1;
remain = numbytes;
while (remain > 0) {
@@ -167,6 +168,19 @@ static void channel_handler(struct channel *m, int i)
ptr += net->len;
remain -= net->len;
}
+ return 0;
+}
+
+/* handler for messages received */
+static void channel_handler(struct channel *m, int i)
+{
+ int k;
+
+ for (k=0; k<CONFIG(event_iterations_limit); k++) {
+ if (channel_handler_routine(m, i) == -1) {
+ break;
+ }
+ }
}
/* select a new interface candidate in a round robin basis */
@@ -277,6 +291,7 @@ static int init_sync(void)
}
for (i=0; i<STATE_SYNC(channel)->channel_num; i++) {
int fd = channel_get_fd(STATE_SYNC(channel)->channel[i]);
+ fcntl(fd, F_SETFL, O_NONBLOCK);
if (register_fd(fd, STATE(fds)) == -1)
return -1;
}