Skip to content

Commit

Permalink
tapchannel: improve quit handling for aux signer
Browse files Browse the repository at this point in the history
In this commit, we add checks of the aux signer cancel and quit signals
at all points during aux sig batch processing when a response may be
sent. This mirrors the signal handling used in the lnwallet sigpool
worker goroutine. We also add an extra check for the job cancel signal,
since it could have been sent by LND before it could be sent from here.
  • Loading branch information
jharveyb committed Sep 8, 2024
1 parent 2cefb08 commit 1c6f95e
Showing 1 changed file with 41 additions and 9 deletions.
50 changes: 41 additions & 9 deletions tapchannel/aux_leaf_signer.go
Original file line number Diff line number Diff line change
Expand Up @@ -240,36 +240,53 @@ func (s *AuxLeafSigner) processAuxSigBatch(chanState *channeldb.OpenChannel,

defer s.Wg.Done()

shutdownErr := fmt.Errorf("tapd is shutting down")
log.Tracef("Processing %d aux sig jobs", len(sigJobs))

for idx := range sigJobs {
sigJob := sigJobs[idx]
cancelAndErr := func(err error) {
log.Errorf("Error processing aux sig job: %v", err)

close(sigJob.Cancel)
// Check that the cancel signal was not already sent
// before cancelling all jobs. The cancel signal must
// only be sent exactly once.
select {
case <-sigJob.Cancel:
default:
close(sigJob.Cancel)
}

sigJob.Resp <- lnwallet.AuxSigJobResp{
Err: err,
}
}

// If we're shutting down, we cancel the job and return.
// Check for cancel or quit signals before beginning the job.
select {
case <-sigJob.Cancel:
continue
case <-s.Quit:
cancelAndErr(fmt.Errorf("tapd is shutting down"))
cancelAndErr(shutdownErr)
return

default:
}

// If there is no commit blob, this isn't a custom channel. We
// still need to signal the job as done though, even if we don't
// have a signature to return.
if sigJob.CommitBlob.IsNone() {
sigJob.Resp <- lnwallet.AuxSigJobResp{
select {
case sigJob.Resp <- lnwallet.AuxSigJobResp{
HtlcIndex: sigJob.HTLC.HtlcIndex,
}:
continue
case <-sigJob.Cancel:
continue
case <-s.Quit:
cancelAndErr(shutdownErr)
return
}
continue
}

com, err := cmsg.DecodeCommitment(
Expand Down Expand Up @@ -299,10 +316,17 @@ func (s *AuxLeafSigner) processAuxSigBatch(chanState *channeldb.OpenChannel,
// If the HTLC doesn't have any asset outputs, it's not an
// asset HTLC, so we can skip it.
if len(htlcOutputs) == 0 {
sigJob.Resp <- lnwallet.AuxSigJobResp{
select {
case sigJob.Resp <- lnwallet.AuxSigJobResp{
HtlcIndex: sigJob.HTLC.HtlcIndex,
}:
continue
case <-sigJob.Cancel:
continue
case <-s.Quit:
cancelAndErr(shutdownErr)
return
}
continue
}

resp, err := s.generateHtlcSignature(
Expand All @@ -318,7 +342,15 @@ func (s *AuxLeafSigner) processAuxSigBatch(chanState *channeldb.OpenChannel,
// Success!
log.Tracef("Generated HTLC signature for HTLC with index %d",
sigJob.HTLC.HtlcIndex)
sigJob.Resp <- resp

select {
case sigJob.Resp <- resp:
case <-sigJob.Cancel:
continue
case <-s.Quit:
cancelAndErr(shutdownErr)
return
}
}
}

Expand Down

0 comments on commit 1c6f95e

Please sign in to comment.