htlcswitch: remove batch counter
Now that channel exposes the number of pending local updates, it is no longer necessary to track the batch size separately in the link.
This commit is contained in:
parent
2482d84d7d
commit
5078d662ef
@ -291,15 +291,6 @@ type channelLink struct {
|
|||||||
// sure we don't process any more updates.
|
// sure we don't process any more updates.
|
||||||
failed bool
|
failed bool
|
||||||
|
|
||||||
// batchCounter is the number of updates which we received from remote
|
|
||||||
// side, but not include in commitment transaction yet and plus the
|
|
||||||
// current number of settles that have been sent, but not yet committed
|
|
||||||
// to the commitment.
|
|
||||||
//
|
|
||||||
// TODO(andrew.shvv) remove after we add additional BatchNumber()
|
|
||||||
// method in state machine.
|
|
||||||
batchCounter uint32
|
|
||||||
|
|
||||||
// keystoneBatch represents a volatile list of keystones that must be
|
// keystoneBatch represents a volatile list of keystones that must be
|
||||||
// written before attempting to sign the next commitment txn. These
|
// written before attempting to sign the next commitment txn. These
|
||||||
// represent all the HTLC's forwarded to the link from the switch. Once
|
// represent all the HTLC's forwarded to the link from the switch. Once
|
||||||
@ -1027,7 +1018,7 @@ out:
|
|||||||
// the batch ticker so that it can be cleared. Otherwise pause
|
// the batch ticker so that it can be cleared. Otherwise pause
|
||||||
// the ticker to prevent waking up the htlcManager while the
|
// the ticker to prevent waking up the htlcManager while the
|
||||||
// batch is empty.
|
// batch is empty.
|
||||||
if l.batchCounter > 0 {
|
if l.channel.PendingLocalUpdateCount() > 0 {
|
||||||
l.cfg.BatchTicker.Resume()
|
l.cfg.BatchTicker.Resume()
|
||||||
} else {
|
} else {
|
||||||
l.cfg.BatchTicker.Pause()
|
l.cfg.BatchTicker.Pause()
|
||||||
@ -1145,9 +1136,9 @@ out:
|
|||||||
if ok && l.overflowQueue.Length() != 0 {
|
if ok && l.overflowQueue.Length() != 0 {
|
||||||
l.log.Infof("downstream htlc add update with "+
|
l.log.Infof("downstream htlc add update with "+
|
||||||
"payment hash(%x) have been added to "+
|
"payment hash(%x) have been added to "+
|
||||||
"reprocessing queue, batch_size=%v",
|
"reprocessing queue, pend_updates=%v",
|
||||||
htlc.PaymentHash[:],
|
htlc.PaymentHash[:],
|
||||||
l.batchCounter)
|
l.channel.PendingLocalUpdateCount())
|
||||||
|
|
||||||
l.overflowQueue.AddPkt(pkt)
|
l.overflowQueue.AddPkt(pkt)
|
||||||
continue
|
continue
|
||||||
@ -1225,8 +1216,6 @@ loop:
|
|||||||
func (l *channelLink) processHodlEvent(hodlEvent invoices.HodlEvent,
|
func (l *channelLink) processHodlEvent(hodlEvent invoices.HodlEvent,
|
||||||
htlc hodlHtlc) error {
|
htlc hodlHtlc) error {
|
||||||
|
|
||||||
l.batchCounter++
|
|
||||||
|
|
||||||
circuitKey := hodlEvent.CircuitKey
|
circuitKey := hodlEvent.CircuitKey
|
||||||
|
|
||||||
// Determine required action for the resolution.
|
// Determine required action for the resolution.
|
||||||
@ -1296,9 +1285,9 @@ func (l *channelLink) handleDownStreamPkt(pkt *htlcPacket, isReProcess bool) {
|
|||||||
case lnwallet.ErrMaxHTLCNumber:
|
case lnwallet.ErrMaxHTLCNumber:
|
||||||
l.log.Infof("downstream htlc add update with "+
|
l.log.Infof("downstream htlc add update with "+
|
||||||
"payment hash(%x) have been added to "+
|
"payment hash(%x) have been added to "+
|
||||||
"reprocessing queue, batch: %v",
|
"reprocessing queue, pend_updates: %v",
|
||||||
htlc.PaymentHash[:],
|
htlc.PaymentHash[:],
|
||||||
l.batchCounter)
|
l.channel.PendingLocalUpdateCount())
|
||||||
|
|
||||||
l.overflowQueue.AddPkt(pkt)
|
l.overflowQueue.AddPkt(pkt)
|
||||||
return
|
return
|
||||||
@ -1375,8 +1364,9 @@ func (l *channelLink) handleDownStreamPkt(pkt *htlcPacket, isReProcess bool) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
l.log.Tracef("received downstream htlc: payment_hash=%x, "+
|
l.log.Tracef("received downstream htlc: payment_hash=%x, "+
|
||||||
"local_log_index=%v, batch_size=%v",
|
"local_log_index=%v, pend_updates=%v",
|
||||||
htlc.PaymentHash[:], index, l.batchCounter+1)
|
htlc.PaymentHash[:], index,
|
||||||
|
l.channel.PendingLocalUpdateCount())
|
||||||
|
|
||||||
pkt.outgoingChanID = l.ShortChanID()
|
pkt.outgoingChanID = l.ShortChanID()
|
||||||
pkt.outgoingHTLCID = index
|
pkt.outgoingHTLCID = index
|
||||||
@ -1507,11 +1497,11 @@ func (l *channelLink) handleDownStreamPkt(pkt *htlcPacket, isReProcess bool) {
|
|||||||
isSettle = true
|
isSettle = true
|
||||||
}
|
}
|
||||||
|
|
||||||
l.batchCounter++
|
|
||||||
|
|
||||||
// If this newly added update exceeds the min batch size for adds, or
|
// If this newly added update exceeds the min batch size for adds, or
|
||||||
// this is a settle request, then initiate an update.
|
// this is a settle request, then initiate an update.
|
||||||
if l.batchCounter >= l.cfg.BatchSize || isSettle {
|
if l.channel.PendingLocalUpdateCount() >= uint64(l.cfg.BatchSize) ||
|
||||||
|
isSettle {
|
||||||
|
|
||||||
if err := l.updateCommitTx(); err != nil {
|
if err := l.updateCommitTx(); err != nil {
|
||||||
l.fail(LinkFailureError{code: ErrInternalError},
|
l.fail(LinkFailureError{code: ErrInternalError},
|
||||||
"unable to update commitment: %v", err)
|
"unable to update commitment: %v", err)
|
||||||
@ -1989,8 +1979,9 @@ func (l *channelLink) updateCommitTx() error {
|
|||||||
theirCommitSig, htlcSigs, pendingHTLCs, err := l.channel.SignNextCommitment()
|
theirCommitSig, htlcSigs, pendingHTLCs, err := l.channel.SignNextCommitment()
|
||||||
if err == lnwallet.ErrNoWindow {
|
if err == lnwallet.ErrNoWindow {
|
||||||
l.log.Tracef("revocation window exhausted, unable to send: "+
|
l.log.Tracef("revocation window exhausted, unable to send: "+
|
||||||
"%v, dangling_opens=%v, dangling_closes%v",
|
"%v, pend_updates=%v, dangling_closes%v",
|
||||||
l.batchCounter, newLogClosure(func() string {
|
l.channel.PendingLocalUpdateCount(),
|
||||||
|
newLogClosure(func() string {
|
||||||
return spew.Sdump(l.openedCircuits)
|
return spew.Sdump(l.openedCircuits)
|
||||||
}),
|
}),
|
||||||
newLogClosure(func() string {
|
newLogClosure(func() string {
|
||||||
@ -2036,10 +2027,6 @@ func (l *channelLink) updateCommitTx() error {
|
|||||||
}
|
}
|
||||||
l.logCommitTick = nil
|
l.logCommitTick = nil
|
||||||
|
|
||||||
// Finally, clear our the current batch, so we can accurately make
|
|
||||||
// further batch flushing decisions.
|
|
||||||
l.batchCounter = 0
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user