mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-03 20:27:35 +03:00
make the outgoing streams map work with stream 0
Stream 0 is now a valid stream ID used for application data, so the streams map must be able to (block on) opening this stream.
This commit is contained in:
parent
08008b680e
commit
5fc2e12038
4 changed files with 29 additions and 6 deletions
|
@ -21,6 +21,7 @@ type outgoingUniStreamsMap struct {
|
|||
|
||||
nextStream protocol.StreamID // stream ID of the stream returned by OpenStream(Sync)
|
||||
maxStream protocol.StreamID // the maximum stream ID we're allowed to open
|
||||
maxStreamSet bool // was maxStream set. If not, it's not possible to any stream (also works for stream 0)
|
||||
highestBlocked protocol.StreamID // the highest stream ID that we queued a STREAM_ID_BLOCKED frame for
|
||||
|
||||
newStream func(protocol.StreamID) sendStreamI
|
||||
|
@ -71,7 +72,7 @@ func (m *outgoingUniStreamsMap) openStreamImpl() (sendStreamI, error) {
|
|||
if m.closeErr != nil {
|
||||
return nil, m.closeErr
|
||||
}
|
||||
if m.nextStream > m.maxStream {
|
||||
if !m.maxStreamSet || m.nextStream > m.maxStream {
|
||||
if m.maxStream == 0 || m.highestBlocked < m.maxStream {
|
||||
m.queueStreamIDBlocked(&wire.StreamIDBlockedFrame{StreamID: m.maxStream})
|
||||
m.highestBlocked = m.maxStream
|
||||
|
@ -108,8 +109,9 @@ func (m *outgoingUniStreamsMap) DeleteStream(id protocol.StreamID) error {
|
|||
|
||||
func (m *outgoingUniStreamsMap) SetMaxStream(id protocol.StreamID) {
|
||||
m.mutex.Lock()
|
||||
if id > m.maxStream {
|
||||
if !m.maxStreamSet || id > m.maxStream {
|
||||
m.maxStream = id
|
||||
m.maxStreamSet = true
|
||||
m.cond.Broadcast()
|
||||
}
|
||||
m.mutex.Unlock()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue