Browse Source

routing: move struct node_connection into struct routing_channel.

No need to have pointers since they're always there.

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
ppa-0.6.1
Rusty Russell 7 years ago
committed by Christian Decker
parent
commit
fd9c0c8543
  1. 21
      gossipd/gossip.c
  2. 31
      gossipd/routing.c
  3. 14
      gossipd/routing.h
  4. 2
      gossipd/test/run-bench-find_route.c
  5. 2
      gossipd/test/run-find_route-specific.c
  6. 4
      gossipd/test/run-find_route.c

21
gossipd/gossip.c

@ -726,13 +726,11 @@ static void handle_get_update(struct peer *peer, const u8 *msg)
&scid)); &scid));
update = NULL; update = NULL;
} else { } else {
struct node_connection *c; /* We want update that comes from our end. */
/* We want update than comes from our end. */
if (pubkey_eq(&chan->nodes[0]->id, &peer->daemon->id)) if (pubkey_eq(&chan->nodes[0]->id, &peer->daemon->id))
c = chan->connections[0]; update = chan->connections[0].channel_update;
else if (pubkey_eq(&chan->nodes[1]->id, &peer->daemon->id)) else if (pubkey_eq(&chan->nodes[1]->id, &peer->daemon->id))
c = chan->connections[1]; update = chan->connections[1].channel_update;
else { else {
status_unusual("peer %s scid %s: not our channel?", status_unusual("peer %s scid %s: not our channel?",
type_to_string(trc, struct pubkey, type_to_string(trc, struct pubkey,
@ -740,11 +738,8 @@ static void handle_get_update(struct peer *peer, const u8 *msg)
type_to_string(trc, type_to_string(trc,
struct short_channel_id, struct short_channel_id,
&scid)); &scid));
c = NULL; update = NULL;
} }
if (c)
update = c->channel_update;
} }
status_trace("peer %s schanid %s: %s update", status_trace("peer %s schanid %s: %s update",
type_to_string(trc, struct pubkey, &peer->id), type_to_string(trc, struct pubkey, &peer->id),
@ -1110,8 +1105,8 @@ static void append_half_channel(struct gossip_getchannels_entry **entries,
static void append_channel(struct gossip_getchannels_entry **entries, static void append_channel(struct gossip_getchannels_entry **entries,
const struct routing_channel *chan) const struct routing_channel *chan)
{ {
append_half_channel(entries, chan->connections[0]); append_half_channel(entries, &chan->connections[0]);
append_half_channel(entries, chan->connections[1]); append_half_channel(entries, &chan->connections[1]);
} }
static struct io_plan *getchannels_req(struct io_conn *conn, struct daemon *daemon, static struct io_plan *getchannels_req(struct io_conn *conn, struct daemon *daemon,
@ -1280,7 +1275,7 @@ fail:
static void gossip_send_keepalive_update(struct routing_state *rstate, static void gossip_send_keepalive_update(struct routing_state *rstate,
struct node_connection *nc) struct node_connection *nc)
{ {
tal_t *tmpctx = tal_tmpctx(nc); tal_t *tmpctx = tal_tmpctx(rstate);
secp256k1_ecdsa_signature sig; secp256k1_ecdsa_signature sig;
struct bitcoin_blkid chain_hash; struct bitcoin_blkid chain_hash;
struct short_channel_id scid; struct short_channel_id scid;
@ -1832,7 +1827,7 @@ static struct io_plan *handle_disable_channel(struct io_conn *conn,
type_to_string(msg, struct short_channel_id, &scid)); type_to_string(msg, struct short_channel_id, &scid));
goto fail; goto fail;
} }
nc = chan->connections[direction]; nc = &chan->connections[direction];
status_trace("Disabling channel %s/%d, active %d -> %d", status_trace("Disabling channel %s/%d, active %d -> %d",
type_to_string(msg, struct short_channel_id, &scid), type_to_string(msg, struct short_channel_id, &scid),

31
gossipd/routing.c

@ -196,20 +196,19 @@ static void destroy_routing_channel(struct routing_channel *chan,
tal_free(chan->nodes[1]); tal_free(chan->nodes[1]);
} }
static struct node_connection *new_node_connection(struct routing_state *rstate, static void init_node_connection(struct routing_state *rstate,
struct routing_channel *chan, struct routing_channel *chan,
struct node *from, struct node *from,
struct node *to, struct node *to,
int idx) int idx)
{ {
struct node_connection *c; struct node_connection *c = &chan->connections[idx];
/* We are going to put this in the right way? */ /* We are going to put this in the right way? */
assert(idx == pubkey_idx(&from->id, &to->id)); assert(idx == pubkey_idx(&from->id, &to->id));
assert(from == chan->nodes[idx]); assert(from == chan->nodes[idx]);
assert(to == chan->nodes[!idx]); assert(to == chan->nodes[!idx]);
c = tal(rstate, struct node_connection);
c->src = from; c->src = from;
c->dst = to; c->dst = to;
c->short_channel_id = chan->scid; c->short_channel_id = chan->scid;
@ -220,10 +219,6 @@ static struct node_connection *new_node_connection(struct routing_state *rstate,
/* We haven't seen channel_update: make it halfway to prune time, /* We haven't seen channel_update: make it halfway to prune time,
* which should be older than any update we'd see. */ * which should be older than any update we'd see. */
c->last_timestamp = time_now().ts.tv_sec - rstate->prune_timeout/2; c->last_timestamp = time_now().ts.tv_sec - rstate->prune_timeout/2;
/* Hook it into in/out arrays. */
chan->connections[idx] = c;
return c;
} }
struct routing_channel *new_routing_channel(struct routing_state *rstate, struct routing_channel *new_routing_channel(struct routing_state *rstate,
@ -260,8 +255,8 @@ struct routing_channel *new_routing_channel(struct routing_state *rstate,
n1->channels[n] = chan; n1->channels[n] = chan;
/* Populate with (inactive) connections */ /* Populate with (inactive) connections */
new_node_connection(rstate, chan, n1, n2, n1idx); init_node_connection(rstate, chan, n1, n2, n1idx);
new_node_connection(rstate, chan, n2, n1, !n1idx); init_node_connection(rstate, chan, n2, n1, !n1idx);
uintmap_add(&rstate->channels, scid->u64, chan); uintmap_add(&rstate->channels, scid->u64, chan);
@ -805,7 +800,7 @@ void set_connection_values(struct routing_channel *chan,
u64 timestamp, u64 timestamp,
u32 htlc_minimum_msat) u32 htlc_minimum_msat)
{ {
struct node_connection *c = chan->connections[idx]; struct node_connection *c = &chan->connections[idx];
c->delay = delay; c->delay = delay;
c->htlc_minimum_msat = htlc_minimum_msat; c->htlc_minimum_msat = htlc_minimum_msat;
@ -898,7 +893,7 @@ void handle_channel_update(struct routing_state *rstate, const u8 *update)
} }
} }
c = chan->connections[direction]; c = &chan->connections[direction];
if (c->last_timestamp >= timestamp) { if (c->last_timestamp >= timestamp) {
SUPERVERBOSE("Ignoring outdated update."); SUPERVERBOSE("Ignoring outdated update.");
@ -936,7 +931,7 @@ void handle_channel_update(struct routing_state *rstate, const u8 *update)
serialized); serialized);
tal_free(c->channel_update); tal_free(c->channel_update);
c->channel_update = tal_steal(c, serialized); c->channel_update = tal_steal(chan, serialized);
tal_free(tmpctx); tal_free(tmpctx);
} }
@ -1278,8 +1273,8 @@ void mark_channel_unroutable(struct routing_state *rstate,
tal_free(tmpctx); tal_free(tmpctx);
return; return;
} }
chan->connections[0]->unroutable_until = now + 20; chan->connections[0].unroutable_until = now + 20;
chan->connections[1]->unroutable_until = now + 20; chan->connections[1].unroutable_until = now + 20;
tal_free(tmpctx); tal_free(tmpctx);
} }
@ -1300,14 +1295,14 @@ void route_prune(struct routing_state *rstate)
if (!chan->public) if (!chan->public)
continue; continue;
if (chan->connections[0]->last_timestamp < highwater if (chan->connections[0].last_timestamp < highwater
&& chan->connections[1]->last_timestamp < highwater) { && chan->connections[1].last_timestamp < highwater) {
status_trace( status_trace(
"Pruning channel %s from network view (ages %"PRIu64" and %"PRIu64"s)", "Pruning channel %s from network view (ages %"PRIu64" and %"PRIu64"s)",
type_to_string(trc, struct short_channel_id, type_to_string(trc, struct short_channel_id,
&chan->scid), &chan->scid),
now - chan->connections[0]->last_timestamp, now - chan->connections[0].last_timestamp,
now - chan->connections[1]->last_timestamp); now - chan->connections[1].last_timestamp);
/* This may perturb iteration so do outside loop. */ /* This may perturb iteration so do outside loop. */
tal_steal(pruned, chan); tal_steal(pruned, chan);

14
gossipd/routing.h

@ -98,7 +98,7 @@ struct routing_channel {
* connections[0]->src == nodes[0] connections[0]->dst == nodes[1] * connections[0]->src == nodes[0] connections[0]->dst == nodes[1]
* connections[1]->src == nodes[1] connections[1]->dst == nodes[0] * connections[1]->src == nodes[1] connections[1]->dst == nodes[0]
*/ */
struct node_connection *connections[2]; struct node_connection connections[2];
/* nodes[0].id < nodes[1].id */ /* nodes[0].id < nodes[1].id */
struct node *nodes[2]; struct node *nodes[2];
@ -124,9 +124,9 @@ static inline struct node_connection *connection_from(const struct node *n,
{ {
int idx = (chan->nodes[1] == n); int idx = (chan->nodes[1] == n);
assert(chan->connections[idx]->src == n); assert(chan->connections[idx].src == n);
assert(chan->connections[!idx]->dst == n); assert(chan->connections[!idx].dst == n);
return chan->connections[idx]; return &chan->connections[idx];
} }
static inline struct node_connection *connection_to(const struct node *n, static inline struct node_connection *connection_to(const struct node *n,
@ -134,9 +134,9 @@ static inline struct node_connection *connection_to(const struct node *n,
{ {
int idx = (chan->nodes[1] == n); int idx = (chan->nodes[1] == n);
assert(chan->connections[idx]->src == n); assert(chan->connections[idx].src == n);
assert(chan->connections[!idx]->dst == n); assert(chan->connections[!idx].dst == n);
return chan->connections[!idx]; return &chan->connections[!idx];
} }
struct routing_state { struct routing_state {

2
gossipd/test/run-bench-find_route.c

@ -117,7 +117,7 @@ static struct node_connection *add_connection(struct routing_state *rstate,
if (!chan) if (!chan)
chan = new_routing_channel(rstate, &scid, from, to); chan = new_routing_channel(rstate, &scid, from, to);
c = chan->connections[pubkey_idx(from, to)]; c = &chan->connections[pubkey_idx(from, to)];
c->base_fee = base_fee; c->base_fee = base_fee;
c->proportional_fee = proportional_fee; c->proportional_fee = proportional_fee;
c->delay = delay; c->delay = delay;

2
gossipd/test/run-find_route-specific.c

@ -83,7 +83,7 @@ get_or_make_connection(struct routing_state *rstate,
if (!chan) if (!chan)
chan = new_routing_channel(rstate, &scid, from_id, to_id); chan = new_routing_channel(rstate, &scid, from_id, to_id);
return chan->connections[pubkey_idx(from_id, to_id)]; return &chan->connections[pubkey_idx(from_id, to_id)];
} }
int main(void) int main(void)

4
gossipd/test/run-find_route.c

@ -82,7 +82,7 @@ static struct node_connection *add_connection(struct routing_state *rstate,
if (!chan) if (!chan)
chan = new_routing_channel(rstate, &scid, from, to); chan = new_routing_channel(rstate, &scid, from, to);
c = chan->connections[pubkey_idx(from, to)]; c = &chan->connections[pubkey_idx(from, to)];
c->base_fee = base_fee; c->base_fee = base_fee;
c->proportional_fee = proportional_fee; c->proportional_fee = proportional_fee;
c->delay = delay; c->delay = delay;
@ -127,7 +127,7 @@ static struct node_connection *get_connection(struct routing_state *rstate,
c = find_channel(rstate, from, to, &idx); c = find_channel(rstate, from, to, &idx);
if (!c) if (!c)
return NULL; return NULL;
return c->connections[idx]; return &c->connections[idx];
} }
int main(void) int main(void)

Loading…
Cancel
Save