opnsense-src/sys
Mark Johnston 8b3d2c19d3 inpcb: Fix reuseport lbgroup array resizing
in_pcblisten() moves an inpcb from the per-group list into the array, at
which point it becomes visible to inpcb lookups in the datapath.  It
assumes that there is space in the array for this, but that's not
guaranteed, since in_pcbinslbgrouphash() doesn't reserve space in the
array if the inpcb isn't associated with a listening socket.

We could resize the array in in_pcblisten(), but that would introduce a
failure case where there currently is none.  Instead, keep track of the
number of pending inpcbs as well, and modify in_pcbinslbgrouphash() to
reserve space for each pending (i.e., not-yet-listening) inpcb.

Add a regression test.

Reviewed by:	glebius
Reported by:	netchild
Fixes:		7cbb6b6e28 ("inpcb: Close some SO_REUSEPORT_LB races, part 2")
Differential Revision:	https://reviews.freebsd.org/D49100
2025-02-23 16:20:12 +00:00
..
amd64 vmm: Consolidate code which manages guest memory regions 2025-02-18 16:00:07 +00:00
arm sys: Empty hints files 2025-02-21 17:25:32 -07:00
arm64 sys: Empty hints files 2025-02-21 17:25:32 -07:00
bsm New setcred() system call and associated MAC hooks 2024-12-16 15:42:39 +01:00
cam cam/cd: The SAW_MEDIA flag duplicates VALID_MEDIA 2025-02-08 14:40:28 -07:00
cddl Revert "dtrace/arm64: Simplify dtrace_getarg() slightly" 2025-01-29 03:12:46 +00:00
compat LinuxKPI: 802.11: fix locking in lkpi_ic_ampdu_rx_stop() 2025-02-23 00:36:50 +00:00
conf vmm: Consolidate code which manages guest memory regions 2025-02-18 16:00:07 +00:00
contrib zfs: merge openzfs/zfs@6a2f7b384 2025-02-20 17:40:55 +01:00
crypto libmd: re-apply masking of _Transform names 2024-09-30 14:59:31 -05:00
ddb proc: Remove kernel stack swapping support, part 6 2024-07-29 01:43:18 +00:00
dev qcom_ess_edma: Add the IPQ4018/IPQ4019 ethernet MAC/MDIO driver. 2025-02-20 18:48:12 -08:00
dts dts: Bump the freebsd branding version to 6.12 2025-01-08 10:34:06 +01:00
fs vm_page: define partial page invalidate 2025-02-21 19:22:47 -06:00
gdb thread: Remove kernel stack swapping support, part 4 2024-07-29 01:40:22 +00:00
geom gvinum: Remove kernel support 2025-01-23 11:20:42 -05:00
gnu sys: Automated cleanup of cdefs and other formatting 2023-11-26 22:24:00 -07:00
i386 sys: Add cpu_update_pcb hook 2025-01-31 15:40:29 -05:00
isa Replace calls to bus_generic_attach with bus_attach_children 2024-12-06 17:26:16 -05:00
kern umtx: Fix a bug in do_lock_pp() 2025-02-22 01:26:38 +00:00
kgssapi kgssapi: use netlink RPC client to talk to gssd(8) 2025-02-01 01:00:25 -08:00
libkern libkern: strdup.c, strndup.c: Prefer memcpy() over bcopy() 2025-02-17 23:37:59 +08:00
modules zfs: merge openzfs/zfs@6a2f7b384 2025-02-20 17:40:55 +01:00
net pf: make log(matches) more useful 2025-02-21 09:11:03 +01:00
net80211 net80211: crypto: ccmp: simplify and style(9) 2025-02-20 18:05:00 +00:00
netgraph ng_hci: add support for Bluetooth Secure Simple Pairing 2025-01-27 13:27:28 +00:00
netinet inpcb: Fix reuseport lbgroup array resizing 2025-02-23 16:20:12 +00:00
netinet6 icmp: use per rate limit randomized jitter 2025-02-10 22:16:20 +01:00
netipsec ipsec: allow it to work with unmapped mbufs 2025-01-13 21:29:32 +02:00
netlink netlink: with debugging log event when a socket is stuck 2025-02-05 10:09:06 -08:00
netpfil pf: Cut down on if statements around pf_icmp_state_lookup 2025-02-21 11:52:26 +01:00
netsmb sockets: garbage collect SB_NOINTR 2025-02-02 22:38:18 -08:00
nfs sys: Automated cleanup of cdefs and other formatting 2023-11-26 22:24:00 -07:00
nfsclient sys: Remove ancient SCCS tags. 2023-11-26 22:23:30 -07:00
nfsserver sys: Remove ancient SCCS tags. 2023-11-26 22:23:30 -07:00
nlm nlm: set vnet(9) context in the NLM syscall 2025-02-01 01:00:26 -08:00
ofed LinuxKPI: Remove owner argument from class_create function on KBI layer 2024-07-21 16:09:58 +03:00
opencrypto sys: make the kernel metadata pointer global 2025-01-24 14:25:51 -07:00
powerpc powerpc: mmu_radix_page_array_startup(): Don't force allocation from domain 0 2025-02-19 15:13:28 +01:00
riscv sys: Empty hints files 2025-02-21 17:25:32 -07:00
rpc krpc/clnt_nl: unregister the netlink group, when client is destroyed 2025-02-05 10:09:06 -08:00
security MAC: mac_biba, mac_lomac: Fix setting loader tunables 2025-02-09 23:53:29 +08:00
sys linuxkpi: Add shrinker_alloc() and shrinker_free() 2025-02-19 21:39:46 +01:00
teken Typo: brig(h)tness 2024-09-11 08:35:46 +00:00
tests netlink: refactor KPI for generic Netlink modules 2025-02-05 10:09:06 -08:00
tools makesyscalls: emit cpp in syscalls.map 2025-02-18 22:03:33 +00:00
ufs ffs: fix build with GEOM_LABEL and without FFS, e.g. MINIMAL 2025-02-01 01:00:25 -08:00
vm vm_page: define partial page invalidate 2025-02-21 19:22:47 -06:00
x86 x86: Fixes for nmi/pmi interrupt sharing 2025-02-05 10:26:27 -05:00
xdr xdr: provide x_putmbuf method for xdrmem 2025-02-01 01:00:25 -08:00
xen x86/xen: Use intended values in HVM_CALLBACK_VECTOR 2024-11-06 15:46:05 +01:00
Makefile sys: Index netlink/ files with the cscope target 2024-07-22 09:50:43 +00:00
README.md man filesystems: fix more xrefs after move to s4 2024-06-27 18:32:05 -06:00

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(4)
vm virtual memory system
x86 code shared by AMD64 and i386 architectures