Browse Source

peer: use signed values for order.

This gives us a clear way to indicate "invalid", and also sqlite3 stores
signed 64-bit numbers, so it's clearer this way.

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
ppa-0.6.1
Rusty Russell 9 years ago
parent
commit
5f4b4525b3
  1. 24
      daemon/peer.c
  2. 6
      daemon/peer.h

24
daemon/peer.c

@ -1642,21 +1642,21 @@ again:
goto again; goto again;
} }
static void retransmit_pkts(struct peer *peer, u64 ack) static void retransmit_pkts(struct peer *peer, s64 ack)
{ {
log_debug(peer->log, "Our order counter is %"PRIu64", their ack %"PRIu64, log_debug(peer->log, "Our order counter is %"PRIi64", their ack %"PRIi64,
peer->order_counter, ack); peer->order_counter, ack);
if (ack > peer->order_counter) { if (ack > peer->order_counter) {
log_unusual(peer->log, "reconnect ack %"PRIu64" > %"PRIu64, log_unusual(peer->log, "reconnect ack %"PRIi64" > %"PRIi64,
ack, peer->order_counter); ack, peer->order_counter);
peer_comms_err(peer, pkt_err(peer, "invalid ack")); peer_comms_err(peer, pkt_err(peer, "invalid ack"));
return; return;
} }
log_debug(peer->log, "They acked %"PRIu64", remote=%"PRIu64" local=%"PRIu64, log_debug(peer->log, "They acked %"PRIi64", remote=%"PRIi64" local=%"PRIi64,
ack, peer->remote.commit ? peer->remote.commit->order : 0, ack, peer->remote.commit ? peer->remote.commit->order : -2,
peer->local.commit ? peer->local.commit->order : 0); peer->local.commit ? peer->local.commit->order : -2);
/* BOLT #2: /* BOLT #2:
* *
@ -1704,10 +1704,10 @@ static void retransmit_pkts(struct peer *peer, u64 ack)
queue_pkt_close_signature(peer); queue_pkt_close_signature(peer);
} else { } else {
log_broken(peer->log, "Can't rexmit %"PRIu64 log_broken(peer->log, "Can't rexmit %"PRIu64
" when local commit %"PRIu64" and remote %"PRIu64, " when local commit %"PRIi64" and remote %"PRIi64,
ack, ack,
peer->local.commit ? peer->local.commit->order : (u64)-2ULL, peer->local.commit ? peer->local.commit->order : -2,
peer->remote.commit ? peer->remote.commit->order : (u64)-2ULL); peer->remote.commit ? peer->remote.commit->order : -2);
peer_comms_err(peer, pkt_err(peer, "invalid ack")); peer_comms_err(peer, pkt_err(peer, "invalid ack"));
return; return;
} }
@ -1877,7 +1877,7 @@ struct commit_info *new_commit_info(const tal_t *ctx, u64 commit_num)
ci->tx = NULL; ci->tx = NULL;
ci->cstate = NULL; ci->cstate = NULL;
ci->sig = NULL; ci->sig = NULL;
ci->order = -1ULL; ci->order = (s64)-1LL;
return ci; return ci;
} }
@ -1968,8 +1968,8 @@ static struct peer *new_peer(struct lightningd_state *dstate,
peer->closing.their_sig = NULL; peer->closing.their_sig = NULL;
peer->closing.our_script = NULL; peer->closing.our_script = NULL;
peer->closing.their_script = NULL; peer->closing.their_script = NULL;
peer->closing.shutdown_order = -1ULL; peer->closing.shutdown_order = (s64)-1LL;
peer->closing.closing_order = -1ULL; peer->closing.closing_order = (s64)-1LL;
peer->closing.sigs_in = 0; peer->closing.sigs_in = 0;
peer->onchain.tx = NULL; peer->onchain.tx = NULL;
peer->onchain.resolved = NULL; peer->onchain.resolved = NULL;

6
daemon/peer.h

@ -51,7 +51,7 @@ struct commit_info {
/* Other side's signature for last commit tx (if known) */ /* Other side's signature for last commit tx (if known) */
struct bitcoin_signature *sig; struct bitcoin_signature *sig;
/* Order which commit was sent (theirs) / revocation was sent (ours) */ /* Order which commit was sent (theirs) / revocation was sent (ours) */
u64 order; s64 order;
}; };
struct peer_visible_state { struct peer_visible_state {
@ -110,7 +110,7 @@ struct peer {
struct pubkey *id; struct pubkey *id;
/* Order counter for transmission of revocations/commitments. */ /* Order counter for transmission of revocations/commitments. */
u64 order_counter; s64 order_counter;
/* Current received packet. */ /* Current received packet. */
Pkt *inpkt; Pkt *inpkt;
@ -165,7 +165,7 @@ struct peer {
/* scriptPubKey we/they want for closing. */ /* scriptPubKey we/they want for closing. */
u8 *our_script, *their_script; u8 *our_script, *their_script;
/* Last sent (in case we need to retransmit) */ /* Last sent (in case we need to retransmit) */
u64 shutdown_order, closing_order; s64 shutdown_order, closing_order;
/* How many closing sigs have we receieved? */ /* How many closing sigs have we receieved? */
u32 sigs_in; u32 sigs_in;
} closing; } closing;

Loading…
Cancel
Save