From 72fb59c72186c327e047cd29d8a66a4a323b9f3b Mon Sep 17 00:00:00 2001 From: Boris Pismenny Date: Thu, 11 Apr 2019 16:24:42 +0300 Subject: [PATCH] Linux ktls sendfile This commit introduces support for Linux KTLS sendfile. Sendfile semantics require the use of a kernel TLS socket to construct the TLS record headers, encrypt and authenticate the data. KTLS sendfile improves performance by avoiding the copy of file data into user space, which is required today. Signed-off-by: Boris Pismenny Reviewed-by: Paul Dale Reviewed-by: Matt Caswell (Merged from https://github.com/openssl/openssl/pull/8727) --- include/internal/ktls.h | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/include/internal/ktls.h b/include/internal/ktls.h index d7bd1f3b66..9f2af1200c 100644 --- a/include/internal/ktls.h +++ b/include/internal/ktls.h @@ -73,8 +73,14 @@ static ossl_inline int ktls_read_record(int fd, void *data, size_t length) return -1; } +static ossl_inline ossl_ssize_t ktls_sendfile(int s, int fd, off_t off, size_t size, int flags) +{ + return -1; +} + # else /* KERNEL_VERSION */ +# include # include # include # include @@ -158,6 +164,15 @@ static ossl_inline int ktls_send_ctrl_message(int fd, unsigned char record_type, return sendmsg(fd, &msg, 0); } +/* + * KTLS enables the sendfile system call to send data from a file over TLS. + * @flags are ignored on Linux. (placeholder for FreeBSD sendfile) + * */ +static ossl_inline ossl_ssize_t ktls_sendfile(int s, int fd, off_t off, size_t size, int flags) +{ + return sendfile(s, fd, &off, size); +} + # define K_MIN1_RX 17 # if LINUX_VERSION_CODE < KERNEL_VERSION(K_MAJ, K_MIN1_RX, K_MIN2) -- 2.25.1