freebsd-nq/sys/arm/conf
Andrew Gallatin 542970fa2d Remove IPSEC from GENERIC due to performance issues
Having IPSEC compiled into the kernel imposes a non-trivial
performance penalty on multi-threaded workloads due to IPSEC
refcounting. In my benchmarks of multi-threaded UDP
transmit (connected sockets), I've seen a roughly 20% performance
penalty when the IPSEC option is included in the kernel (16.8Mpps
vs 13.8Mpps with 32 senders on a 14 core / 28 HTT Xeon
2697v3)). This is largely due to key_addref() incrementing and
decrementing an atomic reference count on the default
policy. This cause all CPUs to stall on the same cacheline, as it
bounces between different CPUs.

Given that relatively few users use ipsec, and that it can be
loaded as a module, it seems reasonable to ask those users to
load the ipsec module so as to avoid imposing this penalty on the
GENERIC kernel. Its my hope that this will make FreeBSD look
better in "out of the box" benchmark comparisons with other
operating systems.

Many thanks to ae for fixing auto-loading of ipsec.ko when
ifconfig tries to configure ipsec, and to cy for volunteering
to ensure the the racoon ports will load the ipsec.ko module

Reviewed by:	cem, cy, delphij, gnn, jhb, jpaetzel
Differential Revision:	https://reviews.freebsd.org/D20163
2019-05-09 22:38:15 +00:00
..
ALPINE
APALIS-IMX6
ARMADA38X
ARMADAXP
ARNDALE
ARNDALE-OCTA
COLIBRI-VF50
COSMIC
DB-78XXX
DB-88F5XXX
DB-88F6XXX
DEFAULTS
DOCKSTAR
DREAMPLUG-1001
EA3250.hints
EFIKA_MX
genboardid.awk
GENERIC
GENERIC-MMCCAM
GENERIC-NODEBUG
IMX6
IMX53
JETSON-TK1
mach-types
Makefile
NOTES
QUARTZ
RPI-B
RT1310
SAM9G20EK.hints
SHEEVAPLUG
SOCDK
SOCFPGA
SOCKIT
SOCKIT-BERI
std.arm
std.armv6 Remove IPSEC from GENERIC due to performance issues 2019-05-09 22:38:15 +00:00
std.armv7 Remove IPSEC from GENERIC due to performance issues 2019-05-09 22:38:15 +00:00
TEGRA124
TS7800
VERSATILEPB
VSATV102
VYBRID
YYHD18
ZEDBOARD