summaryrefslogtreecommitdiff
path: root/UPDATING
diff options
context:
space:
mode:
authorAndrew Gallatin <gallatin@FreeBSD.org>2019-05-09 22:38:15 +0000
committerAndrew Gallatin <gallatin@FreeBSD.org>2019-05-09 22:38:15 +0000
commit542970fa2d3fb42af9addef22eb9e80d26b4c508 (patch)
treef93889921a4834755e0223e0bf2624a89e1f936e /UPDATING
parent9bee6a6083228d0e6abfb991fdbb4edf020fd438 (diff)
downloadsrc-test2-542970fa2d3fb42af9addef22eb9e80d26b4c508.tar.gz
src-test2-542970fa2d3fb42af9addef22eb9e80d26b4c508.zip
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
Notes
Notes: svn path=/head/; revision=347410
Diffstat (limited to 'UPDATING')
-rw-r--r--UPDATING4
1 files changed, 4 insertions, 0 deletions
diff --git a/UPDATING b/UPDATING
index 44438de07cb7..35bd16039d0f 100644
--- a/UPDATING
+++ b/UPDATING
@@ -32,6 +32,10 @@ NOTE TO PEOPLE WHO THINK THAT FreeBSD 13.x IS SLOW:
"ln -s 'abort:false,junk:false' /etc/malloc.conf".)
20190507:
+ The IPSEC option has been removed from GENERIC. Users requiring
+ ipsec(4) must now load the ipsec(4) kernel module.
+
+20190507:
The tap(4) driver has been folded into tun(4), and the module has been
renamed to tuntap. You should update any kld_load="if_tap" or
kld_load="if_tun" entries in /etc/rc.conf, if_tap_load="YES" or