From ebc7541953269b39cd73d703166b9b8ee7b34e37 Mon Sep 17 00:00:00 2001 From: "Jason A. Donenfeld" <Jason@zx2c4.com> Date: Mon, 24 Sep 2018 01:52:02 +0200 Subject: Fix shutdown races --- send.go | 43 ++++++++++++++++++++++++++++++++++++------- 1 file changed, 36 insertions(+), 7 deletions(-) (limited to 'send.go') diff --git a/send.go b/send.go index fa84043..b636a43 100644 --- a/send.go +++ b/send.go @@ -341,12 +341,6 @@ func (peer *Peer) RoutineNonce() { device := peer.device logDebug := device.log.Debug - defer func() { - logDebug.Println(peer, "- Routine: nonce worker - stopped") - peer.queue.packetInNonceQueueIsAwaitingKey.Set(false) - peer.routines.stopping.Done() - }() - flush := func() { for { select { @@ -359,6 +353,13 @@ func (peer *Peer) RoutineNonce() { } } + defer func() { + flush() + logDebug.Println(peer, "- Routine: nonce worker - stopped") + peer.queue.packetInNonceQueueIsAwaitingKey.Set(false) + peer.routines.stopping.Done() + }() + peer.routines.starting.Done() logDebug.Println(peer, "- Routine: nonce worker - started") @@ -461,6 +462,19 @@ func (device *Device) RoutineEncryption() { logDebug := device.log.Debug defer func() { + for { + select { + case elem, ok := <-device.queue.encryption: + if ok && !elem.IsDropped() { + elem.Drop() + device.PutMessageBuffer(elem.buffer) + elem.mutex.Unlock() + } + default: + goto out + } + } + out: logDebug.Println("Routine: encryption worker - stopped") device.state.stopping.Done() }() @@ -485,7 +499,6 @@ func (device *Device) RoutineEncryption() { // check if dropped if elem.IsDropped() { - device.PutOutboundElement(elem) continue } @@ -540,6 +553,22 @@ func (peer *Peer) RoutineSequentialSender() { logError := device.log.Error defer func() { + for { + select { + case elem, ok := <-peer.queue.outbound: + if ok { + if !elem.IsDropped() { + device.PutMessageBuffer(elem.buffer) + elem.Drop() + } + device.PutOutboundElement(elem) + elem.mutex.Unlock() + } + default: + goto out + } + } + out: logDebug.Println(peer, "- Routine: sequential sender - stopped") peer.routines.stopping.Done() }() -- cgit v1.2.3