mirror of
https://github.com/DNSCrypt/dnscrypt-proxy.git
synced 2025-04-04 13:47:39 +03:00
Bumps [github.com/quic-go/quic-go](https://github.com/quic-go/quic-go) from 0.49.0 to 0.50.0. - [Release notes](https://github.com/quic-go/quic-go/releases) - [Changelog](https://github.com/quic-go/quic-go/blob/master/Changelog.md) - [Commits](https://github.com/quic-go/quic-go/compare/v0.49.0...v0.50.0) --- updated-dependencies: - dependency-name: github.com/quic-go/quic-go dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com>
56 lines
1.5 KiB
Go
56 lines
1.5 KiB
Go
package ackhandler
|
|
|
|
import (
|
|
"sync"
|
|
"time"
|
|
|
|
"github.com/quic-go/quic-go/internal/protocol"
|
|
)
|
|
|
|
// A Packet is a packet
|
|
type packet struct {
|
|
SendTime time.Time
|
|
PacketNumber protocol.PacketNumber
|
|
StreamFrames []StreamFrame
|
|
Frames []Frame
|
|
LargestAcked protocol.PacketNumber // InvalidPacketNumber if the packet doesn't contain an ACK
|
|
Length protocol.ByteCount
|
|
EncryptionLevel protocol.EncryptionLevel
|
|
|
|
IsPathMTUProbePacket bool // We don't report the loss of Path MTU probe packets to the congestion controller.
|
|
|
|
includedInBytesInFlight bool
|
|
declaredLost bool
|
|
skippedPacket bool
|
|
isPathProbePacket bool
|
|
}
|
|
|
|
func (p *packet) outstanding() bool {
|
|
return !p.declaredLost && !p.skippedPacket && !p.IsPathMTUProbePacket && !p.isPathProbePacket
|
|
}
|
|
|
|
var packetPool = sync.Pool{New: func() any { return &packet{} }}
|
|
|
|
func getPacket() *packet {
|
|
p := packetPool.Get().(*packet)
|
|
p.PacketNumber = 0
|
|
p.StreamFrames = nil
|
|
p.Frames = nil
|
|
p.LargestAcked = 0
|
|
p.Length = 0
|
|
p.EncryptionLevel = protocol.EncryptionLevel(0)
|
|
p.SendTime = time.Time{}
|
|
p.IsPathMTUProbePacket = false
|
|
p.includedInBytesInFlight = false
|
|
p.declaredLost = false
|
|
p.skippedPacket = false
|
|
return p
|
|
}
|
|
|
|
// We currently only return Packets back into the pool when they're acknowledged (not when they're lost).
|
|
// This simplifies the code, and gives the vast majority of the performance benefit we can gain from using the pool.
|
|
func putPacket(p *packet) {
|
|
p.Frames = nil
|
|
p.StreamFrames = nil
|
|
packetPool.Put(p)
|
|
}
|