@ -153,6 +153,9 @@ struct peer {
/* Make sure peer is live. */
/* Make sure peer is live. */
struct timeabs last_recv ;
struct timeabs last_recv ;
/* Additional confirmations need for local lockin. */
u32 depth_togo ;
} ;
} ;
static u8 * create_channel_announcement ( const tal_t * ctx , struct peer * peer ) ;
static u8 * create_channel_announcement ( const tal_t * ctx , struct peer * peer ) ;
@ -165,8 +168,9 @@ static void billboard_update(const struct peer *peer)
if ( peer - > funding_locked [ LOCAL ] & & peer - > funding_locked [ REMOTE ] )
if ( peer - > funding_locked [ LOCAL ] & & peer - > funding_locked [ REMOTE ] )
funding_status = " Funding transaction locked. " ;
funding_status = " Funding transaction locked. " ;
else if ( ! peer - > funding_locked [ LOCAL ] & & ! peer - > funding_locked [ REMOTE ] )
else if ( ! peer - > funding_locked [ LOCAL ] & & ! peer - > funding_locked [ REMOTE ] )
/* FIXME: Say how many blocks to go! */
funding_status = tal_fmt ( tmpctx ,
funding_status = " Funding needs more confirmations. " ;
" Funding needs %d confirmations to reach lockin. " ,
peer - > depth_togo ) ;
else if ( peer - > funding_locked [ LOCAL ] & & ! peer - > funding_locked [ REMOTE ] )
else if ( peer - > funding_locked [ LOCAL ] & & ! peer - > funding_locked [ REMOTE ] )
funding_status = " We've confirmed funding, they haven't yet. " ;
funding_status = " We've confirmed funding, they haven't yet. " ;
else if ( ! peer - > funding_locked [ LOCAL ] & & peer - > funding_locked [ REMOTE ] )
else if ( ! peer - > funding_locked [ LOCAL ] & & peer - > funding_locked [ REMOTE ] )
@ -2386,36 +2390,52 @@ static void peer_reconnect(struct peer *peer,
}
}
}
}
/* Funding has locked in, and reached depth. */
/* ignores the funding_depth unless depth >= minimum_depth
static void handle_funding_locked ( struct peer * peer , const u8 * msg )
* ( except to update billboard , and set peer - > depth_togo ) . */
static void handle_funding_depth ( struct peer * peer , const u8 * msg )
{
{
unsigned int depth ;
u32 depth ;
struct short_channel_id * scid ;
if ( ! fromwire_channel_funding_locked ( msg ,
if ( ! fromwire_channel_funding_depth ( tmpctx ,
& peer - > short_channel_ids [ LOCAL ] ,
msg ,
& depth ) )
& scid ,
master_badmsg ( WIRE_CHANNEL_FUNDING_LOCKED , msg ) ;
& depth ) )
master_badmsg ( WIRE_CHANNEL_FUNDING_DEPTH , msg ) ;
/* Too late, we're shutting down! */
/* Too late, we're shutting down! */
if ( peer - > shutdown_sent [ LOCAL ] )
if ( peer - > shutdown_sent [ LOCAL ] )
return ;
return ;
if ( ! peer - > funding_locked [ LOCAL ] ) {
if ( depth < peer - > channel - > minimum_depth ) {
status_trace ( " funding_locked: sending commit index % " PRIu64 " : %s " ,
peer - > depth_togo = peer - > channel - > minimum_depth - depth ;
peer - > next_index [ LOCAL ] ,
type_to_string ( tmpctx , struct pubkey ,
& peer - > next_local_per_commit ) ) ;
msg = towire_funding_locked ( NULL ,
& peer - > channel_id ,
& peer - > next_local_per_commit ) ;
sync_crypto_write ( & peer - > cs , PEER_FD , take ( msg ) ) ;
peer - > funding_locked [ LOCAL ] = true ;
}
peer - > announce_depth_reached = ( depth > = ANNOUNCE_MIN_DEPTH ) ;
} else {
peer - > depth_togo = 0 ;
/* Send temporary or final announcements */
assert ( scid ) ;
channel_announcement_negotiate ( peer ) ;
peer - > short_channel_ids [ LOCAL ] = * scid ;
if ( ! peer - > funding_locked [ LOCAL ] ) {
status_trace ( " funding_locked: sending commit index % " PRIu64 " : %s " ,
peer - > next_index [ LOCAL ] ,
type_to_string ( tmpctx , struct pubkey ,
& peer - > next_local_per_commit ) ) ;
msg = towire_funding_locked ( NULL ,
& peer - > channel_id ,
& peer - > next_local_per_commit ) ;
sync_crypto_write ( & peer - > cs , PEER_FD , take ( msg ) ) ;
peer - > funding_locked [ LOCAL ] = true ;
}
peer - > announce_depth_reached = ( depth > = ANNOUNCE_MIN_DEPTH ) ;
/* Send temporary or final announcements */
channel_announcement_negotiate ( peer ) ;
}
billboard_update ( peer ) ;
billboard_update ( peer ) ;
}
}
@ -2654,8 +2674,8 @@ static void req_in(struct peer *peer, const u8 *msg)
enum channel_wire_type t = fromwire_peektype ( msg ) ;
enum channel_wire_type t = fromwire_peektype ( msg ) ;
switch ( t ) {
switch ( t ) {
case WIRE_CHANNEL_FUNDING_LOCKED :
case WIRE_CHANNEL_FUNDING_DEPTH :
handle_funding_locked ( peer , msg ) ;
handle_funding_depth ( peer , msg ) ;
return ;
return ;
case WIRE_CHANNEL_OFFER_HTLC :
case WIRE_CHANNEL_OFFER_HTLC :
handle_offer_htlc ( peer , msg ) ;
handle_offer_htlc ( peer , msg ) ;
@ -2744,6 +2764,7 @@ static void init_channel(struct peer *peer)
u8 * funding_signed ;
u8 * funding_signed ;
const u8 * msg ;
const u8 * msg ;
u32 feerate_per_kw [ NUM_SIDES ] ;
u32 feerate_per_kw [ NUM_SIDES ] ;
u32 minimum_depth ;
struct secret last_remote_per_commit_secret ;
struct secret last_remote_per_commit_secret ;
assert ( ! ( fcntl ( MASTER_FD , F_GETFL ) & O_NONBLOCK ) ) ;
assert ( ! ( fcntl ( MASTER_FD , F_GETFL ) & O_NONBLOCK ) ) ;
@ -2755,6 +2776,7 @@ static void init_channel(struct peer *peer)
& peer - > chain_hash ,
& peer - > chain_hash ,
& funding_txid , & funding_txout ,
& funding_txid , & funding_txout ,
& funding ,
& funding ,
& minimum_depth ,
& conf [ LOCAL ] , & conf [ REMOTE ] ,
& conf [ LOCAL ] , & conf [ REMOTE ] ,
feerate_per_kw ,
feerate_per_kw ,
& peer - > feerate_min , & peer - > feerate_max ,
& peer - > feerate_min , & peer - > feerate_max ,
@ -2797,8 +2819,9 @@ static void init_channel(struct peer *peer)
& funding_signed ,
& funding_signed ,
& peer - > announce_depth_reached ,
& peer - > announce_depth_reached ,
& last_remote_per_commit_secret ,
& last_remote_per_commit_secret ,
& peer - > localfeatures ) )
& peer - > localfeatures ) ) {
master_badmsg ( WIRE_CHANNEL_INIT , msg ) ;
master_badmsg ( WIRE_CHANNEL_INIT , msg ) ;
}
status_trace ( " init %s: remote_per_commit = %s, old_remote_per_commit = %s "
status_trace ( " init %s: remote_per_commit = %s, old_remote_per_commit = %s "
" next_idx_local = % " PRIu64
" next_idx_local = % " PRIu64
@ -2828,7 +2851,9 @@ static void init_channel(struct peer *peer)
peer - > channel = new_full_channel ( peer ,
peer - > channel = new_full_channel ( peer ,
& peer - > chain_hash ,
& peer - > chain_hash ,
& funding_txid , funding_txout ,
& funding_txid ,
funding_txout ,
minimum_depth ,
funding ,
funding ,
local_msat ,
local_msat ,
feerate_per_kw ,
feerate_per_kw ,
@ -2865,6 +2890,9 @@ static void init_channel(struct peer *peer)
if ( peer - > channel - > funder = = LOCAL )
if ( peer - > channel - > funder = = LOCAL )
peer - > desired_feerate = feerate_per_kw [ REMOTE ] ;
peer - > desired_feerate = feerate_per_kw [ REMOTE ] ;
/* from now we need keep watch over WIRE_CHANNEL_FUNDING_DEPTH */
peer - > depth_togo = minimum_depth ;
/* OK, now we can process peer messages. */
/* OK, now we can process peer messages. */
if ( reconnected )
if ( reconnected )
peer_reconnect ( peer , & last_remote_per_commit_secret ) ;
peer_reconnect ( peer , & last_remote_per_commit_secret ) ;