opnsense-src/sys
Gleb Smirnoff 446ccdd08e tcp: use single locked callout per tcpcb for the TCP timers
Use only one callout structure per tcpcb that is responsible for handling
all five TCP timeouts.  Use locked version of callout, of course. The
callout function tcp_timer_enter() chooses soonest timer and executes it
with lock held.  Unless the timer reports that the tcpcb has been freed,
the callout is rescheduled for next soonest timer, if there is any.

With single callout per tcpcb on connection teardown we should be able
to fully stop the callout and immediately free it, avoiding use of
callout_async_drain().  There is one gotcha here: callout_stop() can
actually touch our memory when a rare race condition happens.  See
comment above tcp_timer_stop().  Synchronous stop of the callout makes
tcp_discardcb() the single entry point for tcpcb destructor, merging the
tcp_freecb() to the end of the function.

While here, also remove lots of lingering checks in the beginning of
TCP timer functions.  With a locked callout they are unnecessary.

While here, clean unused parts of timer KPI for the pluggable TCP stacks.

While here, remove TCPDEBUG from tcp_timer.c, as this allows for more
simplification of TCP timers.  The TCPDEBUG is scheduled for removal.

Move the DTrace probes in timers to the beginning of a function, where
a tcpcb is always existing.

Discussed with:		rrs, tuexen, rscheff	(the TCP part of the diff)
Reviewed by:		hselasky, kib, mav	(the callout part)
Differential revision:	https://reviews.freebsd.org/D37321
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 OpenSSL: Regen assembly file for OpenSSSL 1.1.1s 2022-11-01 19:12:09 -04:00
ddb ddb: Don't flag breakpoint/watchpoint commands as MEMSAFE 2022-11-02 13:46:24 -04:00
dev tcp: embed inpcb into tcpcb 2022-12-07 09:00:48 -08:00
dts arm64/rockchip: Remove rk3328-dwc3 overlays 2022-11-16 11:58:32 +01:00
fs nfs: Fix common typos in source code comments 2022-11-08 14:58:32 +01:00
gdb ddb: use _FLAGS command macros where appropriate 2022-07-05 11:56:55 -03:00
geom Don't panic when tasting a disk with sectorsize=0 2022-11-09 10:21:12 -07:00
gnu bwn: eliminate dead writes in BWN_GPL_PHY 2022-05-04 09:32:59 -04:00
i386 Retire broken GPROF support from the kernel 2022-11-15 14:17:10 +00:00
isa Adjust function definition in isa's pnp.c to avoid clang 15 warning 2022-07-27 21:13:59 +02:00
kern Revert "newbus: Change attach failure behavior" 2022-12-05 17:00:26 -07:00
kgssapi kgssapi krb5: Remove unused variables. 2022-04-06 16:45:29 -07:00
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 ng_hci: handle NG_HCI_M_PULLUP failure in le_advertizing_report 2022-11-01 14:33:37 -04:00
netinet tcp: use single locked callout per tcpcb for the TCP timers 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 smb_smb_treedisconnect: eliminate write only variable mbp 2022-04-04 22:30:57 -06:00
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 ibcore: The use of IN_LOOPBACK() now requires a valid VNET context. 2022-09-23 13:42:03 +02:00
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 Check alignment of fp in unwind_frame 2022-11-16 18:29:28 +00:00
rpc clnt_vc.c: Replace msleep() with pause() to avoid assert panic 2022-10-14 15:46:55 -07:00
security mac_lomac: whack giant usage 2022-11-15 14:31:41 +00:00
sys tcp: use single locked callout per tcpcb for the TCP timers 2022-12-07 09:00:48 -08:00
teken
tests
tools dtb: Be much less verbose in the building of dtb 2022-10-29 10:13:54 -06:00
ufs Provide more precise mount(8) failure message. 2022-12-05 14:50:42 -08:00
vm ddb: don't limit pindex output in 'show vmopag' 2022-11-11 14:25:39 -04:00
x86 Retire broken GPROF support from the kernel 2022-11-15 14:17:10 +00:00
xdr
xen xenbus: improve device tracking 2022-06-07 12:29:53 +02:00
Makefile Remove dead code in the cscope target 2022-11-11 15:53:57 +00:00
README.md README.md: shift description of kernel config files 2022-11-01 12:20:55 -03: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.

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