freebsd kernel with SKQ
Go to file
Konstantin Belousov c1141fba00 Update L1TF workaround to sustain L1D pollution from NMI.
Current mitigation for L1TF in bhyve flushes L1D either by an explicit
WRMSR command, or by software reading enough uninteresting data to
fully populate all lines of L1D.  If NMI occurs after either of
methods is completed, but before VM entry, L1D becomes polluted with
the cache lines touched by NMI handlers.  There is no interesting data
which NMI accesses, but something sensitive might be co-located on the
same cache line, and then L1TF exposes that to a rogue guest.

Use VM entry MSR load list to ensure atomicity of L1D cache and VM
entry if updated microcode was loaded.  If only software flush method
is available, try to help the bhyve sw flusher by also flushing L1D on
NMI exit to kernel mode.

Suggested by and discussed with: Andrew Cooper <andrew.cooper3@citrix.com>
Reviewed by:	jhb
Sponsored by:	The FreeBSD Foundation
MFC after:	2 weeks
Differential revision:	https://reviews.freebsd.org/D16790
2018-08-19 18:47:16 +00:00
bin ls(1): Gate the do_color_* definitions behind COLORLS 2018-08-18 21:03:19 +00:00
cddl libbe(3): Move build goop back out of cddl/ 2018-08-18 03:20:59 +00:00
contrib Update userland arc4random() with OpenBSD's Chacha20 based arc4random(). 2018-08-19 17:40:50 +00:00
crypto Update userland arc4random() with OpenBSD's Chacha20 based arc4random(). 2018-08-19 17:40:50 +00:00
etc Add Modbus Application Protocol to /etc/services 2018-08-17 15:18:57 +00:00
gnu Update libstdc++ configuration. 2018-07-16 18:53:28 +00:00
include Update userland arc4random() with OpenBSD's Chacha20 based arc4random(). 2018-08-19 17:40:50 +00:00
kerberos5 krb5-config build: Remove gratuitous escaping 2018-08-12 00:06:21 +00:00
lib Document socket control message routines for ancillary data access (CMSG_DATA). 2018-08-19 17:42:49 +00:00
libexec Rework rtld's TLS Variant I implementation to match r326794 2018-08-17 16:19:47 +00:00
release Copy the boot loader from the new location for the co-existing 2018-08-17 20:41:50 +00:00
rescue Avoid referencing private lib names directly. 2017-11-10 07:53:02 +00:00
sbin bectl(8): Allow running a custom command in the 'jail' subcommand 2018-08-18 01:12:44 +00:00
secure Fix build after r337852: Don't rebuild moduli based on unrelated moduli.c 2018-08-16 19:48:07 +00:00
share Document socket control message routines for ancillary data access (CMSG_DATA). 2018-08-19 17:42:49 +00:00
stand lualoader: Add drawer-exported variables for default logodefs 2018-08-19 18:43:10 +00:00
sys Update L1TF workaround to sustain L1D pollution from NMI. 2018-08-19 18:47:16 +00:00
targets send-pr: wave goodbye 2018-08-19 07:12:35 +00:00
tests Fix sys/netipsec/tunnel tests after r337736 2018-08-17 18:37:22 +00:00
tools Specify DB_FROM_SRC=yes when doing any installation target. 2018-08-16 22:13:43 +00:00
usr.bin send-pr: wave goodbye 2018-08-19 07:12:35 +00:00
usr.sbin send-pr: wave goodbye 2018-08-19 07:12:35 +00:00
.arcconfig callsign isn't required anymore 2016-09-29 06:19:45 +00:00
.arclint arc lint: ignore /tests/ in chmod 2017-12-19 03:38:06 +00:00
.gitattributes Remove spuriously added svn properties 2018-08-02 18:37:02 +00:00
.gitignore Ignore _.universe-toolchain file. 2018-07-01 13:50:37 +00:00
COPYRIGHT Remove 'All Rights Reserved' from the collection copyright and templates. 2018-05-09 02:02:49 +00:00
LOCKS LOCKS: update current locks 2018-06-09 03:08:04 +00:00
MAINTAINERS Add pointer to freebsd-numerics for libm. 2018-07-16 15:29:32 +00:00
Makefile As discussed several times on freebsd-arch, start to decommission armeb. 2018-07-17 23:23:34 +00:00
Makefile.inc1 libbe(3): Move build goop back out of cddl/ 2018-08-18 03:20:59 +00:00
Makefile.libcompat Install the 32-bit compat sanitizer libraries. 2018-08-03 18:52:51 +00:00
Makefile.sys.inc AUTO_OBJ: For all top-level targets enforce using an OBJDIR. 2017-12-05 21:29:47 +00:00
ObsoleteFiles.inc Update userland arc4random() with OpenBSD's Chacha20 based arc4random(). 2018-08-19 17:40:50 +00:00
README README: add generic notes about GENERIC and NOTES 2018-06-17 19:44:24 +00:00
README.md README: add generic notes about GENERIC and NOTES 2018-06-17 19:44:24 +00:00
UPDATING Turn back the clock just a little: make userboot.so always be 4th 2018-08-19 18:18:19 +00:00

FreeBSD Source:

This is the top level of the FreeBSD source directory. This file was last revised on: FreeBSD

FreeBSD is an operating system used to power modern servers, desktops, and embedded platforms. A large community has continually developed it for more than thirty years. Its advanced networking, security, and storage features have made FreeBSD the platform of choice for many of the busiest web sites and most pervasive embedded networking and storage devices.

For copyright information, please see the file COPYRIGHT in this directory. Additional copyright information also exists for some sources in this tree - please see the specific source directories for more information.

The Makefile in this directory supports a number of targets for building components (or all) of the FreeBSD source tree. See build(7), config(8), https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/makeworld.html, and https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html for more information, including setting make(1) variables.

Source Roadmap:

bin		System/user commands.

cddl		Various commands and libraries under the Common Development
		and Distribution License.

contrib		Packages contributed by 3rd parties.

crypto		Cryptography stuff (see crypto/README).

etc		Template files for /etc.

gnu		Various commands and libraries under the GNU Public License.
		Please see gnu/COPYING* for more information.

include		System include files.

kerberos5	Kerberos5 (Heimdal) package.

lib		System libraries.

libexec		System daemons.

release		Release building Makefile & associated tools.

rescue		Build system for statically linked /rescue utilities.

sbin		System commands.

secure		Cryptographic libraries and commands.

share		Shared resources.

stand		Boot loader sources.

sys		Kernel sources.

sys/<arch>/conf Kernel configuration files. GENERIC is the configuration
		used in release builds. NOTES contains documentation of
		all possible entries.

tests		Regression tests which can be run by Kyua.  See tests/README
		for additional information.

tools		Utilities for regression testing and miscellaneous tasks.

usr.bin		User commands.

usr.sbin	System administration commands.

For information on synchronizing your source tree with one or more of the FreeBSD Project's development branches, please see:

https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/current-stable.html