use a uint64 for stream counts

This commit is contained in:
Marten Seemann 2018-11-09 09:00:25 +07:00
parent e8de94485c
commit 0f931ca54e
7 changed files with 34 additions and 17 deletions

View file

@ -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
} }

View file

@ -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,

View file

@ -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) {

View file

@ -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})
} }

View file

@ -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})
} }

View file

@ -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)
) )

View file

@ -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})
} }