mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-05 21:27:35 +03:00
fix deadlock when closing and receiving MAX_STREAM_DATA frames
This commit is contained in:
parent
8761cee0ef
commit
01e37e005a
1 changed files with 9 additions and 7 deletions
|
@ -221,13 +221,14 @@ func (s *sendStream) getDataForWriting(maxBytes protocol.ByteCount) ([]byte, boo
|
||||||
|
|
||||||
func (s *sendStream) Close() error {
|
func (s *sendStream) Close() error {
|
||||||
s.mutex.Lock()
|
s.mutex.Lock()
|
||||||
defer s.mutex.Unlock()
|
|
||||||
|
|
||||||
if s.canceledWrite {
|
if s.canceledWrite {
|
||||||
|
s.mutex.Unlock()
|
||||||
return fmt.Errorf("Close called for canceled stream %d", s.streamID)
|
return fmt.Errorf("Close called for canceled stream %d", s.streamID)
|
||||||
}
|
}
|
||||||
s.finishedWriting = true
|
s.finishedWriting = true
|
||||||
s.sender.onHasStreamData(s.streamID) // need to send the FIN
|
s.mutex.Unlock()
|
||||||
|
|
||||||
|
s.sender.onHasStreamData(s.streamID) // need to send the FIN, must be called without holding the mutex
|
||||||
s.ctxCancel()
|
s.ctxCancel()
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -238,7 +239,7 @@ func (s *sendStream) CancelWrite(errorCode protocol.ApplicationErrorCode) error
|
||||||
s.mutex.Unlock()
|
s.mutex.Unlock()
|
||||||
|
|
||||||
if completed {
|
if completed {
|
||||||
s.sender.onStreamCompleted(s.streamID)
|
s.sender.onStreamCompleted(s.streamID) // must be called without holding the mutex
|
||||||
}
|
}
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -271,12 +272,13 @@ func (s *sendStream) handleStopSendingFrame(frame *wire.StopSendingFrame) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *sendStream) handleMaxStreamDataFrame(frame *wire.MaxStreamDataFrame) {
|
func (s *sendStream) handleMaxStreamDataFrame(frame *wire.MaxStreamDataFrame) {
|
||||||
s.flowController.UpdateSendWindow(frame.ByteOffset)
|
|
||||||
s.mutex.Lock()
|
s.mutex.Lock()
|
||||||
if s.dataForWriting != nil {
|
hasStreamData := s.dataForWriting != nil
|
||||||
|
s.mutex.Unlock()
|
||||||
|
s.flowController.UpdateSendWindow(frame.ByteOffset)
|
||||||
|
if hasStreamData {
|
||||||
s.sender.onHasStreamData(s.streamID)
|
s.sender.onHasStreamData(s.streamID)
|
||||||
}
|
}
|
||||||
s.mutex.Unlock()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// must be called after locking the mutex
|
// must be called after locking the mutex
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue