opnsense-src/sys
Kevin Bowling bc9402abdd igc: Add AIM
igc is derived from igb and has never had an AIM implementation. The
same algorithm from e1000 is appropriate here.

Upon more detailed study of the Linux driver which has a newer AIM
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.

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

MFC after:	1 week
Relnotes:	yes
Sponsored by:	Rubicon Communications, LLC ("Netgate")
Sponsored by:	BBOX.io
Differential Revision:	https://reviews.freebsd.org/D47053
2024-10-12 00:36:39 -07:00
..
amd64 vmm: avoid potential KASSERT kernel panic in vm_handle_db 2024-10-02 12:58:45 -04:00
arm intrng: Add support for multiple interrupt roots 2024-09-22 07:18:34 -06:00
arm64 arm64: Disable coverage sanitization of pmap_update_strided 2024-10-11 16:52:53 +00:00
bsm timerfd: Move implementation from linux compat to sys/kern 2023-08-24 14:28:56 -06:00
cam ctl: limit memory allocation in pci_virtio_scsi 2024-10-03 20:22:34 -04:00
cddl dtrace/amd64: Remove the dtrace_invop_callsite symbol 2024-09-19 09:22:13 +00:00
compat LinuxKPI: add new dummy headers visibility.h and of_net.h 2024-10-11 20:58:35 +00:00
conf LinuxKPI: always include linux/kconfig.h 2024-10-11 20:50:27 +00:00
contrib acpica: Update the SPCR table to version 4 2024-10-11 12:06:33 -06: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 igc: Add AIM 2024-10-12 00:36:39 -07:00
dts dts: Fix arm/qcom-ipq4018-rt-ac58u.dts for recent device-tree versions 2024-07-17 13:55:49 +01:00
fs tmpfs: check residence in data_locked 2024-10-04 02:44:19 -05:00
gdb thread: Remove kernel stack swapping support, part 4 2024-07-29 01:40:22 +00:00
geom ggate: Avoid dropping the GEOM topology lock in dumpconf 2024-10-04 15:56:34 +00:00
gnu sys: Automated cleanup of cdefs and other formatting 2023-11-26 22:24:00 -07:00
i386 sysent: regen comments 2024-10-01 18:46:40 +01:00
isa newbus: replace -1 in BUS_ADD_CHILD(...-1) with DEVICE_UNIT_ANY 2024-07-24 22:23:02 -06:00
kern kinfo_vmentry: report cdev name for device mappings 2024-10-11 13:14:04 +03:00
kgssapi sys: Automated cleanup of cdefs and other formatting 2023-11-26 22:24:00 -07:00
libkern include: ssp: round out fortification of current set of headers 2024-07-13 00:16:24 -05:00
modules rtw89: add man page and hook driver up to the build 2024-10-11 13:47:11 +00:00
net debugnet: Use precise types when accessing mbuf contents 2024-10-11 13:23:25 +00:00
net80211 net80211: add MMIC element ID (for management frame protected group action frames) 2024-09-13 14:13:58 -07:00
netgraph bluetooth(3): Fix two typos in source code comments 2024-09-20 20:00:04 +02:00
netinet sctp: check locking requirements 2024-10-10 15:50:41 +02:00
netinet6 netinet: Explicitly disallow connections to the unspecified address 2024-08-29 13:11:15 +00:00
netipsec ipsec: Drain async ipsec_offload work when destroying a vnet 2024-09-04 14:28:28 +00:00
netlink netinet: correct SIOCDIFADDR{,_IN6} calls to use {,in6_}ifreq 2024-07-22 14:17:21 +00:00
netpfil pf: remove redundant arguments to pf_state_key_addr_setup() 2024-10-10 14:10:42 +02:00
netsmb netsmb: Stop checking for failures from malloc(M_WAITOK) 2024-09-03 18:25:20 +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 sys: Automated cleanup of cdefs and other formatting 2023-11-26 22:24:00 -07:00
ofed LinuxKPI: Remove owner argument from class_create function on KBI layer 2024-07-21 16:09:58 +03:00
opencrypto ktls: Remove the socket parameter to ktls_ocf_try() 2024-07-08 12:10:48 -04:00
powerpc powerpc: Add nominal support for POWER10 and POWER11 2024-10-11 17:17:43 -04:00
riscv intrng: Add support for multiple interrupt roots 2024-09-22 07:18:34 -06:00
rpc svc.c: Check for a non-NULL xp_socket 2024-05-27 19:22:04 -07:00
security MAC: improve handling of listening sockets 2024-09-26 08:06:24 +02:00
sys cdefs: Add __nosanitizecoverage 2024-10-11 16:52:53 +00:00
teken Typo: brig(h)tness 2024-09-11 08:35:46 +00:00
tests tests: Stop checking for failures from malloc(M_WAITOK) 2024-09-03 18:25:21 +08:00
tools sysent: fix a couple more do-no-edit comments 2024-10-03 18:01:30 +01:00
ufs softdep_mount: report failure of the softdepflush thread creation 2024-09-15 17:59:10 +03:00
vm swap_pager: swapoff detecting object death 2024-10-11 12:45:54 -05:00
x86 iommu_qi_seq_processed: use atomic to read hw-written seq number 2024-10-03 09:19:09 +03:00
xdr xdr: Stop checking for failures from malloc(M_WAITOK) 2024-09-03 18:25:20 +08:00
xen xen: introduce a per-arch scratch mapping ranges 2024-07-30 09:39:38 +02: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