htlcswitch: fix deadlock during chainWatcher notifications
This commit is contained in:
parent
d4e650c85d
commit
96fbc7da84
@ -18,7 +18,6 @@ import (
|
|||||||
"github.com/lightningnetwork/lnd/lnwallet"
|
"github.com/lightningnetwork/lnd/lnwallet"
|
||||||
"github.com/lightningnetwork/lnd/lnwire"
|
"github.com/lightningnetwork/lnd/lnwire"
|
||||||
"github.com/roasbeef/btcd/chaincfg/chainhash"
|
"github.com/roasbeef/btcd/chaincfg/chainhash"
|
||||||
"github.com/roasbeef/btcd/wire"
|
|
||||||
"github.com/roasbeef/btcutil"
|
"github.com/roasbeef/btcutil"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -152,11 +151,6 @@ type ChannelLinkConfig struct {
|
|||||||
// (or are close to expiry).
|
// (or are close to expiry).
|
||||||
BlockEpochs *chainntnfs.BlockEpochEvent
|
BlockEpochs *chainntnfs.BlockEpochEvent
|
||||||
|
|
||||||
// SettledContracts is used to notify that a channel has peacefully
|
|
||||||
// been closed. Once a channel has been closed the other subsystem no
|
|
||||||
// longer needs to watch for breach closes.
|
|
||||||
SettledContracts chan *wire.OutPoint
|
|
||||||
|
|
||||||
// DebugHTLC should be turned on if you want all HTLCs sent to a node
|
// DebugHTLC should be turned on if you want all HTLCs sent to a node
|
||||||
// with the debug htlc R-Hash are immediately settled in the next
|
// with the debug htlc R-Hash are immediately settled in the next
|
||||||
// available state transition.
|
// available state transition.
|
||||||
@ -289,12 +283,18 @@ func (l *channelLink) Start() error {
|
|||||||
|
|
||||||
// Before we start the link, we'll update the ChainArbitrator with the
|
// Before we start the link, we'll update the ChainArbitrator with the
|
||||||
// set of new channel signals for this channel.
|
// set of new channel signals for this channel.
|
||||||
if err := l.cfg.UpdateContractSignals(&contractcourt.ContractSignals{
|
//
|
||||||
|
// TODO(roasbeef): split goroutines within channel arb to avoid
|
||||||
|
go func() {
|
||||||
|
err := l.cfg.UpdateContractSignals(&contractcourt.ContractSignals{
|
||||||
HtlcUpdates: l.htlcUpdates,
|
HtlcUpdates: l.htlcUpdates,
|
||||||
ShortChanID: l.channel.ShortChanID(),
|
ShortChanID: l.channel.ShortChanID(),
|
||||||
}); err != nil {
|
})
|
||||||
return err
|
if err != nil {
|
||||||
|
log.Errorf("Unable to update signals for "+
|
||||||
|
"ChannelLink(%v)", l)
|
||||||
}
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
l.mailBox.Start()
|
l.mailBox.Start()
|
||||||
l.overflowQueue.Start()
|
l.overflowQueue.Start()
|
||||||
@ -643,18 +643,12 @@ out:
|
|||||||
log.Warnf("Remote peer has closed ChannelPoint(%v) on-chain",
|
log.Warnf("Remote peer has closed ChannelPoint(%v) on-chain",
|
||||||
l.channel.ChannelPoint())
|
l.channel.ChannelPoint())
|
||||||
|
|
||||||
// TODO(roasbeef): move this and above to chainJanitor
|
|
||||||
|
|
||||||
// TODO(roasbeef): remove all together
|
// TODO(roasbeef): remove all together
|
||||||
go func() {
|
go func() {
|
||||||
chanPoint := l.channel.ChannelPoint()
|
chanPoint := l.channel.ChannelPoint()
|
||||||
if err := l.cfg.Peer.WipeChannel(chanPoint); err != nil {
|
if err := l.cfg.Peer.WipeChannel(chanPoint); err != nil {
|
||||||
log.Errorf("unable to wipe channel %v", err)
|
log.Errorf("unable to wipe channel %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(roasbeef): need to send HTLC outputs to nursery
|
|
||||||
// TODO(roasbeef): or let the arb sweep?
|
|
||||||
l.cfg.SettledContracts <- chanPoint
|
|
||||||
}()
|
}()
|
||||||
|
|
||||||
break out
|
break out
|
||||||
|
Loading…
Reference in New Issue
Block a user