freebsd-dev/crypto/openssl/ssl
John Baldwin c0f977bfb6 OpenSSL: KTLS: Handle TLS 1.3 in ssl3_get_record.
- Don't unpad records, check the outer record type, or extract the
  inner record type from TLS 1.3 records handled by the kernel.  KTLS
  performs all of these steps and returns the inner record type in the
  TLS header.

- When checking the length of a received TLS 1.3 record don't allow
  for the extra byte for the nested record type when KTLS is used.

- Pass a pointer to the record type in the TLS header to the
  SSL3_RT_INNER_CONTENT_TYPE message callback.  For KTLS, the old
  pointer pointed to the last byte of payload rather than the record
  type.  For the non-KTLS case, the TLS header has been updated with
  the inner type before this callback is invoked.

Approved by:	jkim
Obtained from:	OpenSSL commit a5fb9605329fb939abb536c1604d44a511741624
MFC after:	1 week
Sponsored by:	Netflix
Differential Revision:	https://reviews.freebsd.org/D34975
2022-05-04 13:08:27 -07:00
..
record OpenSSL: KTLS: Handle TLS 1.3 in ssl3_get_record. 2022-05-04 13:08:27 -07:00
statem OpenSSL: Merge OpenSSL 1.1.1o 2022-05-03 15:07:06 -04:00
bio_ssl.c OpenSSL: Merge OpenSSL 1.1.1m 2021-12-14 16:03:52 -05:00
build.info OpenSSL: Support for kernel TLS offload (KTLS) 2021-01-28 10:24:13 -08:00
d1_lib.c Import OpenSSL 1.1.1l 2021-09-01 00:26:38 -04:00
d1_msg.c Merge OpenSSL 1.1.1e. 2020-03-18 02:13:12 +00:00
d1_srtp.c Merge OpenSSL 1.1.1e. 2020-03-18 02:13:12 +00:00
ktls.c OpenSSL: KTLS: Check for unprocessed receive records in ktls_configure_crypto. 2022-05-04 13:08:03 -07:00
methods.c Merge OpenSSL 1.1.1e. 2020-03-18 02:13:12 +00:00
packet_local.h Merge OpenSSL 1.1.1e. 2020-03-18 02:13:12 +00:00
packet.c Merge OpenSSL 1.1.1e. 2020-03-18 02:13:12 +00:00
pqueue.c Merge OpenSSL 1.1.1e. 2020-03-18 02:13:12 +00:00
s3_cbc.c OpenSSL: Merge OpenSSL 1.1.1m 2021-12-14 16:03:52 -05:00
s3_enc.c OpenSSL: Merge OpenSSL 1.1.1o 2022-05-03 15:07:06 -04:00
s3_lib.c OpenSSL: Merge OpenSSL 1.1.1n 2022-03-15 19:37:45 -04:00
s3_msg.c Import OpenSSL 1.1.1l 2021-09-01 00:26:38 -04:00
ssl_asn1.c OpenSSL: Merge OpenSSL 1.1.1m 2021-12-14 16:03:52 -05:00
ssl_cert_table.h
ssl_cert.c OpenSSL: Merge OpenSSL 1.1.1n 2022-03-15 19:37:45 -04:00
ssl_ciph.c OpenSSL: Merge OpenSSL 1.1.1m 2021-12-14 16:03:52 -05:00
ssl_conf.c OpenSSL: Only enable KTLS if it is explicitly configured 2021-08-17 14:41:24 -07:00
ssl_err.c Import OpenSSL 1.1.1l 2021-09-01 00:26:38 -04:00
ssl_init.c OpenSSL: Merge OpenSSL 1.1.1o 2022-05-03 15:07:06 -04:00
ssl_lib.c OpenSSL: Merge OpenSSL 1.1.1o 2022-05-03 15:07:06 -04:00
ssl_local.h OpenSSL: KTLS: Check for unprocessed receive records in ktls_configure_crypto. 2022-05-04 13:08:03 -07:00
ssl_mcnf.c Merge OpenSSL 1.1.1e. 2020-03-18 02:13:12 +00:00
ssl_rsa.c Merge OpenSSL 1.1.1h. 2020-09-22 16:18:31 +00:00
ssl_sess.c Merge OpenSSL 1.1.1i. 2020-12-09 02:05:14 +00:00
ssl_stat.c Merge OpenSSL 1.1.1e. 2020-03-18 02:13:12 +00:00
ssl_txt.c OpenSSL: Merge OpenSSL 1.1.1o 2022-05-03 15:07:06 -04:00
ssl_utst.c Merge OpenSSL 1.1.1e. 2020-03-18 02:13:12 +00:00
t1_enc.c OpenSSL: KTLS: Check for unprocessed receive records in ktls_configure_crypto. 2022-05-04 13:08:03 -07:00
t1_lib.c Import OpenSSL 1.1.1l 2021-09-01 00:26:38 -04:00
t1_trce.c Merge OpenSSL 1.1.1h. 2020-09-22 16:18:31 +00:00
tls13_enc.c OpenSSL: KTLS: Check for unprocessed receive records in ktls_configure_crypto. 2022-05-04 13:08:03 -07:00
tls_srp.c Merge OpenSSL 1.1.1e. 2020-03-18 02:13:12 +00:00