mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-05 21:27:35 +03:00
fix deadlock when the crypto setup is closed while qtls writes messages
This commit is contained in:
parent
f1d14ecdea
commit
e224768e46
1 changed files with 3 additions and 10 deletions
|
@ -70,7 +70,6 @@ type cryptoSetup struct {
|
|||
|
||||
runner handshakeRunner
|
||||
|
||||
closed bool
|
||||
alertChan chan uint8
|
||||
// handshakeDone is closed as soon as the go routine running qtls.Handshake() returns
|
||||
handshakeDone chan struct{}
|
||||
|
@ -283,19 +282,13 @@ func (h *cryptoSetup) RunHandshake() {
|
|||
}
|
||||
|
||||
func (h *cryptoSetup) onError(alert uint8, message string) {
|
||||
|
||||
h.runner.OnError(qerr.CryptoError(alert, message))
|
||||
}
|
||||
|
||||
// Close closes the crypto setup.
|
||||
// It aborts the handshake, if it is still running.
|
||||
// It must only be called once.
|
||||
func (h *cryptoSetup) Close() error {
|
||||
h.mutex.Lock()
|
||||
defer h.mutex.Unlock()
|
||||
|
||||
if h.closed {
|
||||
return nil
|
||||
}
|
||||
h.closed = true
|
||||
|
||||
close(h.closeChan)
|
||||
// wait until qtls.Handshake() actually returned
|
||||
<-h.handshakeDone
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue