freebsd-src/sys
Gleb Smirnoff 513f2e2e71 tcp: always set tcp_tun_port to a correct value
The tcp_tun_port field that is used to pass port value between UDP
and TCP in case of tunneling is a generic field that used to pass
data between network layers.  It can be contaminated on entry, e.g.
by a VLAN tag set by a NIC driver.  Explicily set it, so that it
is zeroed out in a normal not-tunneled TCP.  If it contains garbage,
tcp_twcheck() later can enter wrong block of code and treat the packet
as incorrectly tunneled one.  On main and stable/14 that will end up
with sending incorrect responses, but on stable/13 with ipfw(8) and
pcb-matching rules it may end up in a panic.

This is a minimal conservative patch to be merged to stable branches.
Later we may redesign this.

PR:			275169
Reviewed by:		tuexen
Differential Revision:	https://reviews.freebsd.org/D43065
2023-12-19 11:24:17 -08:00
..
amd64 xen: add SPDX license tags to Xen headers 2023-12-15 14:59:25 +01:00
arm
arm64 arm64: Remove an unused global variable 2023-12-18 13:13:43 -05:00
bsm
cam
cddl
compat LinuxKPI: 802.11: more TXQ implementation and locking 2023-12-19 00:50:49 +00:00
conf sys/conf: make xen_acpi_cpu.c depend on acpi 2023-12-15 14:59:25 +01:00
contrib zfs: merge openzfs/zfs@86e115e21 2023-12-15 14:18:07 +01:00
crypto
ddb
dev nvme: Initialize HMB entries before loading them into the controller 2023-12-18 17:45:24 -05:00
dts
fs tmpfs: increase memory reserve to a percent of available memory + swap 2023-12-19 09:33:33 -06:00
gdb
geom
gnu
i386 xen: add SPDX license tags to Xen headers 2023-12-15 14:59:25 +01:00
isa
kern tty: delete knotes when TTY is revoked 2023-12-18 15:40:46 -09:00
kgssapi
libkern
modules zfs: merge openzfs/zfs@86e115e21 2023-12-15 14:18:07 +01:00
net
net80211 ieee80211: Check for copyout() errors in the SIOCG80211STATS handler 2023-12-18 22:44:54 -05:00
netgraph
netinet tcp: always set tcp_tun_port to a correct value 2023-12-19 11:24:17 -08:00
netinet6
netipsec
netlink netlink: fix debug text typo in message parser 2023-12-18 08:34:55 -05:00
netpfil dummynet: add simple gilbert-elliott channel model 2023-12-17 13:20:45 +01:00
netsmb
nfs
nfsclient
nfsserver
nlm
ofed
opencrypto
powerpc
riscv
rpc
security
sys
teken
tests
tools
ufs ufs: do not leave around empty buffers shadowing disk content 2023-12-16 00:06:10 +02:00
vm vm: Plug umtx shm object leak. 2023-12-16 05:18:36 -08:00
x86 xen: add atomic #defines to accomodate differing xen_ulong_t sizes 2023-12-15 14:59:26 +01:00
xdr
xen xen: add atomic #defines to accomodate differing xen_ulong_t sizes 2023-12-15 14:59:26 +01:00
Makefile
README.md

FreeBSD Kernel Source:

This directory contains the source files and build glue that make up the FreeBSD kernel and its modules, including both original and contributed software.

Kernel configuration files are located in the conf/ subdirectory of each architecture. GENERIC is the configuration used in release builds. NOTES contains documentation of all possible entries. LINT is a compile-only configuration used to maximize build coverage and detect regressions.

Documentation:

Source code documentation is maintained in a set of man pages, under section 9. These pages are located in share/man/man9, from the top-level of the src tree. Consult intro(9) for an overview of existing pages.

Some additional high-level documentation of the kernel is maintained in the Architecture Handbook.

Source Roadmap:

Directory Description
amd64 AMD64 (64-bit x86) architecture support
arm 32-bit ARM architecture support
arm64 64-bit ARM (AArch64) architecture support
cam Common Access Method storage subsystem - cam(4) and ctl(4)
cddl CDDL-licensed optional sources such as DTrace
conf kernel build glue
compat Linux compatibility layer, FreeBSD 32-bit compatibility
contrib 3rd-party imported software such as OpenZFS
crypto crypto drivers
ddb interactive kernel debugger - ddb(4)
fs most filesystems, excluding UFS, NFS, and ZFS
dev device drivers and other arch independent code
gdb kernel remote GDB stub - gdb(4)
geom GEOM framework - geom(4)
i386 i386 (32-bit x86) architecture support
kern main part of the kernel
libkern libc-like and other support functions for kernel use
modules kernel module infrastructure
net core networking code
net80211 wireless networking (IEEE 802.11) - net80211(4)
netgraph graph-based networking subsystem - netgraph(4)
netinet IPv4 protocol implementation - inet(4)
netinet6 IPv6 protocol implementation - inet6(4)
netipsec IPsec protocol implementation - ipsec(4)
netpfil packet filters - ipfw(4), pf(4), and ipfilter(4)
opencrypto OpenCrypto framework - crypto(7)
powerpc PowerPC/POWER (32 and 64-bit) architecture support
riscv 64-bit RISC-V architecture support
security security facilities - audit(4) and mac(4)
sys kernel headers
tests kernel unit tests
ufs Unix File System - ffs(7)
vm virtual memory system
x86 code shared by AMD64 and i386 architectures