summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/network.h6
-rw-r--r--src/sync-ftfw.c44
2 files changed, 30 insertions, 20 deletions
diff --git a/include/network.h b/include/network.h
index 777be11..d2e4edd 100644
--- a/include/network.h
+++ b/include/network.h
@@ -65,12 +65,6 @@ enum {
SEQ_BEFORE,
};
-enum {
- SAY_HELLO,
- HELLO_BACK,
- HELLO_DONE,
-};
-
int mcast_track_seq(uint32_t seq, uint32_t *exp_seq);
void mcast_track_update_seq(uint32_t seq);
int mcast_track_is_seq_set(void);
diff --git a/src/sync-ftfw.c b/src/sync-ftfw.c
index 8dd5554..11c0638 100644
--- a/src/sync-ftfw.c
+++ b/src/sync-ftfw.c
@@ -46,7 +46,14 @@ static uint32_t window;
static uint32_t ack_from;
static int ack_from_set = 0;
static struct alarm_block alive_alarm;
-static int hello_state = SAY_HELLO;
+
+enum {
+ HELLO_INIT,
+ HELLO_SAY,
+ HELLO_DONE,
+};
+static int hello_state = HELLO_INIT;
+static int say_hello_back;
/* XXX: alive message expiration configurable */
#define ALIVE_INT 1
@@ -96,13 +103,17 @@ static void tx_queue_add_ctlmsg(uint32_t flags, uint32_t from, uint32_t to)
};
switch(hello_state) {
- case SAY_HELLO:
+ case HELLO_INIT:
+ hello_state = HELLO_SAY;
+ /* fall through */
+ case HELLO_SAY:
ack.flags |= NET_F_HELLO;
break;
- case HELLO_BACK:
+ }
+
+ if (say_hello_back) {
ack.flags |= NET_F_HELLO_BACK;
- hello_state = HELLO_DONE;
- break;
+ say_hello_back = 0;
}
queue_add(tx_queue, &ack, NETHDR_ACK_SIZ);
@@ -335,12 +346,13 @@ static int digest_hello(const struct nethdr *net)
int ret = 0;
if (IS_HELLO(net)) {
- dlog(LOG_NOTICE, "The other node says HELLO");
- hello_state = HELLO_BACK;
+ say_hello_back = 1;
ret = 1;
- } else if (IS_HELLO_BACK(net)) {
- dlog(LOG_NOTICE, "The other node says HELLO BACK");
- hello_state = HELLO_DONE;
+ }
+ if (IS_HELLO_BACK(net)) {
+ /* this is a hello back for a requested hello */
+ if (hello_state == HELLO_SAY)
+ hello_state = HELLO_DONE;
}
return ret;
@@ -428,15 +440,19 @@ static void ftfw_send(struct nethdr *net, struct us_conntrack *u)
}
switch(hello_state) {
- case SAY_HELLO:
+ case HELLO_INIT:
+ hello_state = HELLO_SAY;
+ /* fall through */
+ case HELLO_SAY:
net->flags = ntohs(net->flags) | NET_F_HELLO;
net->flags = htons(net->flags);
break;
- case HELLO_BACK:
+ }
+
+ if (say_hello_back) {
net->flags = ntohs(net->flags) | NET_F_HELLO_BACK;
net->flags = htons(net->flags);
- hello_state = HELLO_DONE;
- break;
+ say_hello_back = 0;
}
cn->seq = ntohl(net->seq);