Merge pull request #5116 from joostjager/mc-deadlock

routing: fix mission control deadlock
This commit is contained in:
Olaoluwa Osuntokun 2021-04-05 20:02:57 -07:00 committed by GitHub
commit ca96e66b43
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -238,9 +238,6 @@ func NewMissionControl(db kvdb.Backend, self route.Vertex,
func (m *MissionControl) init() error { func (m *MissionControl) init() error {
log.Debugf("Mission control state reconstruction started") log.Debugf("Mission control state reconstruction started")
m.Lock()
defer m.Unlock()
start := time.Now() start := time.Now()
results, err := m.store.fetchAll() results, err := m.store.fetchAll()
@ -392,9 +389,6 @@ func (m *MissionControl) ReportPaymentFail(paymentID uint64, rt *route.Route,
failureSourceIdx *int, failure lnwire.FailureMessage) ( failureSourceIdx *int, failure lnwire.FailureMessage) (
*channeldb.FailureReason, error) { *channeldb.FailureReason, error) {
m.Lock()
defer m.Unlock()
timestamp := m.now() timestamp := m.now()
result := &paymentResult{ result := &paymentResult{
@ -415,9 +409,6 @@ func (m *MissionControl) ReportPaymentFail(paymentID uint64, rt *route.Route,
func (m *MissionControl) ReportPaymentSuccess(paymentID uint64, func (m *MissionControl) ReportPaymentSuccess(paymentID uint64,
rt *route.Route) error { rt *route.Route) error {
m.Lock()
defer m.Unlock()
timestamp := m.now() timestamp := m.now()
result := &paymentResult{ result := &paymentResult{
@ -442,6 +433,9 @@ func (m *MissionControl) processPaymentResult(result *paymentResult) (
return nil, err return nil, err
} }
m.Lock()
defer m.Unlock()
// Apply result to update mission control state. // Apply result to update mission control state.
reason := m.applyPaymentResult(result) reason := m.applyPaymentResult(result)