
full diff: https://github.com/golang/net/compare/ab34263943818b32f575efc978 This fixes the same CVE as go1.21.3 and go1.20.10; - net/http: rapid stream resets can cause excessive work A malicious HTTP/2 client which rapidly creates requests and immediately resets them can cause excessive server resource consumption. While the total number of requests is bounded to the http2.Server.MaxConcurrentStreams setting, resetting an in-progress request allows the attacker to create a new request while the existing one is still executing. HTTP/2 servers now bound the number of simultaneously executing handler goroutines to the stream concurrency limit. New requests arriving when at the limit (which can only happen after the client has reset an existing, in-flight request) will be queued until a handler exits. If the request queue grows too large, the server will terminate the connection. This issue is also fixed in golang.org/x/net/http2 v0.17.0, for users manually configuring HTTP/2. The default stream concurrency limit is 250 streams (requests) per HTTP/2 connection. This value may be adjusted using the golang.org/x/net/http2 package; see the Server.MaxConcurrentStreams setting and the ConfigureServer function. This is CVE-2023-39325 and Go issue https://go.dev/issue/63417. This is also tracked by CVE-2023-44487. Dependency full diffs: a3d24e80b04bd7...v0.17.0 https://github.com/golang/sys/compare/33da011f77ade50ff5b6a6fb4a 9a1e6d6b285809...v0.13.0 https://github.com/golang/text/compare/v0.3.3...v0.13.0 https://github.com/golang/crypto/compare/c1f2f97bffc9c53fc40a1a28a5 b460094c0050d9...v0.14.0 Signed-off-by: Cory Snider <csnider@mirantis.com>
80 lines
3.1 KiB
Go
80 lines
3.1 KiB
Go
// Copyright 2016 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
/*
|
|
Package bpf implements marshaling and unmarshaling of programs for the
|
|
Berkeley Packet Filter virtual machine, and provides a Go implementation
|
|
of the virtual machine.
|
|
|
|
BPF's main use is to specify a packet filter for network taps, so that
|
|
the kernel doesn't have to expensively copy every packet it sees to
|
|
userspace. However, it's been repurposed to other areas where running
|
|
user code in-kernel is needed. For example, Linux's seccomp uses BPF
|
|
to apply security policies to system calls. For simplicity, this
|
|
documentation refers only to packets, but other uses of BPF have their
|
|
own data payloads.
|
|
|
|
BPF programs run in a restricted virtual machine. It has almost no
|
|
access to kernel functions, and while conditional branches are
|
|
allowed, they can only jump forwards, to guarantee that there are no
|
|
infinite loops.
|
|
|
|
# The virtual machine
|
|
|
|
The BPF VM is an accumulator machine. Its main register, called
|
|
register A, is an implicit source and destination in all arithmetic
|
|
and logic operations. The machine also has 16 scratch registers for
|
|
temporary storage, and an indirection register (register X) for
|
|
indirect memory access. All registers are 32 bits wide.
|
|
|
|
Each run of a BPF program is given one packet, which is placed in the
|
|
VM's read-only "main memory". LoadAbsolute and LoadIndirect
|
|
instructions can fetch up to 32 bits at a time into register A for
|
|
examination.
|
|
|
|
The goal of a BPF program is to produce and return a verdict (uint32),
|
|
which tells the kernel what to do with the packet. In the context of
|
|
packet filtering, the returned value is the number of bytes of the
|
|
packet to forward to userspace, or 0 to ignore the packet. Other
|
|
contexts like seccomp define their own return values.
|
|
|
|
In order to simplify programs, attempts to read past the end of the
|
|
packet terminate the program execution with a verdict of 0 (ignore
|
|
packet). This means that the vast majority of BPF programs don't need
|
|
to do any explicit bounds checking.
|
|
|
|
In addition to the bytes of the packet, some BPF programs have access
|
|
to extensions, which are essentially calls to kernel utility
|
|
functions. Currently, the only extensions supported by this package
|
|
are the Linux packet filter extensions.
|
|
|
|
# Examples
|
|
|
|
This packet filter selects all ARP packets.
|
|
|
|
bpf.Assemble([]bpf.Instruction{
|
|
// Load "EtherType" field from the ethernet header.
|
|
bpf.LoadAbsolute{Off: 12, Size: 2},
|
|
// Skip over the next instruction if EtherType is not ARP.
|
|
bpf.JumpIf{Cond: bpf.JumpNotEqual, Val: 0x0806, SkipTrue: 1},
|
|
// Verdict is "send up to 4k of the packet to userspace."
|
|
bpf.RetConstant{Val: 4096},
|
|
// Verdict is "ignore packet."
|
|
bpf.RetConstant{Val: 0},
|
|
})
|
|
|
|
This packet filter captures a random 1% sample of traffic.
|
|
|
|
bpf.Assemble([]bpf.Instruction{
|
|
// Get a 32-bit random number from the Linux kernel.
|
|
bpf.LoadExtension{Num: bpf.ExtRand},
|
|
// 1% dice roll?
|
|
bpf.JumpIf{Cond: bpf.JumpLessThan, Val: 2^32/100, SkipFalse: 1},
|
|
// Capture.
|
|
bpf.RetConstant{Val: 4096},
|
|
// Ignore.
|
|
bpf.RetConstant{Val: 0},
|
|
})
|
|
*/
|
|
package bpf // import "golang.org/x/net/bpf"
|