opnsense-src/sys
Andrew Gallatin fd67ff5c7a Use the correct idle routine on recent AMD EPYC servers
We have been incorrectly choosing the "hlt" idle method on modern AMD
EPYC servers for C1 idle. This is because AMD also uses the Functional
Fixed Hardware interface. Due to not parsing the table properly for
AMD, and due to a weird quirk where the mwait latency for C1 is
mis-interpreted as the latency for hlt, we wind up choosing hlt for
c1, which has a far higher wake up latency (similar to IO) of roughly
400us on my test system (AMD 7502P).

This patch fixes this by:

- Looking for AMD in addition to Intel in the FFH
 (Note the vendor id of "2" for AMD is not publically documented, but
 AMD has confirmed they are using "2" and has promised to document it.)

- Using mwait on AMD when specified in the table, and when CPUid says
 its supported

- Fixing a weird issue where we copy the contents of cx_ptr for C1 and
 when moving to C2, we do not reinitialize cx_ptr. This leads to
 mwait being selected, and ignoring the specified i/o halt method
 unless we clear mwait before looking at the table for C2.

Differential Revision: https://reviews.freebsd.org/D47444
Reviewed by: dab, kib, vangyzen
Sponsored by: Netflix
2024-11-08 17:10:44 -05:00
..
amd64 vmm: Postpone vmm module initialization to after SI_SUB_DEVFS 2024-11-07 20:38:38 +00:00
arm Check for errors when detaching children first, not last 2024-11-04 20:30:33 -05:00
arm64 vmm: Postpone vmm module initialization to after SI_SUB_DEVFS 2024-11-07 20:38:38 +00:00
bsm
cam da: Add quirk for ADATA USB Drive 2024-11-07 17:40:05 -07:00
cddl Update mentions of makesyscalls.lua 2024-10-30 21:04:31 +00:00
compat LinuxKPI: lockdep fix #includes 2024-11-02 01:24:42 +00:00
conf ng_ubt(4): do not attach Realtek 87XX/88XX adaptors in bootloader mode. 2024-11-07 02:28:11 +03:00
contrib iwlwifi: script to extract firmware details 2024-11-08 18:09:37 +00: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 Use the correct idle routine on recent AMD EPYC servers 2024-11-08 17:10:44 -05:00
dts dts: Fix arm/qcom-ipq4018-rt-ac58u.dts for recent device-tree versions 2024-07-17 13:55:49 +01:00
fs p9fs: Use UNLINKAT instead of REMOVE to implement removals 2024-11-07 18:23:32 +00:00
gdb thread: Remove kernel stack swapping support, part 4 2024-07-29 01:40:22 +00:00
geom geom_flashmap: Rename the kernel module 2024-10-29 15:11:12 +00:00
gnu
i386 x86: Remove invalid DEVMETHOD methods for leaf devices 2024-11-01 10:10:30 -04:00
isa isa: Use a bus_child_deleted method to free ivars for children 2024-11-01 10:09:31 -04:00
kern vm_object: do not assume that un_pager.devp.dev is cdev 2024-11-06 02:11:00 +02:00
kgssapi
libkern include: ssp: round out fortification of current set of headers 2024-07-13 00:16:24 -05:00
modules ng_ubt(4): do not attach Realtek 87XX/88XX adaptors in bootloader mode. 2024-11-07 02:28:11 +03:00
net pf: Fix handling of v6 loopback connections with pf syncookies enabled 2024-10-29 15:01:20 +00:00
net80211 net80211: add MMIC element ID (for management frame protected group action frames) 2024-09-13 14:13:58 -07:00
netgraph ng_ubt(4): do not attach Realtek 87XX/88XX adaptors in bootloader mode. 2024-11-07 02:28:11 +03:00
netinet inpcb: Remove some unused parameters in internal hash lookup functions 2024-11-08 14:25:19 +00:00
netinet6 inpcb: Remove some unused parameters in internal hash lookup functions 2024-11-08 14:25:19 +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: fix cmd id for PFNL_CMD_GET_ADDR 2024-11-06 12:02:31 +01:00
netsmb netsmb: Stop checking for failures from malloc(M_WAITOK) 2024-09-03 18:25:20 +08:00
nfs
nfsclient
nfsserver
nlm
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 sys: Avoid relying on pollution from refcount.h 2024-11-05 18:22:20 +00:00
riscv vmm: Postpone vmm module initialization to after SI_SUB_DEVFS 2024-11-07 20:38:38 +00:00
rpc nfs, rpc: Ensure kernel credentials have at least one group 2024-11-02 21:37:42 +01:00
security cred: kern_setgroups(): Internally use int as number of groups' type 2024-11-02 21:37:41 +01:00
sys rtld: add rtld_{get,set}_var 2024-11-07 07:15:23 +02: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: add a NOLIB modifer to prevent stub generation 2024-11-01 15:44:47 +00:00
ufs softdep_mount: report failure of the softdepflush thread creation 2024-09-15 17:59:10 +03:00
vm vm_object: do not assume that un_pager.devp.dev is cdev 2024-11-06 02:11:00 +02:00
x86 Use the correct idle routine on recent AMD EPYC servers 2024-11-08 17:10:44 -05:00
xdr rpc: Fix the definition of xdr_void() 2024-10-30 19:27:18 +00: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