Merge pull request #5116 from joostjager/mc-deadlock
routing: fix mission control deadlock
This commit is contained in:
commit
ca96e66b43
@ -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)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user