freebsd-nq/sys
Gleb Smirnoff e68b379244 tcp: embed inpcb into tcpcb
For the TCP protocol inpcb storage specify allocation size that would
provide space to most of the data a TCP connection needs, embedding
into struct tcpcb several structures, that previously were allocated
separately.

The most import one is the inpcb itself.  With embedding we can provide
strong guarantee that with a valid TCP inpcb the tcpcb is always valid
and vice versa.  Also we reduce number of allocs/frees per connection.
The embedded inpcb is placed in the beginning of the struct tcpcb,
since in_pcballoc() requires that.  However, later we may want to move
it around for cache line efficiency, and this can be done with a little
effort.  The new intotcpcb() macro is ready for such move.

The congestion algorithm data, the TCP timers and osd(9) data are
also embedded into tcpcb, and temprorary struct tcpcb_mem goes away.
There was no extra allocation here, but we went through extra pointer
every time we accessed this data.

One interesting side effect is that now TCP data is allocated from
SMR-protected zone.  Potentially this allows the TCP stacks or other
TCP related modules to utilize that for their own synchronization.

Large part of the change was done with sed script:

s/tp->ccv->/tp->t_ccv./g
s/tp->ccv/\&tp->t_ccv/g
s/tp->cc_algo/tp->t_cc/g
s/tp->t_timers->tt_/tp->tt_/g
s/CCV\(ccv, osd\)/\&CCV(ccv, t_osd)/g

Dependency side effect is that code that needs to know struct tcpcb
should also know struct inpcb, that added several <netinet/in_pcb.h>.

Differential revision:	https://reviews.freebsd.org/D37127
2022-12-07 09:00:48 -08:00
..
amd64 vmm: Remove stale comment for vm_rendezvous. 2022-11-30 13:06:46 -08:00
arm AM335x: Fix compatible name 2022-11-28 08:13:18 +01:00
arm64 arm64/machdep: Reserve memory when we find Linux EFI reserved memory table 2022-11-30 16:31:14 -07:00
bsm
cam CTL: Allow userland supply tags via ioctl frontend. 2022-12-03 12:05:05 -05:00
cddl powerpc/dtrace: Guard fuword64 usage for powerpc64 only 2022-11-20 19:50:45 -05:00
compat linuxkpi: Fix style for dma_map_sgtable 2022-12-06 16:52:16 +01:00
conf tcp: embed inpcb into tcpcb 2022-12-07 09:00:48 -08:00
contrib zfs: merge openzfs/zfs@59493b63c (master) 2022-12-07 14:10:46 +01:00
crypto
ddb
dev tcp: embed inpcb into tcpcb 2022-12-07 09:00:48 -08:00
dts
fs
gdb
geom
gnu
i386
isa
kern Revert "newbus: Change attach failure behavior" 2022-12-05 17:00:26 -07:00
kgssapi
libkern ashldi3: Use C89-style function definition 2022-11-27 13:23:25 -07:00
modules zfs: merge openzfs/zfs@59493b63c (master) 2022-12-07 14:10:46 +01:00
net if_ovpn: extend notifications with a reason 2022-12-05 11:09:34 +01:00
net80211 net80211: fix IEEE80211_DEBUG_REFCNT builds 2022-11-29 21:20:37 +00:00
netgraph
netinet tcp: embed inpcb into tcpcb 2022-12-07 09:00:48 -08:00
netinet6 tcp: embed inpcb into tcpcb 2022-12-07 09:00:48 -08:00
netipsec tcp: embed inpcb into tcpcb 2022-12-07 09:00:48 -08:00
netlink netlink: fix non-multipath build 2022-12-02 22:21:00 +00:00
netpfil tcp: embed inpcb into tcpcb 2022-12-07 09:00:48 -08:00
netsmb
nfs Allow any user to read the NFS stats, for example with nfsstat(1). 2022-12-01 22:21:14 -07:00
nfsclient
nfsserver
nlm nlm: only access refcounts using dedicated primitives 2022-11-24 19:46:43 +00:00
ofed
opencrypto crypto: move all zeroing into crypto_getreq 2022-11-22 12:28:07 +00:00
powerpc powerpc/mpc85xx: Add compat strings for P5040 PCIe 2022-11-30 19:45:10 -05:00
riscv
rpc
security
sys tree.h: Fix SP/TAB white-space issues, add () for clarity. 2022-12-05 14:28:56 +00:00
teken
tests
tools
ufs Provide more precise mount(8) failure message. 2022-12-05 14:50:42 -08:00
vm
x86
xdr
xen
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.

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
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