mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-05 13:17:36 +03:00
Merge pull request #666 from twdkeule/fix-526
Make max flow control windows configurable
This commit is contained in:
commit
c520b548ae
10 changed files with 92 additions and 48 deletions
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
## v0.6.0 (unreleased)
|
## v0.6.0 (unreleased)
|
||||||
|
|
||||||
|
- Added `quic.Config` options for maximal flow control windows
|
||||||
- Add a `quic.Config` option for QUIC versions
|
- Add a `quic.Config` option for QUIC versions
|
||||||
- Add a `quic.Config` option to request truncation of the connection ID from a server
|
- Add a `quic.Config` option to request truncation of the connection ID from a server
|
||||||
- Add a `quic.Config` option to configure the source address validation
|
- Add a `quic.Config` option to configure the source address validation
|
||||||
|
|
13
client.go
13
client.go
|
@ -9,9 +9,9 @@ import (
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/lucas-clemente/quic-go/internal/utils"
|
||||||
"github.com/lucas-clemente/quic-go/protocol"
|
"github.com/lucas-clemente/quic-go/protocol"
|
||||||
"github.com/lucas-clemente/quic-go/qerr"
|
"github.com/lucas-clemente/quic-go/qerr"
|
||||||
"github.com/lucas-clemente/quic-go/internal/utils"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type client struct {
|
type client struct {
|
||||||
|
@ -123,11 +123,22 @@ func populateClientConfig(config *Config) *Config {
|
||||||
handshakeTimeout = config.HandshakeTimeout
|
handshakeTimeout = config.HandshakeTimeout
|
||||||
}
|
}
|
||||||
|
|
||||||
|
maxReceiveStreamFlowControlWindow := config.MaxReceiveStreamFlowControlWindow
|
||||||
|
if maxReceiveStreamFlowControlWindow == 0 {
|
||||||
|
maxReceiveStreamFlowControlWindow = protocol.DefaultMaxReceiveStreamFlowControlWindowClient
|
||||||
|
}
|
||||||
|
maxReceiveConnectionFlowControlWindow := config.MaxReceiveConnectionFlowControlWindow
|
||||||
|
if maxReceiveConnectionFlowControlWindow == 0 {
|
||||||
|
maxReceiveConnectionFlowControlWindow = protocol.DefaultMaxReceiveConnectionFlowControlWindowClient
|
||||||
|
}
|
||||||
|
|
||||||
return &Config{
|
return &Config{
|
||||||
TLSConfig: config.TLSConfig,
|
TLSConfig: config.TLSConfig,
|
||||||
Versions: versions,
|
Versions: versions,
|
||||||
HandshakeTimeout: handshakeTimeout,
|
HandshakeTimeout: handshakeTimeout,
|
||||||
RequestConnectionIDTruncation: config.RequestConnectionIDTruncation,
|
RequestConnectionIDTruncation: config.RequestConnectionIDTruncation,
|
||||||
|
MaxReceiveStreamFlowControlWindow: maxReceiveStreamFlowControlWindow,
|
||||||
|
MaxReceiveConnectionFlowControlWindow: maxReceiveConnectionFlowControlWindow,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,9 +5,9 @@ import (
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/lucas-clemente/quic-go/internal/utils"
|
||||||
"github.com/lucas-clemente/quic-go/protocol"
|
"github.com/lucas-clemente/quic-go/protocol"
|
||||||
"github.com/lucas-clemente/quic-go/qerr"
|
"github.com/lucas-clemente/quic-go/qerr"
|
||||||
"github.com/lucas-clemente/quic-go/internal/utils"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// ConnectionParametersManager negotiates and stores the connection parameters
|
// ConnectionParametersManager negotiates and stores the connection parameters
|
||||||
|
@ -50,6 +50,8 @@ type connectionParametersManager struct {
|
||||||
sendConnectionFlowControlWindow protocol.ByteCount
|
sendConnectionFlowControlWindow protocol.ByteCount
|
||||||
receiveStreamFlowControlWindow protocol.ByteCount
|
receiveStreamFlowControlWindow protocol.ByteCount
|
||||||
receiveConnectionFlowControlWindow protocol.ByteCount
|
receiveConnectionFlowControlWindow protocol.ByteCount
|
||||||
|
maxReceiveStreamFlowControlWindow protocol.ByteCount
|
||||||
|
maxReceiveConnectionFlowControlWindow protocol.ByteCount
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ ConnectionParametersManager = &connectionParametersManager{}
|
var _ ConnectionParametersManager = &connectionParametersManager{}
|
||||||
|
@ -61,7 +63,10 @@ var (
|
||||||
)
|
)
|
||||||
|
|
||||||
// NewConnectionParamatersManager creates a new connection parameters manager
|
// NewConnectionParamatersManager creates a new connection parameters manager
|
||||||
func NewConnectionParamatersManager(pers protocol.Perspective, v protocol.VersionNumber) ConnectionParametersManager {
|
func NewConnectionParamatersManager(
|
||||||
|
pers protocol.Perspective, v protocol.VersionNumber,
|
||||||
|
maxReceiveStreamFlowControlWindow protocol.ByteCount, maxReceiveConnectionFlowControlWindow protocol.ByteCount,
|
||||||
|
) ConnectionParametersManager {
|
||||||
h := &connectionParametersManager{
|
h := &connectionParametersManager{
|
||||||
perspective: pers,
|
perspective: pers,
|
||||||
version: v,
|
version: v,
|
||||||
|
@ -69,6 +74,8 @@ func NewConnectionParamatersManager(pers protocol.Perspective, v protocol.Versio
|
||||||
sendConnectionFlowControlWindow: protocol.InitialConnectionFlowControlWindow, // can only be changed by the client
|
sendConnectionFlowControlWindow: protocol.InitialConnectionFlowControlWindow, // can only be changed by the client
|
||||||
receiveStreamFlowControlWindow: protocol.ReceiveStreamFlowControlWindow,
|
receiveStreamFlowControlWindow: protocol.ReceiveStreamFlowControlWindow,
|
||||||
receiveConnectionFlowControlWindow: protocol.ReceiveConnectionFlowControlWindow,
|
receiveConnectionFlowControlWindow: protocol.ReceiveConnectionFlowControlWindow,
|
||||||
|
maxReceiveStreamFlowControlWindow: maxReceiveStreamFlowControlWindow,
|
||||||
|
maxReceiveConnectionFlowControlWindow: maxReceiveConnectionFlowControlWindow,
|
||||||
}
|
}
|
||||||
|
|
||||||
if h.perspective == protocol.PerspectiveServer {
|
if h.perspective == protocol.PerspectiveServer {
|
||||||
|
@ -207,10 +214,7 @@ func (h *connectionParametersManager) GetReceiveStreamFlowControlWindow() protoc
|
||||||
|
|
||||||
// GetMaxReceiveStreamFlowControlWindow gets the maximum size of the stream-level flow control window for sending data
|
// GetMaxReceiveStreamFlowControlWindow gets the maximum size of the stream-level flow control window for sending data
|
||||||
func (h *connectionParametersManager) GetMaxReceiveStreamFlowControlWindow() protocol.ByteCount {
|
func (h *connectionParametersManager) GetMaxReceiveStreamFlowControlWindow() protocol.ByteCount {
|
||||||
if h.perspective == protocol.PerspectiveServer {
|
return h.maxReceiveStreamFlowControlWindow
|
||||||
return protocol.MaxReceiveStreamFlowControlWindowServer
|
|
||||||
}
|
|
||||||
return protocol.MaxReceiveStreamFlowControlWindowClient
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetReceiveConnectionFlowControlWindow gets the size of the stream-level flow control window for receiving data
|
// GetReceiveConnectionFlowControlWindow gets the size of the stream-level flow control window for receiving data
|
||||||
|
@ -222,10 +226,7 @@ func (h *connectionParametersManager) GetReceiveConnectionFlowControlWindow() pr
|
||||||
|
|
||||||
// GetMaxReceiveConnectionFlowControlWindow gets the maximum size of the stream-level flow control window for sending data
|
// GetMaxReceiveConnectionFlowControlWindow gets the maximum size of the stream-level flow control window for sending data
|
||||||
func (h *connectionParametersManager) GetMaxReceiveConnectionFlowControlWindow() protocol.ByteCount {
|
func (h *connectionParametersManager) GetMaxReceiveConnectionFlowControlWindow() protocol.ByteCount {
|
||||||
if h.perspective == protocol.PerspectiveServer {
|
return h.maxReceiveConnectionFlowControlWindow
|
||||||
return protocol.MaxReceiveConnectionFlowControlWindowServer
|
|
||||||
}
|
|
||||||
return protocol.MaxReceiveConnectionFlowControlWindowClient
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetMaxOutgoingStreams gets the maximum number of outgoing streams per connection
|
// GetMaxOutgoingStreams gets the maximum number of outgoing streams per connection
|
||||||
|
|
|
@ -2,6 +2,7 @@ package handshake
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
|
"math"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/lucas-clemente/quic-go/protocol"
|
"github.com/lucas-clemente/quic-go/protocol"
|
||||||
|
@ -12,10 +13,18 @@ import (
|
||||||
var _ = Describe("ConnectionsParameterManager", func() {
|
var _ = Describe("ConnectionsParameterManager", func() {
|
||||||
var cpm *connectionParametersManager // a connectionParametersManager for a server
|
var cpm *connectionParametersManager // a connectionParametersManager for a server
|
||||||
var cpmClient *connectionParametersManager
|
var cpmClient *connectionParametersManager
|
||||||
|
const MB = 1 << 20
|
||||||
|
maxReceiveStreamFlowControlWindowServer := protocol.ByteCount(math.Floor(1.1 * MB)) // default is 1 MB
|
||||||
|
maxReceiveConnectionFlowControlWindowServer := protocol.ByteCount(math.Floor(1.5 * MB)) // default is 1.5 MB
|
||||||
|
maxReceiveStreamFlowControlWindowClient := protocol.ByteCount(math.Floor(6.4 * MB)) // default is 6 MB
|
||||||
|
maxReceiveConnectionFlowControlWindowClient := protocol.ByteCount(math.Floor(13 * MB)) // default is 15 MB
|
||||||
BeforeEach(func() {
|
BeforeEach(func() {
|
||||||
cpm = NewConnectionParamatersManager(protocol.PerspectiveServer, protocol.Version36).(*connectionParametersManager)
|
cpm = NewConnectionParamatersManager(protocol.PerspectiveServer, protocol.Version36,
|
||||||
cpmClient = NewConnectionParamatersManager(protocol.PerspectiveClient, protocol.Version36).(*connectionParametersManager)
|
maxReceiveStreamFlowControlWindowServer, maxReceiveConnectionFlowControlWindowServer,
|
||||||
|
).(*connectionParametersManager)
|
||||||
|
cpmClient = NewConnectionParamatersManager(protocol.PerspectiveClient, protocol.Version36,
|
||||||
|
maxReceiveStreamFlowControlWindowClient, maxReceiveConnectionFlowControlWindowClient,
|
||||||
|
).(*connectionParametersManager)
|
||||||
})
|
})
|
||||||
|
|
||||||
Context("SHLO", func() {
|
Context("SHLO", func() {
|
||||||
|
@ -137,10 +146,10 @@ var _ = Describe("ConnectionsParameterManager", func() {
|
||||||
})
|
})
|
||||||
|
|
||||||
It("has the correct maximum flow control windows", func() {
|
It("has the correct maximum flow control windows", func() {
|
||||||
Expect(cpm.GetMaxReceiveStreamFlowControlWindow()).To(Equal(protocol.MaxReceiveStreamFlowControlWindowServer))
|
Expect(cpm.GetMaxReceiveStreamFlowControlWindow()).To(Equal(maxReceiveStreamFlowControlWindowServer))
|
||||||
Expect(cpm.GetMaxReceiveConnectionFlowControlWindow()).To(Equal(protocol.MaxReceiveConnectionFlowControlWindowServer))
|
Expect(cpm.GetMaxReceiveConnectionFlowControlWindow()).To(Equal(maxReceiveConnectionFlowControlWindowServer))
|
||||||
Expect(cpmClient.GetMaxReceiveStreamFlowControlWindow()).To(Equal(protocol.MaxReceiveStreamFlowControlWindowClient))
|
Expect(cpmClient.GetMaxReceiveStreamFlowControlWindow()).To(Equal(maxReceiveStreamFlowControlWindowClient))
|
||||||
Expect(cpmClient.GetMaxReceiveConnectionFlowControlWindow()).To(Equal(protocol.MaxReceiveConnectionFlowControlWindowClient))
|
Expect(cpmClient.GetMaxReceiveConnectionFlowControlWindow()).To(Equal(maxReceiveConnectionFlowControlWindowClient))
|
||||||
})
|
})
|
||||||
|
|
||||||
It("sets a new stream-level flow control window for sending", func() {
|
It("sets a new stream-level flow control window for sending", func() {
|
||||||
|
|
|
@ -8,9 +8,9 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/lucas-clemente/quic-go/crypto"
|
"github.com/lucas-clemente/quic-go/crypto"
|
||||||
|
"github.com/lucas-clemente/quic-go/internal/utils"
|
||||||
"github.com/lucas-clemente/quic-go/protocol"
|
"github.com/lucas-clemente/quic-go/protocol"
|
||||||
"github.com/lucas-clemente/quic-go/qerr"
|
"github.com/lucas-clemente/quic-go/qerr"
|
||||||
"github.com/lucas-clemente/quic-go/internal/utils"
|
|
||||||
. "github.com/onsi/ginkgo"
|
. "github.com/onsi/ginkgo"
|
||||||
. "github.com/onsi/gomega"
|
. "github.com/onsi/gomega"
|
||||||
)
|
)
|
||||||
|
@ -111,7 +111,9 @@ var _ = Describe("Client Crypto Setup", func() {
|
||||||
version,
|
version,
|
||||||
stream,
|
stream,
|
||||||
nil,
|
nil,
|
||||||
NewConnectionParamatersManager(protocol.PerspectiveClient, version),
|
NewConnectionParamatersManager(protocol.PerspectiveClient, version,
|
||||||
|
protocol.DefaultMaxReceiveStreamFlowControlWindowClient, protocol.DefaultMaxReceiveConnectionFlowControlWindowClient,
|
||||||
|
),
|
||||||
aeadChanged,
|
aeadChanged,
|
||||||
&TransportParameters{},
|
&TransportParameters{},
|
||||||
nil,
|
nil,
|
||||||
|
|
|
@ -7,9 +7,9 @@ import (
|
||||||
"net"
|
"net"
|
||||||
|
|
||||||
"github.com/lucas-clemente/quic-go/crypto"
|
"github.com/lucas-clemente/quic-go/crypto"
|
||||||
|
"github.com/lucas-clemente/quic-go/internal/utils"
|
||||||
"github.com/lucas-clemente/quic-go/protocol"
|
"github.com/lucas-clemente/quic-go/protocol"
|
||||||
"github.com/lucas-clemente/quic-go/qerr"
|
"github.com/lucas-clemente/quic-go/qerr"
|
||||||
"github.com/lucas-clemente/quic-go/internal/utils"
|
|
||||||
|
|
||||||
. "github.com/onsi/ginkgo"
|
. "github.com/onsi/ginkgo"
|
||||||
. "github.com/onsi/gomega"
|
. "github.com/onsi/gomega"
|
||||||
|
@ -184,7 +184,9 @@ var _ = Describe("Server Crypto Setup", func() {
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
version = protocol.SupportedVersions[len(protocol.SupportedVersions)-1]
|
version = protocol.SupportedVersions[len(protocol.SupportedVersions)-1]
|
||||||
supportedVersions = []protocol.VersionNumber{version, 98, 99}
|
supportedVersions = []protocol.VersionNumber{version, 98, 99}
|
||||||
cpm = NewConnectionParamatersManager(protocol.PerspectiveServer, protocol.VersionWhatever)
|
cpm = NewConnectionParamatersManager(protocol.PerspectiveServer, protocol.VersionWhatever,
|
||||||
|
protocol.DefaultMaxReceiveStreamFlowControlWindowServer, protocol.DefaultMaxReceiveConnectionFlowControlWindowServer,
|
||||||
|
)
|
||||||
csInt, err := NewCryptoSetup(
|
csInt, err := NewCryptoSetup(
|
||||||
protocol.ConnectionID(42),
|
protocol.ConnectionID(42),
|
||||||
remoteAddr,
|
remoteAddr,
|
||||||
|
|
|
@ -76,9 +76,15 @@ type Config struct {
|
||||||
HandshakeTimeout time.Duration
|
HandshakeTimeout time.Duration
|
||||||
// AcceptSTK determines if an STK is accepted.
|
// AcceptSTK determines if an STK is accepted.
|
||||||
// It is called with stk = nil if the client didn't send an STK.
|
// It is called with stk = nil if the client didn't send an STK.
|
||||||
// If not set, it verifies that the address matches, and that the STK was issued within the last 24 hours
|
// If not set, it verifies that the address matches, and that the STK was issued within the last 24 hours.
|
||||||
// This option is only valid for the server.
|
// This option is only valid for the server.
|
||||||
AcceptSTK func(clientAddr net.Addr, stk *STK) bool
|
AcceptSTK func(clientAddr net.Addr, stk *STK) bool
|
||||||
|
// MaxReceiveStreamFlowControlWindow is the maximum stream-level flow control window for receiving data.
|
||||||
|
// If this value is zero, it will default to 1 MB for the server and 6 MB for the client.
|
||||||
|
MaxReceiveStreamFlowControlWindow protocol.ByteCount
|
||||||
|
// MaxReceiveConnectionFlowControlWindow is the connection-level flow control window for receiving data.
|
||||||
|
// If this value is zero, it will default to 1.5 MB for the server and 15 MB for the client.
|
||||||
|
MaxReceiveConnectionFlowControlWindow protocol.ByteCount
|
||||||
}
|
}
|
||||||
|
|
||||||
// A Listener for incoming QUIC connections
|
// A Listener for incoming QUIC connections
|
||||||
|
|
|
@ -39,21 +39,21 @@ const ReceiveStreamFlowControlWindow ByteCount = (1 << 10) * 32 // 32 kB
|
||||||
// This is the value that Google servers are using
|
// This is the value that Google servers are using
|
||||||
const ReceiveConnectionFlowControlWindow ByteCount = (1 << 10) * 48 // 48 kB
|
const ReceiveConnectionFlowControlWindow ByteCount = (1 << 10) * 48 // 48 kB
|
||||||
|
|
||||||
// MaxReceiveStreamFlowControlWindowServer is the maximum stream-level flow control window for receiving data
|
// DefaultMaxReceiveStreamFlowControlWindowServer is the default maximum stream-level flow control window for receiving data, for the server
|
||||||
// This is the value that Google servers are using
|
// This is the value that Google servers are using
|
||||||
const MaxReceiveStreamFlowControlWindowServer ByteCount = 1 * (1 << 20) // 1 MB
|
const DefaultMaxReceiveStreamFlowControlWindowServer ByteCount = 1 * (1 << 20) // 1 MB
|
||||||
|
|
||||||
// MaxReceiveConnectionFlowControlWindowServer is the connection-level flow control window for receiving data
|
// DefaultMaxReceiveConnectionFlowControlWindowServer is the default connection-level flow control window for receiving data, for the server
|
||||||
// This is the value that Google servers are using
|
// This is the value that Google servers are using
|
||||||
const MaxReceiveConnectionFlowControlWindowServer ByteCount = 1.5 * (1 << 20) // 1.5 MB
|
const DefaultMaxReceiveConnectionFlowControlWindowServer ByteCount = 1.5 * (1 << 20) // 1.5 MB
|
||||||
|
|
||||||
// MaxReceiveStreamFlowControlWindowClient is the maximum stream-level flow control window for receiving data, for the client
|
// DefaultMaxReceiveStreamFlowControlWindowClient is the default maximum stream-level flow control window for receiving data, for the client
|
||||||
// This is the value that Chromium is using
|
// This is the value that Chromium is using
|
||||||
const MaxReceiveStreamFlowControlWindowClient ByteCount = 6 * (1 << 20) // 6 MB
|
const DefaultMaxReceiveStreamFlowControlWindowClient ByteCount = 6 * (1 << 20) // 6 MB
|
||||||
|
|
||||||
// MaxReceiveConnectionFlowControlWindowClient is the connection-level flow control window for receiving data, for the server
|
// DefaultMaxReceiveConnectionFlowControlWindowClient is the default connection-level flow control window for receiving data, for the client
|
||||||
// This is the value that Google servers are using
|
// This is the value that Google servers are using
|
||||||
const MaxReceiveConnectionFlowControlWindowClient ByteCount = 15 * (1 << 20) // 15 MB
|
const DefaultMaxReceiveConnectionFlowControlWindowClient ByteCount = 15 * (1 << 20) // 15 MB
|
||||||
|
|
||||||
// ConnectionFlowControlMultiplier determines how much larger the connection flow control windows needs to be relative to any stream's flow control window
|
// ConnectionFlowControlMultiplier determines how much larger the connection flow control windows needs to be relative to any stream's flow control window
|
||||||
// This is the value that Chromium is using
|
// This is the value that Chromium is using
|
||||||
|
|
13
server.go
13
server.go
|
@ -9,9 +9,9 @@ import (
|
||||||
|
|
||||||
"github.com/lucas-clemente/quic-go/crypto"
|
"github.com/lucas-clemente/quic-go/crypto"
|
||||||
"github.com/lucas-clemente/quic-go/handshake"
|
"github.com/lucas-clemente/quic-go/handshake"
|
||||||
|
"github.com/lucas-clemente/quic-go/internal/utils"
|
||||||
"github.com/lucas-clemente/quic-go/protocol"
|
"github.com/lucas-clemente/quic-go/protocol"
|
||||||
"github.com/lucas-clemente/quic-go/qerr"
|
"github.com/lucas-clemente/quic-go/qerr"
|
||||||
"github.com/lucas-clemente/quic-go/internal/utils"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// packetHandler handles packets
|
// packetHandler handles packets
|
||||||
|
@ -117,11 +117,22 @@ func populateServerConfig(config *Config) *Config {
|
||||||
handshakeTimeout = config.HandshakeTimeout
|
handshakeTimeout = config.HandshakeTimeout
|
||||||
}
|
}
|
||||||
|
|
||||||
|
maxReceiveStreamFlowControlWindow := config.MaxReceiveStreamFlowControlWindow
|
||||||
|
if maxReceiveStreamFlowControlWindow == 0 {
|
||||||
|
maxReceiveStreamFlowControlWindow = protocol.DefaultMaxReceiveStreamFlowControlWindowServer
|
||||||
|
}
|
||||||
|
maxReceiveConnectionFlowControlWindow := config.MaxReceiveConnectionFlowControlWindow
|
||||||
|
if maxReceiveConnectionFlowControlWindow == 0 {
|
||||||
|
maxReceiveConnectionFlowControlWindow = protocol.DefaultMaxReceiveConnectionFlowControlWindowServer
|
||||||
|
}
|
||||||
|
|
||||||
return &Config{
|
return &Config{
|
||||||
TLSConfig: config.TLSConfig,
|
TLSConfig: config.TLSConfig,
|
||||||
Versions: versions,
|
Versions: versions,
|
||||||
HandshakeTimeout: handshakeTimeout,
|
HandshakeTimeout: handshakeTimeout,
|
||||||
AcceptSTK: vsa,
|
AcceptSTK: vsa,
|
||||||
|
MaxReceiveStreamFlowControlWindow: maxReceiveStreamFlowControlWindow,
|
||||||
|
MaxReceiveConnectionFlowControlWindow: maxReceiveConnectionFlowControlWindow,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,9 +12,9 @@ import (
|
||||||
"github.com/lucas-clemente/quic-go/flowcontrol"
|
"github.com/lucas-clemente/quic-go/flowcontrol"
|
||||||
"github.com/lucas-clemente/quic-go/frames"
|
"github.com/lucas-clemente/quic-go/frames"
|
||||||
"github.com/lucas-clemente/quic-go/handshake"
|
"github.com/lucas-clemente/quic-go/handshake"
|
||||||
|
"github.com/lucas-clemente/quic-go/internal/utils"
|
||||||
"github.com/lucas-clemente/quic-go/protocol"
|
"github.com/lucas-clemente/quic-go/protocol"
|
||||||
"github.com/lucas-clemente/quic-go/qerr"
|
"github.com/lucas-clemente/quic-go/qerr"
|
||||||
"github.com/lucas-clemente/quic-go/internal/utils"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type unpacker interface {
|
type unpacker interface {
|
||||||
|
@ -172,7 +172,8 @@ func (s *session) setup(
|
||||||
s.sessionCreationTime = now
|
s.sessionCreationTime = now
|
||||||
|
|
||||||
s.rttStats = &congestion.RTTStats{}
|
s.rttStats = &congestion.RTTStats{}
|
||||||
s.connectionParameters = handshake.NewConnectionParamatersManager(s.perspective, s.version)
|
s.connectionParameters = handshake.NewConnectionParamatersManager(s.perspective, s.version,
|
||||||
|
s.config.MaxReceiveStreamFlowControlWindow, s.config.MaxReceiveConnectionFlowControlWindow)
|
||||||
s.sentPacketHandler = ackhandler.NewSentPacketHandler(s.rttStats)
|
s.sentPacketHandler = ackhandler.NewSentPacketHandler(s.rttStats)
|
||||||
s.flowControlManager = flowcontrol.NewFlowControlManager(s.connectionParameters, s.rttStats)
|
s.flowControlManager = flowcontrol.NewFlowControlManager(s.connectionParameters, s.rttStats)
|
||||||
s.receivedPacketHandler = ackhandler.NewReceivedPacketHandler(s.ackAlarmChanged)
|
s.receivedPacketHandler = ackhandler.NewReceivedPacketHandler(s.ackAlarmChanged)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue