mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-18 05:12:45 +01:00
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>
This commit is contained in:
parent
7275aa9c32
commit
5f4b4525b3
@ -1642,21 +1642,21 @@ 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);
|
||||
|
||||
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);
|
||||
peer_comms_err(peer, pkt_err(peer, "invalid ack"));
|
||||
return;
|
||||
}
|
||||
|
||||
log_debug(peer->log, "They acked %"PRIu64", remote=%"PRIu64" local=%"PRIu64,
|
||||
ack, peer->remote.commit ? peer->remote.commit->order : 0,
|
||||
peer->local.commit ? peer->local.commit->order : 0);
|
||||
log_debug(peer->log, "They acked %"PRIi64", remote=%"PRIi64" local=%"PRIi64,
|
||||
ack, peer->remote.commit ? peer->remote.commit->order : -2,
|
||||
peer->local.commit ? peer->local.commit->order : -2);
|
||||
|
||||
/* BOLT #2:
|
||||
*
|
||||
@ -1704,10 +1704,10 @@ static void retransmit_pkts(struct peer *peer, u64 ack)
|
||||
queue_pkt_close_signature(peer);
|
||||
} else {
|
||||
log_broken(peer->log, "Can't rexmit %"PRIu64
|
||||
" when local commit %"PRIu64" and remote %"PRIu64,
|
||||
" when local commit %"PRIi64" and remote %"PRIi64,
|
||||
ack,
|
||||
peer->local.commit ? peer->local.commit->order : (u64)-2ULL,
|
||||
peer->remote.commit ? peer->remote.commit->order : (u64)-2ULL);
|
||||
peer->local.commit ? peer->local.commit->order : -2,
|
||||
peer->remote.commit ? peer->remote.commit->order : -2);
|
||||
peer_comms_err(peer, pkt_err(peer, "invalid ack"));
|
||||
return;
|
||||
}
|
||||
@ -1877,7 +1877,7 @@ struct commit_info *new_commit_info(const tal_t *ctx, u64 commit_num)
|
||||
ci->tx = NULL;
|
||||
ci->cstate = NULL;
|
||||
ci->sig = NULL;
|
||||
ci->order = -1ULL;
|
||||
ci->order = (s64)-1LL;
|
||||
return ci;
|
||||
}
|
||||
|
||||
@ -1968,8 +1968,8 @@ static struct peer *new_peer(struct lightningd_state *dstate,
|
||||
peer->closing.their_sig = NULL;
|
||||
peer->closing.our_script = NULL;
|
||||
peer->closing.their_script = NULL;
|
||||
peer->closing.shutdown_order = -1ULL;
|
||||
peer->closing.closing_order = -1ULL;
|
||||
peer->closing.shutdown_order = (s64)-1LL;
|
||||
peer->closing.closing_order = (s64)-1LL;
|
||||
peer->closing.sigs_in = 0;
|
||||
peer->onchain.tx = NULL;
|
||||
peer->onchain.resolved = NULL;
|
||||
|
@ -51,7 +51,7 @@ struct commit_info {
|
||||
/* Other side's signature for last commit tx (if known) */
|
||||
struct bitcoin_signature *sig;
|
||||
/* Order which commit was sent (theirs) / revocation was sent (ours) */
|
||||
u64 order;
|
||||
s64 order;
|
||||
};
|
||||
|
||||
struct peer_visible_state {
|
||||
@ -110,7 +110,7 @@ struct peer {
|
||||
struct pubkey *id;
|
||||
|
||||
/* Order counter for transmission of revocations/commitments. */
|
||||
u64 order_counter;
|
||||
s64 order_counter;
|
||||
|
||||
/* Current received packet. */
|
||||
Pkt *inpkt;
|
||||
@ -165,7 +165,7 @@ struct peer {
|
||||
/* scriptPubKey we/they want for closing. */
|
||||
u8 *our_script, *their_script;
|
||||
/* 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? */
|
||||
u32 sigs_in;
|
||||
} closing;
|
||||
|
Loading…
Reference in New Issue
Block a user