From 792feb853215cbbc6589850268075a97627dfb10 Mon Sep 17 00:00:00 2001 From: Rusty Russell Date: Wed, 28 Feb 2018 06:28:20 +1030 Subject: [PATCH] gossip: Only do a single lookup in channel_update. get_connection_by_scid() and update_to_pending() both do the same lookup which we did in handle_channel_update(). Do the lookup once, and simplify the others. Signed-off-by: Rusty Russell --- gossipd/routing.c | 44 +++++++++++++++++++++++++------------------- 1 file changed, 25 insertions(+), 19 deletions(-) diff --git a/gossipd/routing.c b/gossipd/routing.c index 5b421ff8f..e5139d5c7 100644 --- a/gossipd/routing.c +++ b/gossipd/routing.c @@ -851,18 +851,15 @@ bool handle_pending_cannouncement(struct routing_state *rstate, return local && forward; } -/* Return true if this is an update to a pending announcement (and queue it) */ -static bool update_to_pending(struct routing_state *rstate, - const struct short_channel_id *scid, - u32 timestamp, const u8 *update, - const u8 direction) +static void update_pending(struct routing_channel *chan, + u32 timestamp, const u8 *update, + const u8 direction) { - u64 uscid = short_channel_id_to_uint(scid); - struct routing_channel *chan = uintmap_get(&rstate->channels, uscid); - struct pending_cannouncement *pending = chan?chan->pending:NULL; + struct pending_cannouncement *pending = chan->pending; - if (!pending) - return false; + SUPERVERBOSE("Deferring update for pending channel %s(%d)", + type_to_string(trc, struct short_channel_id, + &short_channel_id), direction); if (pending->update_timestamps[direction] < timestamp) { if (pending->updates[direction]) { @@ -872,7 +869,6 @@ static bool update_to_pending(struct routing_state *rstate, pending->updates[direction] = tal_dup_arr(pending, u8, update, tal_len(update), 0); pending->update_timestamps[direction] = timestamp; } - return true; } void handle_channel_update(struct routing_state *rstate, const u8 *update) @@ -917,25 +913,35 @@ void handle_channel_update(struct routing_state *rstate, const u8 *update) return; } - if (update_to_pending(rstate, &short_channel_id, timestamp,serialized, direction)) { - SUPERVERBOSE("Deferring update for pending channel %s(%d)", + chan = uintmap_get(&rstate->channels, + short_channel_id_to_uint(&short_channel_id)); + if (!chan) { + SUPERVERBOSE("Ignoring update for unknown channel %s", type_to_string(trc, struct short_channel_id, - &short_channel_id), direction); + &short_channel_id)); tal_free(tmpctx); return; } - c = get_connection_by_scid(rstate, &short_channel_id, direction); - chan = uintmap_get(&rstate->channels, - short_channel_id_to_uint(&short_channel_id)); + if (chan->pending) { + update_pending(chan, timestamp, serialized, direction); + tal_free(tmpctx); + return; + } + c = chan->connections[direction]; + + /* When we local_add_channel(), we only half-populate, so this case + * is possible. */ if (!c) { - SUPERVERBOSE("Ignoring update for unknown channel %s", + SUPERVERBOSE("Ignoring update for unknown half channel %s", type_to_string(trc, struct short_channel_id, &short_channel_id)); tal_free(tmpctx); return; - } else if (c->last_timestamp >= timestamp) { + } + + if (c->last_timestamp >= timestamp) { SUPERVERBOSE("Ignoring outdated update."); tal_free(tmpctx); return;