Browse Source

Revert gossip: Track whether we read a message from store or peer

Messages from peers and messages from the gossip_store now have completely
different entrypoints, so we don't need to trace their origin around the message
handling code any longer.
ppa-0.6.1
Christian Decker 7 years ago
committed by Rusty Russell
parent
commit
c4ea79cc5c
  1. 12
      gossipd/gossip.c
  2. 35
      gossipd/routing.c
  3. 9
      gossipd/routing.h

12
gossipd/gossip.c

@ -477,7 +477,7 @@ static void send_node_announcement(struct daemon *daemon)
* from the HSM, create the real announcement and forward it to * from the HSM, create the real announcement and forward it to
* gossipd so it can take care of forwarding it. */ * gossipd so it can take care of forwarding it. */
nannounce = create_node_announcement(NULL, daemon, &sig, timestamp); nannounce = create_node_announcement(NULL, daemon, &sig, timestamp);
err = handle_node_announcement(daemon->rstate, take(nannounce), true); err = handle_node_announcement(daemon->rstate, take(nannounce));
if (err) if (err)
status_failed(STATUS_FAIL_INTERNAL_ERROR, status_failed(STATUS_FAIL_INTERNAL_ERROR,
"rejected own node announcement: %s", "rejected own node announcement: %s",
@ -495,7 +495,7 @@ static u8 *handle_gossip_msg(struct daemon *daemon, const u8 *msg, bool store)
case WIRE_CHANNEL_ANNOUNCEMENT: { case WIRE_CHANNEL_ANNOUNCEMENT: {
const struct short_channel_id *scid; const struct short_channel_id *scid;
/* If it's OK, tells us the short_channel_id to lookup */ /* If it's OK, tells us the short_channel_id to lookup */
err = handle_channel_announcement(rstate, msg, &scid, store); err = handle_channel_announcement(rstate, msg, &scid);
if (err) if (err)
return err; return err;
else if (scid) else if (scid)
@ -506,13 +506,13 @@ static u8 *handle_gossip_msg(struct daemon *daemon, const u8 *msg, bool store)
} }
case WIRE_NODE_ANNOUNCEMENT: case WIRE_NODE_ANNOUNCEMENT:
err = handle_node_announcement(rstate, msg, store); err = handle_node_announcement(rstate, msg);
if (err) if (err)
return err; return err;
break; break;
case WIRE_CHANNEL_UPDATE: case WIRE_CHANNEL_UPDATE:
err = handle_channel_update(rstate, msg, store); err = handle_channel_update(rstate, msg);
if (err) if (err)
return err; return err;
break; break;
@ -1370,7 +1370,7 @@ static void gossip_send_keepalive_update(struct routing_state *rstate,
status_trace("Sending keepalive channel_update for %s", status_trace("Sending keepalive channel_update for %s",
type_to_string(tmpctx, struct short_channel_id, &scid)); type_to_string(tmpctx, struct short_channel_id, &scid));
err = handle_channel_update(rstate, update, true); err = handle_channel_update(rstate, update);
if (err) if (err)
status_failed(STATUS_FAIL_INTERNAL_ERROR, status_failed(STATUS_FAIL_INTERNAL_ERROR,
"rejected keepalive channel_update: %s", "rejected keepalive channel_update: %s",
@ -1954,7 +1954,7 @@ static struct io_plan *handle_disable_channel(struct io_conn *conn,
strerror(errno)); strerror(errno));
} }
err = handle_channel_update(daemon->rstate, msg, true); err = handle_channel_update(daemon->rstate, msg);
if (err) if (err)
status_failed(STATUS_FAIL_INTERNAL_ERROR, status_failed(STATUS_FAIL_INTERNAL_ERROR,
"rejected disabling channel_update: %s", "rejected disabling channel_update: %s",

35
gossipd/routing.c

@ -50,9 +50,6 @@ struct pending_cannouncement {
/* Only ever replace with newer updates */ /* Only ever replace with newer updates */
u32 update_timestamps[2]; u32 update_timestamps[2];
/* Was this from a peer and should be stored? */
bool store;
}; };
struct pending_node_announce { struct pending_node_announce {
@ -551,8 +548,7 @@ static void add_pending_node_announcement(struct routing_state *rstate, struct p
} }
static void process_pending_node_announcement(struct routing_state *rstate, static void process_pending_node_announcement(struct routing_state *rstate,
struct pubkey *nodeid, struct pubkey *nodeid)
bool store)
{ {
struct pending_node_announce *pna = pending_node_map_get(rstate->pending_node_map, &nodeid->pubkey); struct pending_node_announce *pna = pending_node_map_get(rstate->pending_node_map, &nodeid->pubkey);
if (!pna) if (!pna)
@ -565,7 +561,7 @@ static void process_pending_node_announcement(struct routing_state *rstate,
type_to_string(pna, struct pubkey, nodeid)); type_to_string(pna, struct pubkey, nodeid));
/* Should not error, since we processed it before */ /* Should not error, since we processed it before */
err = handle_node_announcement(rstate, pna->node_announcement, store); err = handle_node_announcement(rstate, pna->node_announcement);
if (err) if (err)
status_failed(STATUS_FAIL_INTERNAL_ERROR, status_failed(STATUS_FAIL_INTERNAL_ERROR,
"pending node_announcement %s malformed %s?", "pending node_announcement %s malformed %s?",
@ -632,8 +628,7 @@ void routing_add_channel_announcement(struct routing_state *rstate,
u8 *handle_channel_announcement(struct routing_state *rstate, u8 *handle_channel_announcement(struct routing_state *rstate,
const u8 *announce TAKES, const u8 *announce TAKES,
const struct short_channel_id **scid, const struct short_channel_id **scid)
bool store)
{ {
struct pending_cannouncement *pending; struct pending_cannouncement *pending;
struct bitcoin_blkid chain_hash; struct bitcoin_blkid chain_hash;
@ -645,7 +640,6 @@ u8 *handle_channel_announcement(struct routing_state *rstate,
pending = tal(rstate, struct pending_cannouncement); pending = tal(rstate, struct pending_cannouncement);
pending->updates[0] = NULL; pending->updates[0] = NULL;
pending->updates[1] = NULL; pending->updates[1] = NULL;
pending->store = store;
pending->announce = tal_dup_arr(pending, u8, pending->announce = tal_dup_arr(pending, u8,
announce, tal_len(announce), 0); announce, tal_len(announce), 0);
pending->update_timestamps[0] = pending->update_timestamps[1] = 0; pending->update_timestamps[0] = pending->update_timestamps[1] = 0;
@ -768,7 +762,7 @@ ignored:
static void process_pending_channel_update(struct routing_state *rstate, static void process_pending_channel_update(struct routing_state *rstate,
const struct short_channel_id *scid, const struct short_channel_id *scid,
const u8 *cupdate, bool store) const u8 *cupdate)
{ {
u8 *err; u8 *err;
@ -776,7 +770,7 @@ static void process_pending_channel_update(struct routing_state *rstate,
return; return;
/* FIXME: We don't remember who sent us updates, so can't error them */ /* FIXME: We don't remember who sent us updates, so can't error them */
err = handle_channel_update(rstate, cupdate, store); err = handle_channel_update(rstate, cupdate);
if (err) { if (err) {
status_trace("Pending channel_update for %s: %s", status_trace("Pending channel_update for %s: %s",
type_to_string(tmpctx, struct short_channel_id, scid), type_to_string(tmpctx, struct short_channel_id, scid),
@ -832,7 +826,6 @@ bool handle_pending_cannouncement(struct routing_state *rstate,
return false; return false;
} }
if (pending->store)
gossip_store_add_channel_announcement(rstate->store, pending->announce, satoshis); gossip_store_add_channel_announcement(rstate->store, pending->announce, satoshis);
routing_add_channel_announcement(rstate, pending->announce, satoshis); routing_add_channel_announcement(rstate, pending->announce, satoshis);
@ -840,11 +833,11 @@ bool handle_pending_cannouncement(struct routing_state *rstate,
pubkey_eq(&pending->node_id_2, &rstate->local_id); pubkey_eq(&pending->node_id_2, &rstate->local_id);
/* Did we have an update waiting? If so, apply now. */ /* Did we have an update waiting? If so, apply now. */
process_pending_channel_update(rstate, scid, pending->updates[0], pending->store); process_pending_channel_update(rstate, scid, pending->updates[0]);
process_pending_channel_update(rstate, scid, pending->updates[1], pending->store); process_pending_channel_update(rstate, scid, pending->updates[1]);
process_pending_node_announcement(rstate, &pending->node_id_1, pending->store); process_pending_node_announcement(rstate, &pending->node_id_1);
process_pending_node_announcement(rstate, &pending->node_id_2, pending->store); process_pending_node_announcement(rstate, &pending->node_id_2);
tal_free(pending); tal_free(pending);
return local; return local;
@ -936,8 +929,7 @@ void routing_add_channel_update(struct routing_state *rstate,
take(update)); take(update));
} }
u8 *handle_channel_update(struct routing_state *rstate, const u8 *update, u8 *handle_channel_update(struct routing_state *rstate, const u8 *update)
bool store)
{ {
u8 *serialized; u8 *serialized;
struct half_chan *c; struct half_chan *c;
@ -1100,8 +1092,7 @@ void routing_add_node_announcement(struct routing_state *rstate, const u8 *msg T
take(msg)); take(msg));
} }
u8 *handle_node_announcement(struct routing_state *rstate, const u8 *node_ann, u8 *handle_node_announcement(struct routing_state *rstate, const u8 *node_ann)
bool store)
{ {
u8 *serialized; u8 *serialized;
struct sha256_double hash; struct sha256_double hash;
@ -1225,8 +1216,6 @@ u8 *handle_node_announcement(struct routing_state *rstate, const u8 *node_ann,
status_trace("Received node_announcement for node %s", status_trace("Received node_announcement for node %s",
type_to_string(tmpctx, struct pubkey, &node_id)); type_to_string(tmpctx, struct pubkey, &node_id));
/* FIXME: remove store guard */
if (store)
gossip_store_add_node_announcement(rstate->store, serialized); gossip_store_add_node_announcement(rstate->store, serialized);
routing_add_node_announcement(rstate, serialized); routing_add_node_announcement(rstate, serialized);
return NULL; return NULL;
@ -1385,7 +1374,7 @@ void routing_failure(struct routing_state *rstate,
(int) failcode); (int) failcode);
return; return;
} }
err = handle_channel_update(rstate, channel_update, true); err = handle_channel_update(rstate, channel_update);
if (err) { if (err) {
status_unusual("routing_failure: " status_unusual("routing_failure: "
"bad channel_update %s", "bad channel_update %s",

9
gossipd/routing.h

@ -200,8 +200,7 @@ struct chan *new_chan(struct routing_state *rstate,
*/ */
u8 *handle_channel_announcement(struct routing_state *rstate, u8 *handle_channel_announcement(struct routing_state *rstate,
const u8 *announce TAKES, const u8 *announce TAKES,
const struct short_channel_id **scid, const struct short_channel_id **scid);
bool store);
/** /**
* handle_pending_cannouncement -- handle channel_announce once we've * handle_pending_cannouncement -- handle channel_announce once we've
@ -217,12 +216,10 @@ bool handle_pending_cannouncement(struct routing_state *rstate,
const u8 *txscript); const u8 *txscript);
/* Returns NULL if all OK, otherwise an error for the peer which sent. */ /* Returns NULL if all OK, otherwise an error for the peer which sent. */
u8 *handle_channel_update(struct routing_state *rstate, const u8 *update, u8 *handle_channel_update(struct routing_state *rstate, const u8 *update);
bool store);
/* Returns NULL if all OK, otherwise an error for the peer which sent. */ /* Returns NULL if all OK, otherwise an error for the peer which sent. */
u8 *handle_node_announcement(struct routing_state *rstate, const u8 *node, u8 *handle_node_announcement(struct routing_state *rstate, const u8 *node);
bool store);
/* Set values on the struct node_connection */ /* Set values on the struct node_connection */
void set_connection_values(struct chan *chan, void set_connection_values(struct chan *chan,

Loading…
Cancel
Save