mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-04 20:57:36 +03:00
remove the params negotiator
This commit is contained in:
parent
925a52f032
commit
f3e9bf4332
37 changed files with 1013 additions and 1296 deletions
|
@ -5,7 +5,6 @@ import (
|
|||
"fmt"
|
||||
"sync"
|
||||
|
||||
"github.com/lucas-clemente/quic-go/internal/handshake"
|
||||
"github.com/lucas-clemente/quic-go/internal/protocol"
|
||||
"github.com/lucas-clemente/quic-go/internal/utils"
|
||||
"github.com/lucas-clemente/quic-go/qerr"
|
||||
|
@ -14,7 +13,6 @@ import (
|
|||
type streamsMap struct {
|
||||
mutex sync.RWMutex
|
||||
|
||||
connParams handshake.ParamsNegotiator
|
||||
perspective protocol.Perspective
|
||||
|
||||
streams map[protocol.StreamID]*stream
|
||||
|
@ -36,6 +34,7 @@ type streamsMap struct {
|
|||
numOutgoingStreams uint32
|
||||
numIncomingStreams uint32
|
||||
maxIncomingStreams uint32
|
||||
maxOutgoingStreams uint32
|
||||
}
|
||||
|
||||
type streamLambda func(*stream) (bool, error)
|
||||
|
@ -44,7 +43,7 @@ type newStreamLambda func(protocol.StreamID) *stream
|
|||
|
||||
var errMapAccess = errors.New("streamsMap: Error accessing the streams map")
|
||||
|
||||
func newStreamsMap(newStream newStreamLambda, removeStreamCallback removeStreamCallback, pers protocol.Perspective, connParams handshake.ParamsNegotiator) *streamsMap {
|
||||
func newStreamsMap(newStream newStreamLambda, removeStreamCallback removeStreamCallback, pers protocol.Perspective) *streamsMap {
|
||||
// add some tolerance to the maximum incoming streams value
|
||||
maxStreams := uint32(protocol.MaxIncomingStreams)
|
||||
maxIncomingStreams := utils.MaxUint32(
|
||||
|
@ -57,7 +56,6 @@ func newStreamsMap(newStream newStreamLambda, removeStreamCallback removeStreamC
|
|||
openStreams: make([]protocol.StreamID, 0),
|
||||
newStream: newStream,
|
||||
removeStreamCallback: removeStreamCallback,
|
||||
connParams: connParams,
|
||||
maxIncomingStreams: maxIncomingStreams,
|
||||
}
|
||||
sm.nextStreamOrErrCond.L = &sm.mutex
|
||||
|
@ -66,6 +64,8 @@ func newStreamsMap(newStream newStreamLambda, removeStreamCallback removeStreamC
|
|||
if pers == protocol.PerspectiveClient {
|
||||
sm.nextStream = 1
|
||||
sm.nextStreamToAccept = 2
|
||||
// TODO: find a better solution for opening the crypto stream
|
||||
sm.maxOutgoingStreams = 1 // allow the crypto stream
|
||||
} else {
|
||||
sm.nextStream = 2
|
||||
sm.nextStreamToAccept = 1
|
||||
|
@ -159,7 +159,7 @@ func (m *streamsMap) openRemoteStream(id protocol.StreamID) (*stream, error) {
|
|||
|
||||
func (m *streamsMap) openStreamImpl() (*stream, error) {
|
||||
id := m.nextStream
|
||||
if m.numOutgoingStreams >= m.connParams.GetMaxOutgoingStreams() {
|
||||
if m.numOutgoingStreams >= m.maxOutgoingStreams {
|
||||
return nil, qerr.TooManyOpenStreams
|
||||
}
|
||||
|
||||
|
@ -340,3 +340,9 @@ func (m *streamsMap) CloseWithError(err error) {
|
|||
m.streams[s].Cancel(err)
|
||||
}
|
||||
}
|
||||
|
||||
func (m *streamsMap) UpdateMaxStreamLimit(limit uint32) {
|
||||
m.mutex.Lock()
|
||||
defer m.mutex.Unlock()
|
||||
m.maxOutgoingStreams = limit
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue