fix deadlock when concurrently closing server and transport (#4332)

* server: fix deadlock when closing concurrently with transport

* add test for checking no deadlock
This commit is contained in:
Sukun 2024-03-03 16:30:28 +05:30 committed by GitHub
parent ba1fbbe964
commit d6269b71af
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 34 additions and 9 deletions

View file

@ -98,7 +98,7 @@ type baseServer struct {
protocol.Version,
) quicConn
closeOnce sync.Once
closeMx sync.Mutex
errorChan chan struct{} // is closed when the server is closed
closeErr error
running chan struct{} // closed as soon as run() returns
@ -338,15 +338,19 @@ func (s *baseServer) Close() error {
}
func (s *baseServer) close(e error, notifyOnClose bool) {
s.closeOnce.Do(func() {
s.closeErr = e
close(s.errorChan)
s.closeMx.Lock()
if s.closeErr != nil {
s.closeMx.Unlock()
return
}
s.closeErr = e
close(s.errorChan)
<-s.running
s.closeMx.Unlock()
<-s.running
if notifyOnClose {
s.onClose()
}
})
if notifyOnClose {
s.onClose()
}
}
// Addr returns the server's network address