FreeBSD src
Go to file
John Baldwin 019cff03b3 OpenSSL: KTLS: Check for unprocessed receive records in ktls_configure_crypto.
KTLS implementations currently assume that the start of the in-kernel
socket buffer is aligned with the start of a TLS record for the
receive side.  The socket option to enable KTLS specifies the TLS
sequence number of this initial record.

When read ahead is enabled, data can be pending in the SSL read buffer
after negotiating session keys.  This pending data must be examined to
ensurs that the kernel's socket buffer does not contain a partial TLS
record as well as to determine the correct sequence number of the
first TLS record to be processed by the kernel.

In preparation for enabling receive kernel offload for TLS 1.3, move
the existing logic to handle read ahead from t1_enc.c into ktls.c and
invoke it from ktls_configure_crypto().

Approved by:	jkim
Obtained from:	OpenSSL commit 85773128d0e80cd8dcc772a6931d385b8cf4acd1
MFC after:	1 week
Sponsored by:	Netflix
Differential Revision:	https://reviews.freebsd.org/D34973
2022-05-04 13:08:03 -07:00
.cirrus-ci Cirrus-CI: add some timing info on pkg install failure 2021-08-04 15:02:00 -04:00
.github GitHub: Add libefivar's path to CODEOWNERS 2022-02-27 09:11:39 -07:00
bin pax(1): Remove a few double words in source code comments 2022-04-09 14:27:39 +02:00
cddl ctf: Link CTF toolchain man pages to ctf.5 2022-04-21 11:20:28 -04:00
contrib libcxxrt: Insert padding in __cxa_dependent_exception 2022-04-27 09:41:26 -04:00
crypto OpenSSL: KTLS: Check for unprocessed receive records in ktls_configure_crypto. 2022-05-04 13:08:03 -07:00
etc bintrans: move files to a new directory 2022-04-18 10:53:11 +02:00
gnu libdialog: Bump shared library version to 10. 2021-10-27 09:30:24 -07:00
include Import OpenSSL 1.1.1o 2022-05-03 11:01:12 -04:00
kerberos5 pkgbase: Create a FreeBSD-kerberos package 2021-09-07 10:23:14 +02:00
lib build target triple variable from sys/conf/newvers.sh 2022-05-03 08:09:38 -03:00
libexec libexec/rc.d/hostapd: Down/up interface when interface is specified 2022-04-22 09:15:49 -07:00
release release: fix on-disc pkg binary symbolic links 2022-04-26 15:52:40 -04:00
rescue rescue: Link with -lncursesw instead of -lncursesw_real. 2022-02-11 13:58:59 -08:00
sbin pkgbase: move devd's hyperv.conf to hyperv-tools package 2022-05-03 18:15:54 +02:00
secure OpenSSL: Merge OpenSSL 1.1.1o 2022-05-03 15:12:42 -04:00
share build target triple variable from sys/conf/newvers.sh 2022-05-03 08:09:38 -03:00
stand stand: Initial kboot support on amd64 2022-05-01 11:13:39 -06:00
sys asmc: Add support for Macmini 5,1 (2011) and 5,3 and 7,1 (2014) models 2022-05-04 11:31:01 -04:00
targets bintrans: move files to a new directory 2022-04-18 10:53:11 +02:00
tests tests: vnet tests started failing in CI, disable temporarily 2022-05-04 06:19:46 +02:00
tools mfc-candidates.sh: Set default target branch for ports 2022-05-04 16:43:20 -03:00
usr.bin diff3: Remove test case that references non existent test files 2022-05-02 16:00:44 +01:00
usr.sbin bsdinstall/script: umount before zpool export 2022-05-03 16:02:39 +02:00
.arcconfig Remove history.immutable from .arcconfig 2021-04-13 12:36:25 +01:00
.arclint arc lint: ignore /tests/ in chmod 2017-12-19 03:38:06 +00:00
.cirrus.yml Cirrus-CI: add a manual amd64-gcc9 build and smoketest job 2022-02-15 12:55:14 -05:00
.clang-format clang-format: Add bitset loop macros 2021-09-21 12:08:01 -04:00
.gitattributes Add a basic clang-format configuration file 2019-06-07 15:23:52 +00:00
.gitignore Vendor import of BearSSL at 2022-04-18 hash d40d23b 2022-04-18 11:05:13 -07:00
COPYRIGHT Welcome 2022, update copyrights. 2022-01-01 09:49:49 -07:00
LOCKS LOCKS: update current locks 2018-06-09 03:08:04 +00:00
MAINTAINERS Remove myself from bhyve maintenance; ENOTIME. 2021-11-19 07:09:30 +10:00
Makefile cleankernel: A target to delete the kernel compile file 2022-02-11 12:51:24 -07:00
Makefile.inc1 build target triple variable from sys/conf/newvers.sh 2022-05-03 08:09:38 -03:00
Makefile.libcompat Makefile.libcompat: Sort 2022-02-02 14:34:29 -07: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 bintrans: move files to a new directory 2022-04-18 10:53:11 +02:00
README.md README.md: update gnu directory description 2021-12-17 08:45:31 -05:00
RELNOTES RELNOTES: Add an entry for boottrace(4) 2022-03-29 13:35:14 +02:00
UPDATING UPDATING: Fix a few typos 2022-04-10 10:11:17 +02: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.

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.
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 FreeBSD Handbook.