Browse Source

gossip: Only replace with newer updates while txout check is pending

Signed-off-by: Christian Decker <decker.christian@gmail.com>
ppa-0.6.1
Christian Decker 7 years ago
committed by Rusty Russell
parent
commit
24d52ec23a
  1. 21
      gossipd/routing.c

21
gossipd/routing.c

@ -48,6 +48,9 @@ struct pending_cannouncement {
/* Deferred updates, if we received them while waiting for
* this (one for each direction) */
const u8 *updates[2];
/* Only ever replace with newer updates */
u32 update_timestamps[2];
};
/**
@ -609,6 +612,7 @@ const struct short_channel_id *handle_channel_announcement(
pending->updates[1] = NULL;
pending->announce = tal_dup_arr(pending, u8,
announce, tal_len(announce), 0);
pending->update_timestamps[0] = pending->update_timestamps[1] = 0;
if (!fromwire_channel_announcement(pending, pending->announce, NULL,
&node_signature_1,
@ -793,7 +797,8 @@ bool handle_pending_cannouncement(struct routing_state *rstate,
/* 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,
const u8 *update, const u8 direction)
u32 timestamp, const u8 *update,
const u8 direction)
{
struct pending_cannouncement *pending;
@ -801,12 +806,14 @@ static bool update_to_pending(struct routing_state *rstate,
if (!pending)
return false;
/* FIXME: should compare timestamps! */
if (pending->updates[direction]) {
status_trace("Replacing existing update");
tal_free(pending->updates[direction]);
if (pending->update_timestamps[direction] < timestamp) {
if (pending->updates[direction]) {
status_trace("Replacing existing update");
tal_free(pending->updates[direction]);
}
pending->updates[direction] = tal_dup_arr(pending, u8, update, tal_len(update), 0);
pending->update_timestamps[direction] = timestamp;
}
pending->updates[direction] = tal_dup_arr(pending, u8, update, tal_len(update), 0);
return true;
}
@ -851,7 +858,7 @@ void handle_channel_update(struct routing_state *rstate, const u8 *update)
return;
}
if (update_to_pending(rstate, &short_channel_id, serialized, direction)) {
if (update_to_pending(rstate, &short_channel_id, timestamp,serialized, direction)) {
SUPERVERBOSE("Deferring update for pending channel %s(%d)",
type_to_string(trc, struct short_channel_id,
&short_channel_id), direction);

Loading…
Cancel
Save