opnsense-src/sys
Kevin Bowling 49f12d5b38 e1000: Re-add AIM
We originally left this out because iflib modulates interrupts and
accomplishes some level of batching versus the custom queues in the
older driver. Upon more detailed study of the Linux driver which has a
newer implementation, it finally became clear to me this is actually a
holdoff timer and not an interrupt limit as it is conventionally
(statically) programmed and displayed as an interrupt rate. The data
sheets also make this somewhat clear.

Thus, AIM accomplishes two beneficial things for a wide variety of
workloads[1]:

1. At low throughput/packet rates, it will significantly lower latency
(by counter-intuitively "increasing" the interrupt rate.. better
thought of as decreasing the holdoff timer because you will modulate
down before coming anywhere near these interrupt rates).
2. At bulk data rates, it is tuned to achieve a lower interrupt rate
(by increasing the holdoff timer) than the current static 8000/s. This
decreases processing overhead and yields more headroom for other work
such as packet filters or userland.

For a single NIC this might be worth a few sys% on common CPUs, but may
be meaningful when multiplied such as if_lagg, if_bridge and forwarding
setups.

The AIM algorithm was re-introduced from the older igb or out of tree
driver, and then modernized with permission to use Intel code from other
drivers.

I have retroactively added it to lem(4) and em(4) where the same concept
applies, albeit to a single ITR register.

[1]: http://iommu.com/datasheets/ethernet/controllers-nics/intel/e1000/gbe-controllers-interrupt-moderation-appl-note.pdf

Tested by:	cc (https://wiki.freebsd.org/chengcui/testD46768)
Relnotes:	yes
Sponsored by:	Rubicon Communications, LLC ("Netgate")
Sponsored by:	BBOX.io
Differential Revision:	https://reviews.freebsd.org/D46768

(cherry picked from commit 3e501ef896671cb190e8c40c6258b8f27d136f07)
2024-10-17 18:41:56 -07:00
..
amd64 sys: add conf/std.debug, generic debugging options 2024-10-09 10:44:35 +02:00
arm sys: add conf/std.debug, generic debugging options 2024-10-09 10:44:35 +02:00
arm64 sys: add conf/std.debug, generic debugging options 2024-10-09 10:44:35 +02:00
bsm
cam ctl: limit memory allocation in pci_virtio_scsi 2024-10-11 11:53:17 -04:00
cddl dtrace/amd64: Remove the dtrace_invop_callsite symbol 2024-10-04 15:56:42 +00:00
compat LinuxKPI: add cleanup.h for guard DEFINE_GUARD/guard. 2024-10-16 21:50:37 +00:00
conf 14.2: Update stable/14 to -PRERELEASE 2024-10-17 17:07:44 -07:00
contrib rtw89fw: remove module build dirs and firmware 2024-10-16 22:01:56 +00:00
crypto openssl: Import OpenSSL 3.0.15. 2024-09-27 20:50:47 -07:00
ddb
dev e1000: Re-add AIM 2024-10-17 18:41:56 -07:00
dts add allwinner overlays for enabling additional USB ports 2024-02-17 16:15:10 +02:00
fs Revert "nfscl: Enable support for the Lookup+Open RPC" 2024-10-11 17:45:22 -07:00
gdb
geom pkcs5v2: Add pkcs5v2_genkey_raw function 2024-09-29 08:24:52 -07:00
gnu
i386 sys: add conf/std.debug, generic debugging options 2024-10-09 10:44:35 +02:00
isa isa: Postpone removal of the non-PNP driver until 15 2023-10-30 08:55:08 +08:00
kern socket: Only log splice structs to ktrace if KTR_STRUCT is configured 2024-10-17 15:49:12 +00:00
kgssapi nfscl/kgssapi: Fix Kerberized NFS mounts to pNFS servers 2023-12-23 17:03:58 -08:00
libkern arm64: Mark the armv8 crc32c as supporting BTI 2024-02-19 13:17:47 +00:00
modules rtw89fw: remove module build dirs and firmware 2024-10-16 22:01:56 +00:00
net iflib: Make iflib_stop() static 2024-10-15 12:39:06 +08:00
net80211 net80211: scan/internal: change boolean argument from int to bool 2024-09-28 10:35:12 +00:00
netgraph bluetooth(3): Fix two typos in source code comments 2024-09-23 06:50:34 +02:00
netinet sctp: propagate cap rights on sctp_peeloff 2024-10-17 12:29:21 -04:00
netinet6 netinet: Explicitly disallow connections to the unspecified address 2024-09-20 11:39:16 +00:00
netipsec ipsec esp: avoid dereferencing freed secasindex 2024-03-04 02:27:17 +02:00
netlink netlink: Wrap long lines 2024-07-21 20:55:27 -04:00
netpfil pf: Stop checking for failures from malloc(M_WAITOK) 2024-09-30 12:44:16 +08:00
netsmb netsmb: Stop checking for failures from malloc(M_WAITOK) 2024-09-30 12:44:16 +08:00
nfs
nfsclient
nfsserver
nlm
ofed ibcore: Mark write-only variables 2024-07-15 12:28:53 +00:00
opencrypto ktls: Remove the socket parameter to ktls_ocf_try() 2024-07-23 09:01:30 -04:00
powerpc sys: add conf/std.debug, generic debugging options 2024-10-09 10:44:35 +02:00
riscv sys: add conf/std.debug, generic debugging options 2024-10-09 10:44:35 +02:00
rpc svc.c: Check for a non-NULL xp_socket 2024-05-31 15:35:18 -07:00
security MAC/do: allow to call setuid if real user id is 0 2024-06-27 10:47:06 +02:00
sys socket: Implement SO_SPLICE 2024-10-17 15:48:36 +00:00
teken teken: fix style in teken_wcwidth.h 2023-10-21 17:28:35 +03:00
tests tests: Stop checking for failures from malloc(M_WAITOK) 2024-09-30 12:44:18 +08:00
tools tools/sdiodevs2h.awk: introduce palias 2024-10-09 19:18:36 +00:00
ufs softdep_mount: report failure of the softdepflush thread creation 2024-09-22 00:19:50 +03:00
vm sysctl vm.vm_objects: report cdev name for device-backed objects 2024-10-15 18:03:59 +03:00
x86 iommu_qi_seq_processed: use atomic to read hw-written seq number 2024-10-10 12:10:33 +03:00
xdr xdr: Stop checking for failures from malloc(M_WAITOK) 2024-09-30 12:44:16 +08:00
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.

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