From 132acf7ceb59aa9567a7d254686dd612a3a79dfb Mon Sep 17 00:00:00 2001 From: Garrett D'Amore Date: Sat, 18 Jan 2020 11:25:38 -0800 Subject: TTL reads could be fewer. Specifically, we don't need to read the atomic value each loop iteration. We can just get it when a message is first received, and then use that value. This should make receiving through proxies a little more efficient. --- src/protocol/survey0/respond.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) (limited to 'src/protocol/survey0/respond.c') diff --git a/src/protocol/survey0/respond.c b/src/protocol/survey0/respond.c index 201811de..19dedef0 100644 --- a/src/protocol/survey0/respond.c +++ b/src/protocol/survey0/respond.c @@ -480,12 +480,14 @@ resp0_pipe_recv_cb(void *arg) nni_aio * aio; int hops; size_t len; + int ttl; if (nni_aio_result(&p->aio_recv) != 0) { nni_pipe_close(p->npipe); return; } + ttl = nni_atomic_get(&s->ttl); msg = nni_aio_get_msg(&p->aio_recv); nni_msg_set_pipe(msg, p->id); @@ -495,7 +497,7 @@ resp0_pipe_recv_cb(void *arg) bool end = 0; uint8_t *body; - if (hops > nni_atomic_get(&s->ttl)) { + if (hops > ttl) { goto drop; } hops++; -- cgit v1.2.3-70-g09d2