Find a file
Mark Johnston 9a3444d91c ossl: Add a VAES-based AES-GCM implementation for amd64
aes-gcm-avx512.S is generated from OpenSSL 3.1 and implements AES-GCM.
ossl_x86.c detects whether the CPU implements the required AVX512
instructions; if not, the ossl(4) module does not provide an AES-GCM
implementation.  The VAES implementation increases throughput for all
buffer sizes in both directions, up to 2x for sufficiently large
buffers.

The "process" implementation is in two parts: a generic OCF layer in
ossl_aes.c that calls a set of MD functions to do the heavy lifting.
The intent there is to make it possible to add other implementations for
other platforms, e.g., to reduce the diff required for D37421.

A follow-up commit will add a fallback path to legacy AES-NI, so that
ossl(4) can be used in preference to aesni(4) on all amd64 platforms.
In the long term we would like to replace aesni(4) and armv8crypto(4)
with ossl(4).

Note, currently this implementation will not be selected by default
since aesni(4) and ossl(4) return the same probe priority for crypto
sessions, and the opencrypto framework selects the first registered
implementation to break a tie.  Since aesni(4) is compiled into the
kernel, aesni(4) wins.  A separate change may modify ossl(4) to have
priority.

Sponsored by:	Stormshield
Sponsored by:	Klara, Inc.
Reviewed by:	jhb
MFC after:	3 months
Differential Revision:	https://reviews.freebsd.org/D39783
2023-06-02 12:15:01 -04:00
.cirrus-ci Cirrus-CI: add some timing info on pkg install failure 2021-08-04 15:02:00 -04:00
.github MAINTAINERS: Add myself to stand 2023-05-07 22:30:10 -06:00
bin pwd.1: replace /home with /sys in example 2023-05-23 07:21:50 -05:00
cddl zfsd: Fix typo in comment 2023-06-01 20:33:42 -06:00
contrib ntp: import ntp-4.2.8p16 2023-06-01 07:04:37 -07:00
crypto OpenSSL: Merge OpenSSL 1.1.1u 2023-05-30 10:40:04 -04:00
etc Add simple factor/primes regression tests 2023-05-27 11:11:44 -07:00
gnu Update/fix Makefile.depend for userland 2023-04-18 17:14:23 -07:00
include ntp: import ntp-4.2.8p16 2023-06-01 06:28:01 -07:00
kerberos5 spdx: The BSD-2-Clause-FreeBSD identifier is obsolete, drop -FreeBSD 2023-05-12 10:44:03 -06:00
lib gpart(8): Improve manual page syntax 2023-06-01 20:43:04 -06:00
libexec Revert "When stopping powerd, set the CPU frequency back to its maximum value" 2023-05-25 09:40:26 -04:00
release release/oci.conf: add missing vm_extra_pre_umount() steps 2023-05-24 13:11:07 -04:00
rescue Update/fix Makefile.depend for userland 2023-04-18 17:14:23 -07:00
sbin dumpon: Request the OpenSSL 1.1 API 2023-06-02 10:00:48 -04:00
secure OpenSSL: Merge OpenSSL 1.1.1u 2023-05-30 11:14:28 -04:00
share ports(7): '*-list' targets: Add/fix doc on whether they are recursive 2023-06-01 20:38:16 -06:00
stand stand: libefi: avoid a null pointer deref in eficom 2023-05-28 13:54:50 -05:00
sys ossl: Add a VAES-based AES-GCM implementation for amd64 2023-06-02 12:15:01 -04:00
targets local.dirdeps.mk skip N_host_libs for non-FreeBSD host 2023-05-04 11:58:39 -07:00
tests netlink: use netlink mbufs in the mbuf chains. 2023-06-02 13:14:20 +00:00
tools genl: add new command to list genetlink(4) 2023-05-30 13:36:43 +02:00
usr.bin split(1): add '-c' to continue creating files 2023-05-30 16:13:16 +03:00
usr.sbin mfiuitl: Spell acquire correctly 2023-06-01 20:33:42 -06:00
.arcconfig arcanist: use FreeBSD/git project repository instead of FreeBSD/svn 2022-08-23 14:16:41 +00:00
.arclint
.cirrus.yml Cirrus-CI: add amd64 and arm64 Clang/LLVM 16 jobs 2023-05-30 09:17:15 -04:00
.clang-format clang-format: Add bitset loop macros 2021-09-21 12:08:01 -04:00
.git-blame-ignore-revs Add git-blame ignore file 2023-01-23 15:27:25 -05:00
.gitattributes Add a basic clang-format configuration file 2019-06-07 15:23:52 +00:00
.gitignore .gitignore: Ignore LSP generated .cache 2023-03-07 10:04:18 -05:00
CONTRIBUTING.md CONTRIBUTING.md: minor changes 2023-05-14 06:51:56 -06:00
COPYRIGHT ntp: import ntp-4.2.8p16 2023-06-01 06:28:01 -07:00
LOCKS
MAINTAINERS MAINTAINERS: Add myself to stand 2023-05-07 22:30:10 -06:00
Makefile Move MACHINE/MACHINE_ARCH handling to sys.machine.mk 2023-05-13 08:15:49 -07:00
Makefile.inc1 Makefile.inc1: use make builtin :ts instead of sed 2023-05-05 08:14:35 -04:00
Makefile.libcompat libcompat: avoid installing include files twice 2022-11-16 19:15:20 -05:00
Makefile.sys.inc
ObsoleteFiles.inc delete-old: add two files left behind in certs/blacklisted 2023-05-24 13:03:10 -07:00
README.md README.md: link to the list of supported platforms 2022-11-01 12:20:55 -03:00
RELNOTES RELNOTES: add note about moving /usr/home to /home 2023-05-24 10:32:07 -05:00
UPDATING Update UPDATING 2023-05-14 07:05:42 -06:00

FreeBSD Source:

This is the top level of the FreeBSD source directory.

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), FreeBSD handbook on building userland, and Handbook for kernels for more information, including setting make(1) variables.

For information on the CPU architectures and platforms supported by FreeBSD, see the FreeBSD website's Platforms page.

Source Roadmap:

Directory Description
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 Commands and libraries under the GNU General Public License (GPL) or Lesser General Public License (LGPL). Please see gnu/COPYING and gnu/COPYING.LIB 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 (see sys/README.md).
targets Support for experimental DIRDEPS_BUILD
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 FreeBSD Handbook.