lnwallet: add select on quit when waiting for job from sigPool
In this commit we ensure that the channel is always able to exit by adding a select statement with a quit case when we’re waiting on the result of a job that was previously sent into the sigPool.
This commit is contained in:
parent
03ba13fcf8
commit
861412529d
@ -2938,16 +2938,19 @@ func (lc *LightningChannel) SignNextCommitment() (*btcec.Signature, []*btcec.Sig
|
||||
// gather each of the signatures in order.
|
||||
htlcSigs := make([]*btcec.Signature, 0, len(sigBatch))
|
||||
for _, htlcSigJob := range sigBatch {
|
||||
jobResp := <-htlcSigJob.resp
|
||||
|
||||
// If an error occurred, then we'll cancel any other active
|
||||
// jobs.
|
||||
select {
|
||||
case jobResp := <-htlcSigJob.resp:
|
||||
// If an error occurred, then we'll cancel any other
|
||||
// active jobs.
|
||||
if jobResp.err != nil {
|
||||
close(cancelChan)
|
||||
return nil, nil, err
|
||||
}
|
||||
|
||||
htlcSigs = append(htlcSigs, jobResp.sig)
|
||||
case <-lc.quit:
|
||||
return nil, nil, fmt.Errorf("channel shutting down")
|
||||
}
|
||||
}
|
||||
|
||||
// As we're about to proposer a new commitment state for the remote
|
||||
@ -3432,10 +3435,15 @@ func (lc *LightningChannel) ReceiveNewCommitment(commitSig *btcec.Signature,
|
||||
for i := 0; i < len(verifyJobs); i++ {
|
||||
// In the case that a single signature is invalid, we'll exit
|
||||
// early and cancel all the outstanding verification jobs.
|
||||
if err := <-verifyResps; err != nil {
|
||||
select {
|
||||
case err := <-verifyResps:
|
||||
if err != nil {
|
||||
close(cancelChan)
|
||||
return fmt.Errorf("invalid htlc signature: %v", err)
|
||||
}
|
||||
case <-lc.quit:
|
||||
return fmt.Errorf("channel shutting down")
|
||||
}
|
||||
}
|
||||
|
||||
// The signature checks out, so we can now add the new commitment to
|
||||
|
Loading…
Reference in New Issue
Block a user