freebsd with flexible iflib nic queues
Go to file
Ruslan Bukin 2164af29a0 Add support for Intel Software Guard Extensions (Intel SGX).
Intel SGX allows to manage isolated compartments "Enclaves" in user VA
space. Enclaves memory is part of processor reserved memory (PRM) and
always encrypted. This allows to protect user application code and data
from upper privilege levels including OS kernel.

This includes SGX driver and optional linux ioctl compatibility layer.
Intel SGX SDK for FreeBSD is also available.

Note this requires support from hardware (available since late Intel
Skylake CPUs).

Many thanks to Robert Watson for support and Konstantin Belousov
for code review.

Project wiki: https://wiki.freebsd.org/Intel_SGX.

Reviewed by:	kib
Relnotes:	yes
Sponsored by:	DARPA, AFRL
Differential Revision:	https://reviews.freebsd.org/D11113
2017-08-16 10:38:06 +00:00
bin Add supporting changes for Add limited sandbox capability to "make check" 2017-08-14 19:21:37 +00:00
cddl MFV r322229: 7600 zfs rollback should pass target snapshot to kernel 2017-08-08 10:52:01 +00:00
contrib Rename RISC-V GCC config directory: riscv64 -> riscv 2017-08-14 14:16:56 +00:00
crypto Upgrade to OpenSSH 7.5p1. 2017-08-04 12:57:24 +00:00
etc Unconditionally install rwhod support scripts. 2017-08-15 22:16:15 +00:00
gnu Convert all the arm big endian tests into a regexp rather than a list. 2017-08-14 22:25:20 +00:00
include Vendor import of libc++ release_50 branch r310316: 2017-08-08 16:53:40 +00:00
kerberos5 Remove dead target introduced in r178828. 2017-08-06 06:35:40 +00:00
lib There is no MACHINE_CPUARCH == armv6, remove redunant check. 2017-08-14 22:38:54 +00:00
libexec Add supporting changes for Add limited sandbox capability to "make check" 2017-08-14 19:21:37 +00:00
release Revert r322327, r322352, r322358: 2017-08-15 15:13:33 +00:00
rescue DIRDEPS_BUILD: Update dependencies. 2017-05-09 01:48:23 +00:00
sbin Typo, the '-6' option selects inet6. 2017-08-15 19:29:10 +00:00
secure Convert traditional ${MK_TESTS} conditional idiom for including test 2017-08-02 08:35:51 +00:00
share Use -S for library installations except for -DNO_ROOT builds. 2017-08-16 05:02:31 +00:00
sys Add support for Intel Software Guard Extensions (Intel SGX). 2017-08-16 10:38:06 +00:00
targets Update targets/pseudo/tests/Makefile.depend after recent additions/subtractions 2017-07-19 16:45:57 +00:00
tests Add supporting changes for Add limited sandbox capability to "make check" 2017-08-14 19:21:37 +00:00
tools Add limited sandbox capability to "make check" 2017-08-14 19:03:05 +00:00
usr.bin Add supporting changes for Add limited sandbox capability to "make check" 2017-08-14 19:21:37 +00:00
usr.sbin Add supporting changes for Add limited sandbox capability to "make check" 2017-08-14 19:21:37 +00:00
.arcconfig callsign isn't required anymore 2016-09-29 06:19:45 +00:00
.arclint
COPYRIGHT Bump copyright year. 2016-12-31 12:41:42 +00:00
LOCKS
MAINTAINERS Add asomers as a pjdfstest co-maintainer per the project status change 2017-06-28 09:25:15 +00:00
Makefile Make _TO_CPUARCH macro for ARCH to CPUARCH conversions 2017-08-12 17:07:27 +00:00
Makefile.inc1 Revert r322327, r322352, r322358: 2017-08-15 15:13:33 +00:00
Makefile.libcompat Follow-up to r321684 (Don't use libc++ when cross-building for gcc 2017-08-07 16:23:53 +00:00
ObsoleteFiles.inc Rework and simplify the ksyms(4) implementation. 2017-08-03 00:38:13 +00:00
README Vendor import of OpenSSH 7.5p1. 2017-08-03 10:10:20 +00:00
README.md Remove hard line breaks from README.md 2017-03-01 15:39:58 +00:00
UPDATING Add an UPDATING entry for r322511. 2017-08-14 19:18:50 +00:00

FreeBSD Source:

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

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) and http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/makeworld.html for more information, including setting make(1) variables.

The buildkernel and installkernel targets build and install the kernel and the modules (see below). Please see the top of the Makefile in this directory for more information on the standard build targets and compile-time flags.

Building a kernel is a somewhat more involved process. See build(7), config(8), and http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html for more information.

Note: If you want to build and install the kernel with the buildkernel and installkernel targets, you might need to build world before. More information is available in the handbook.

The kernel configuration files reside in the sys/<arch>/conf sub-directory. GENERIC is the default configuration used in release builds. NOTES contains entries and documentation for all possible devices, not just those commonly used.

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.

sys				Kernel sources.

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:

http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/synching.html