mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-04 20:57:36 +03:00
use a uint64 for stream counts
This commit is contained in:
parent
e8de94485c
commit
0f931ca54e
7 changed files with 34 additions and 17 deletions
|
@ -31,7 +31,7 @@ func (s StreamID) Type() StreamType {
|
||||||
|
|
||||||
// MaxStreamID is the highest stream ID that a peer is allowed to open,
|
// MaxStreamID is the highest stream ID that a peer is allowed to open,
|
||||||
// when it is allowed to open numStreams.
|
// when it is allowed to open numStreams.
|
||||||
func MaxStreamID(stype StreamType, numStreams int, pers Perspective) StreamID {
|
func MaxStreamID(stype StreamType, numStreams uint64, pers Perspective) StreamID {
|
||||||
if numStreams == 0 {
|
if numStreams == 0 {
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
18
session.go
18
session.go
|
@ -158,7 +158,14 @@ var newSession = func(
|
||||||
s.preSetup()
|
s.preSetup()
|
||||||
initialStream := newCryptoStream()
|
initialStream := newCryptoStream()
|
||||||
handshakeStream := newCryptoStream()
|
handshakeStream := newCryptoStream()
|
||||||
s.streamsMap = newStreamsMap(s, s.newFlowController, s.config.MaxIncomingStreams, s.config.MaxIncomingUniStreams, s.perspective, s.version)
|
s.streamsMap = newStreamsMap(
|
||||||
|
s,
|
||||||
|
s.newFlowController,
|
||||||
|
uint64(s.config.MaxIncomingStreams),
|
||||||
|
uint64(s.config.MaxIncomingUniStreams),
|
||||||
|
s.perspective,
|
||||||
|
s.version,
|
||||||
|
)
|
||||||
s.framer = newFramer(s.streamsMap, s.version)
|
s.framer = newFramer(s.streamsMap, s.version)
|
||||||
cs, err := handshake.NewCryptoSetupServer(
|
cs, err := handshake.NewCryptoSetupServer(
|
||||||
initialStream,
|
initialStream,
|
||||||
|
@ -248,7 +255,14 @@ var newClientSession = func(
|
||||||
s.cryptoStreamHandler = cs
|
s.cryptoStreamHandler = cs
|
||||||
s.cryptoStreamManager = newCryptoStreamManager(cs, initialStream, handshakeStream)
|
s.cryptoStreamManager = newCryptoStreamManager(cs, initialStream, handshakeStream)
|
||||||
s.unpacker = newPacketUnpacker(cs, s.version)
|
s.unpacker = newPacketUnpacker(cs, s.version)
|
||||||
s.streamsMap = newStreamsMap(s, s.newFlowController, s.config.MaxIncomingStreams, s.config.MaxIncomingUniStreams, s.perspective, s.version)
|
s.streamsMap = newStreamsMap(
|
||||||
|
s,
|
||||||
|
s.newFlowController,
|
||||||
|
uint64(s.config.MaxIncomingStreams),
|
||||||
|
uint64(s.config.MaxIncomingUniStreams),
|
||||||
|
s.perspective,
|
||||||
|
s.version,
|
||||||
|
)
|
||||||
s.framer = newFramer(s.streamsMap, s.version)
|
s.framer = newFramer(s.streamsMap, s.version)
|
||||||
s.packer = newPacketPacker(
|
s.packer = newPacketPacker(
|
||||||
s.destConnID,
|
s.destConnID,
|
||||||
|
|
|
@ -26,8 +26,8 @@ var _ streamManager = &streamsMap{}
|
||||||
func newStreamsMap(
|
func newStreamsMap(
|
||||||
sender streamSender,
|
sender streamSender,
|
||||||
newFlowController func(protocol.StreamID) flowcontrol.StreamFlowController,
|
newFlowController func(protocol.StreamID) flowcontrol.StreamFlowController,
|
||||||
maxIncomingStreams int,
|
maxIncomingStreams uint64,
|
||||||
maxIncomingUniStreams int,
|
maxIncomingUniStreams uint64,
|
||||||
perspective protocol.Perspective,
|
perspective protocol.Perspective,
|
||||||
version protocol.VersionNumber,
|
version protocol.VersionNumber,
|
||||||
) streamManager {
|
) streamManager {
|
||||||
|
@ -162,8 +162,8 @@ func (m *streamsMap) HandleMaxStreamIDFrame(f *wire.MaxStreamIDFrame) error {
|
||||||
|
|
||||||
func (m *streamsMap) UpdateLimits(p *handshake.TransportParameters) {
|
func (m *streamsMap) UpdateLimits(p *handshake.TransportParameters) {
|
||||||
// Max{Uni,Bidi}StreamID returns the highest stream ID that the peer is allowed to open.
|
// Max{Uni,Bidi}StreamID returns the highest stream ID that the peer is allowed to open.
|
||||||
m.outgoingBidiStreams.SetMaxStream(protocol.MaxStreamID(protocol.StreamTypeBidi, int(p.MaxBidiStreams), m.perspective))
|
m.outgoingBidiStreams.SetMaxStream(protocol.MaxStreamID(protocol.StreamTypeBidi, p.MaxBidiStreams, m.perspective))
|
||||||
m.outgoingUniStreams.SetMaxStream(protocol.MaxStreamID(protocol.StreamTypeUni, int(p.MaxUniStreams), m.perspective))
|
m.outgoingUniStreams.SetMaxStream(protocol.MaxStreamID(protocol.StreamTypeUni, p.MaxUniStreams, m.perspective))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *streamsMap) CloseWithError(err error) {
|
func (m *streamsMap) CloseWithError(err error) {
|
||||||
|
|
|
@ -21,7 +21,7 @@ type incomingBidiStreamsMap struct {
|
||||||
nextStreamToAccept protocol.StreamID // the next stream that will be returned by AcceptStream()
|
nextStreamToAccept protocol.StreamID // the next stream that will be returned by AcceptStream()
|
||||||
nextStreamToOpen protocol.StreamID // the highest stream that the peer openend
|
nextStreamToOpen protocol.StreamID // the highest stream that the peer openend
|
||||||
maxStream protocol.StreamID // the highest stream that the peer is allowed to open
|
maxStream protocol.StreamID // the highest stream that the peer is allowed to open
|
||||||
maxNumStreams int // maximum number of streams
|
maxNumStreams uint64 // maximum number of streams
|
||||||
|
|
||||||
newStream func(protocol.StreamID) streamI
|
newStream func(protocol.StreamID) streamI
|
||||||
queueMaxStreamID func(*wire.MaxStreamIDFrame)
|
queueMaxStreamID func(*wire.MaxStreamIDFrame)
|
||||||
|
@ -32,7 +32,7 @@ type incomingBidiStreamsMap struct {
|
||||||
func newIncomingBidiStreamsMap(
|
func newIncomingBidiStreamsMap(
|
||||||
nextStreamToAccept protocol.StreamID,
|
nextStreamToAccept protocol.StreamID,
|
||||||
initialMaxStreamID protocol.StreamID,
|
initialMaxStreamID protocol.StreamID,
|
||||||
maxNumStreams int,
|
maxNumStreams uint64,
|
||||||
queueControlFrame func(wire.Frame),
|
queueControlFrame func(wire.Frame),
|
||||||
newStream func(protocol.StreamID) streamI,
|
newStream func(protocol.StreamID) streamI,
|
||||||
) *incomingBidiStreamsMap {
|
) *incomingBidiStreamsMap {
|
||||||
|
@ -108,7 +108,8 @@ func (m *incomingBidiStreamsMap) DeleteStream(id protocol.StreamID) error {
|
||||||
}
|
}
|
||||||
delete(m.streams, id)
|
delete(m.streams, id)
|
||||||
// queue a MAX_STREAM_ID frame, giving the peer the option to open a new stream
|
// queue a MAX_STREAM_ID frame, giving the peer the option to open a new stream
|
||||||
if numNewStreams := m.maxNumStreams - len(m.streams); numNewStreams > 0 {
|
if m.maxNumStreams > uint64(len(m.streams)) {
|
||||||
|
numNewStreams := m.maxNumStreams - uint64(len(m.streams))
|
||||||
m.maxStream = m.nextStreamToOpen + protocol.StreamID((numNewStreams-1)*4)
|
m.maxStream = m.nextStreamToOpen + protocol.StreamID((numNewStreams-1)*4)
|
||||||
m.queueMaxStreamID(&wire.MaxStreamIDFrame{StreamID: m.maxStream})
|
m.queueMaxStreamID(&wire.MaxStreamIDFrame{StreamID: m.maxStream})
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,7 @@ type incomingItemsMap struct {
|
||||||
nextStreamToAccept protocol.StreamID // the next stream that will be returned by AcceptStream()
|
nextStreamToAccept protocol.StreamID // the next stream that will be returned by AcceptStream()
|
||||||
nextStreamToOpen protocol.StreamID // the highest stream that the peer openend
|
nextStreamToOpen protocol.StreamID // the highest stream that the peer openend
|
||||||
maxStream protocol.StreamID // the highest stream that the peer is allowed to open
|
maxStream protocol.StreamID // the highest stream that the peer is allowed to open
|
||||||
maxNumStreams int // maximum number of streams
|
maxNumStreams uint64 // maximum number of streams
|
||||||
|
|
||||||
newStream func(protocol.StreamID) item
|
newStream func(protocol.StreamID) item
|
||||||
queueMaxStreamID func(*wire.MaxStreamIDFrame)
|
queueMaxStreamID func(*wire.MaxStreamIDFrame)
|
||||||
|
@ -30,7 +30,7 @@ type incomingItemsMap struct {
|
||||||
func newIncomingItemsMap(
|
func newIncomingItemsMap(
|
||||||
nextStreamToAccept protocol.StreamID,
|
nextStreamToAccept protocol.StreamID,
|
||||||
initialMaxStreamID protocol.StreamID,
|
initialMaxStreamID protocol.StreamID,
|
||||||
maxNumStreams int,
|
maxNumStreams uint64,
|
||||||
queueControlFrame func(wire.Frame),
|
queueControlFrame func(wire.Frame),
|
||||||
newStream func(protocol.StreamID) item,
|
newStream func(protocol.StreamID) item,
|
||||||
) *incomingItemsMap {
|
) *incomingItemsMap {
|
||||||
|
@ -106,7 +106,8 @@ func (m *incomingItemsMap) DeleteStream(id protocol.StreamID) error {
|
||||||
}
|
}
|
||||||
delete(m.streams, id)
|
delete(m.streams, id)
|
||||||
// queue a MAX_STREAM_ID frame, giving the peer the option to open a new stream
|
// queue a MAX_STREAM_ID frame, giving the peer the option to open a new stream
|
||||||
if numNewStreams := m.maxNumStreams - len(m.streams); numNewStreams > 0 {
|
if m.maxNumStreams > uint64(len(m.streams)) {
|
||||||
|
numNewStreams := m.maxNumStreams - uint64(len(m.streams))
|
||||||
m.maxStream = m.nextStreamToOpen + protocol.StreamID((numNewStreams-1)*4)
|
m.maxStream = m.nextStreamToOpen + protocol.StreamID((numNewStreams-1)*4)
|
||||||
m.queueMaxStreamID(&wire.MaxStreamIDFrame{StreamID: m.maxStream})
|
m.queueMaxStreamID(&wire.MaxStreamIDFrame{StreamID: m.maxStream})
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,7 +27,7 @@ func (s *mockGenericStream) closeForShutdown(err error) {
|
||||||
var _ = Describe("Streams Map (incoming)", func() {
|
var _ = Describe("Streams Map (incoming)", func() {
|
||||||
const (
|
const (
|
||||||
firstNewStream protocol.StreamID = 20
|
firstNewStream protocol.StreamID = 20
|
||||||
maxNumStreams int = 10
|
maxNumStreams uint64 = 10
|
||||||
initialMaxStream protocol.StreamID = firstNewStream + 4*protocol.StreamID(maxNumStreams-1)
|
initialMaxStream protocol.StreamID = firstNewStream + 4*protocol.StreamID(maxNumStreams-1)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,7 @@ type incomingUniStreamsMap struct {
|
||||||
nextStreamToAccept protocol.StreamID // the next stream that will be returned by AcceptStream()
|
nextStreamToAccept protocol.StreamID // the next stream that will be returned by AcceptStream()
|
||||||
nextStreamToOpen protocol.StreamID // the highest stream that the peer openend
|
nextStreamToOpen protocol.StreamID // the highest stream that the peer openend
|
||||||
maxStream protocol.StreamID // the highest stream that the peer is allowed to open
|
maxStream protocol.StreamID // the highest stream that the peer is allowed to open
|
||||||
maxNumStreams int // maximum number of streams
|
maxNumStreams uint64 // maximum number of streams
|
||||||
|
|
||||||
newStream func(protocol.StreamID) receiveStreamI
|
newStream func(protocol.StreamID) receiveStreamI
|
||||||
queueMaxStreamID func(*wire.MaxStreamIDFrame)
|
queueMaxStreamID func(*wire.MaxStreamIDFrame)
|
||||||
|
@ -32,7 +32,7 @@ type incomingUniStreamsMap struct {
|
||||||
func newIncomingUniStreamsMap(
|
func newIncomingUniStreamsMap(
|
||||||
nextStreamToAccept protocol.StreamID,
|
nextStreamToAccept protocol.StreamID,
|
||||||
initialMaxStreamID protocol.StreamID,
|
initialMaxStreamID protocol.StreamID,
|
||||||
maxNumStreams int,
|
maxNumStreams uint64,
|
||||||
queueControlFrame func(wire.Frame),
|
queueControlFrame func(wire.Frame),
|
||||||
newStream func(protocol.StreamID) receiveStreamI,
|
newStream func(protocol.StreamID) receiveStreamI,
|
||||||
) *incomingUniStreamsMap {
|
) *incomingUniStreamsMap {
|
||||||
|
@ -108,7 +108,8 @@ func (m *incomingUniStreamsMap) DeleteStream(id protocol.StreamID) error {
|
||||||
}
|
}
|
||||||
delete(m.streams, id)
|
delete(m.streams, id)
|
||||||
// queue a MAX_STREAM_ID frame, giving the peer the option to open a new stream
|
// queue a MAX_STREAM_ID frame, giving the peer the option to open a new stream
|
||||||
if numNewStreams := m.maxNumStreams - len(m.streams); numNewStreams > 0 {
|
if m.maxNumStreams > uint64(len(m.streams)) {
|
||||||
|
numNewStreams := m.maxNumStreams - uint64(len(m.streams))
|
||||||
m.maxStream = m.nextStreamToOpen + protocol.StreamID((numNewStreams-1)*4)
|
m.maxStream = m.nextStreamToOpen + protocol.StreamID((numNewStreams-1)*4)
|
||||||
m.queueMaxStreamID(&wire.MaxStreamIDFrame{StreamID: m.maxStream})
|
m.queueMaxStreamID(&wire.MaxStreamIDFrame{StreamID: m.maxStream})
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue