channeld: handle funding_locked message before reestablish.

LND seems to do this occasionally, though fixed in new versions.  Workaround
in the meantime.

I tested this by hacking our code to send it prematurely, and this worked.

Fixes: #2219
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
This commit is contained in:
Rusty Russell 2019-02-20 21:46:59 +10:30 committed by Christian Decker
parent 3b68e29bbd
commit 5f0b065622
2 changed files with 18 additions and 2 deletions

View File

@ -46,6 +46,8 @@ changes.
- You can no longer make giant unpayable "wumbo" invoices. - You can no longer make giant unpayable "wumbo" invoices.
- CLTV of total route now correctly evaluated when finding best route. - CLTV of total route now correctly evaluated when finding best route.
- `riskfactor` arguments to `pay` and `getroute` now have an effect. - `riskfactor` arguments to `pay` and `getroute` now have an effect.
- Handle lnd sending premature 'funding_locked' message when we're expected 'reestablish';
we used to close channel if this happened.
### Security ### Security

View File

@ -2087,6 +2087,7 @@ static void peer_reconnect(struct peer *peer,
remote_current_per_commitment_point; remote_current_per_commitment_point;
struct secret last_local_per_commitment_secret; struct secret last_local_per_commitment_secret;
bool dataloss_protect; bool dataloss_protect;
const u8 *premature_funding_locked = NULL;
dataloss_protect = local_feature_negotiated(peer->localfeatures, dataloss_protect = local_feature_negotiated(peer->localfeatures,
LOCAL_DATA_LOSS_PROTECT); LOCAL_DATA_LOSS_PROTECT);
@ -2143,8 +2144,16 @@ static void peer_reconnect(struct peer *peer,
do { do {
clean_tmpctx(); clean_tmpctx();
msg = sync_crypto_read(tmpctx, &peer->cs, PEER_FD); msg = sync_crypto_read(tmpctx, &peer->cs, PEER_FD);
} while (handle_peer_gossip_or_error(PEER_FD, GOSSIP_FD, &peer->cs,
&peer->channel_id, msg)); /* Older LND sometimes sends funding_locked before reestablish! */
if (fromwire_peektype(msg) == WIRE_FUNDING_LOCKED
&& !premature_funding_locked) {
status_trace("Stashing early funding_locked msg!");
premature_funding_locked = tal_steal(peer, msg);
msg = NULL;
}
} while (!msg || handle_peer_gossip_or_error(PEER_FD, GOSSIP_FD, &peer->cs,
&peer->channel_id, msg));
if (dataloss_protect) { if (dataloss_protect) {
if (!fromwire_channel_reestablish_option_data_loss_protect(msg, if (!fromwire_channel_reestablish_option_data_loss_protect(msg,
@ -2342,6 +2351,11 @@ static void peer_reconnect(struct peer *peer,
peer->channel->changes_pending[LOCAL] = true; peer->channel->changes_pending[LOCAL] = true;
peer_billboard(true, "Reconnected, and reestablished."); peer_billboard(true, "Reconnected, and reestablished.");
if (premature_funding_locked) {
handle_peer_funding_locked(peer, premature_funding_locked);
tal_free(premature_funding_locked);
}
} }
/* Funding has locked in, and reached depth. */ /* Funding has locked in, and reached depth. */