Re: [PATCH] crypto: keywrap - remove unused keywrap algorithm
From: Ard Biesheuvel
Date: Sun Dec 29 2024 - 02:54:42 EST
On Fri, 27 Dec 2024 at 23:09, Eric Biggers <ebiggers@xxxxxxxxxx> wrote:
>
> From: Eric Biggers <ebiggers@xxxxxxxxxx>
>
> The keywrap (kw) algorithm has no in-tree user. It has never had an
> in-tree user, and the patch that added it provided no justification for
> its inclusion. Even use of it via AF_ALG is impossible, as it uses a
> weird calling convention where part of the ciphertext is returned via
> the IV buffer, which is not returned to userspace in AF_ALG.
>
> It's also unclear whether any new code in the kernel that does key
> wrapping would actually use this algorithm. It is controversial in the
> cryptographic community due to having no clearly stated security goal,
> no security proof, poor performance, and only a 64-bit auth tag. Later
> work (https://eprint.iacr.org/2006/221) suggested that the goal is
> deterministic authenticated encryption. But there are now more modern
> algorithms for this, and this is not the same as key wrapping, for which
> a regular AEAD such as AES-GCM usually can be (and is) used instead.
>
> Therefore, remove this unused code.
>
> There were several special cases for this algorithm in the self-tests,
> due to its weird calling convention. Remove those too.
>
> Cc: Stephan Mueller <smueller@xxxxxxxxxx>
> Signed-off-by: Eric Biggers <ebiggers@xxxxxxxxxx>
Acked-by: Ard Biesheuvel <ardb@xxxxxxxxxx>
> ---
> arch/m68k/configs/amiga_defconfig | 1 -
> arch/m68k/configs/apollo_defconfig | 1 -
> arch/m68k/configs/atari_defconfig | 1 -
> arch/m68k/configs/bvme6000_defconfig | 1 -
> arch/m68k/configs/hp300_defconfig | 1 -
> arch/m68k/configs/mac_defconfig | 1 -
> arch/m68k/configs/multi_defconfig | 1 -
> arch/m68k/configs/mvme147_defconfig | 1 -
> arch/m68k/configs/mvme16x_defconfig | 1 -
> arch/m68k/configs/q40_defconfig | 1 -
> arch/m68k/configs/sun3_defconfig | 1 -
> arch/m68k/configs/sun3x_defconfig | 1 -
> arch/mips/configs/decstation_64_defconfig | 1 -
> arch/mips/configs/decstation_defconfig | 1 -
> arch/mips/configs/decstation_r4k_defconfig | 1 -
> arch/s390/configs/debug_defconfig | 1 -
> arch/s390/configs/defconfig | 1 -
> crypto/Kconfig | 8 -
> crypto/Makefile | 1 -
> crypto/keywrap.c | 319 ---------------------
> crypto/testmgr.c | 20 +-
> crypto/testmgr.h | 39 ---
> 22 files changed, 1 insertion(+), 403 deletions(-)
> delete mode 100644 crypto/keywrap.c
>
> diff --git a/arch/m68k/configs/amiga_defconfig b/arch/m68k/configs/amiga_defconfig
> index c705247e7b5b..d74581facb49 100644
> --- a/arch/m68k/configs/amiga_defconfig
> +++ b/arch/m68k/configs/amiga_defconfig
> @@ -577,11 +577,10 @@ CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> diff --git a/arch/m68k/configs/apollo_defconfig b/arch/m68k/configs/apollo_defconfig
> index 6d62b9187a58..e3442fd188b6 100644
> --- a/arch/m68k/configs/apollo_defconfig
> +++ b/arch/m68k/configs/apollo_defconfig
> @@ -534,11 +534,10 @@ CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> diff --git a/arch/m68k/configs/atari_defconfig b/arch/m68k/configs/atari_defconfig
> index c3c644df852d..a9c41344a33b 100644
> --- a/arch/m68k/configs/atari_defconfig
> +++ b/arch/m68k/configs/atari_defconfig
> @@ -554,11 +554,10 @@ CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> diff --git a/arch/m68k/configs/bvme6000_defconfig b/arch/m68k/configs/bvme6000_defconfig
> index 20261f819691..9b299152958c 100644
> --- a/arch/m68k/configs/bvme6000_defconfig
> +++ b/arch/m68k/configs/bvme6000_defconfig
> @@ -526,11 +526,10 @@ CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> diff --git a/arch/m68k/configs/hp300_defconfig b/arch/m68k/configs/hp300_defconfig
> index ce4fe93a0f70..851a564fcd7c 100644
> --- a/arch/m68k/configs/hp300_defconfig
> +++ b/arch/m68k/configs/hp300_defconfig
> @@ -536,11 +536,10 @@ CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> diff --git a/arch/m68k/configs/mac_defconfig b/arch/m68k/configs/mac_defconfig
> index 040ae75f47c3..7773ce50673e 100644
> --- a/arch/m68k/configs/mac_defconfig
> +++ b/arch/m68k/configs/mac_defconfig
> @@ -553,11 +553,10 @@ CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> diff --git a/arch/m68k/configs/multi_defconfig b/arch/m68k/configs/multi_defconfig
> index 20d877cb4e30..16039dcb0fca 100644
> --- a/arch/m68k/configs/multi_defconfig
> +++ b/arch/m68k/configs/multi_defconfig
> @@ -640,11 +640,10 @@ CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> diff --git a/arch/m68k/configs/mvme147_defconfig b/arch/m68k/configs/mvme147_defconfig
> index 5e1c8d0d3da5..396e261719ff 100644
> --- a/arch/m68k/configs/mvme147_defconfig
> +++ b/arch/m68k/configs/mvme147_defconfig
> @@ -526,11 +526,10 @@ CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> diff --git a/arch/m68k/configs/mvme16x_defconfig b/arch/m68k/configs/mvme16x_defconfig
> index 5d1409e6a137..30c189ccd89c 100644
> --- a/arch/m68k/configs/mvme16x_defconfig
> +++ b/arch/m68k/configs/mvme16x_defconfig
> @@ -527,11 +527,10 @@ CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> diff --git a/arch/m68k/configs/q40_defconfig b/arch/m68k/configs/q40_defconfig
> index e4c30e2b9bbb..09d6bc21edfb 100644
> --- a/arch/m68k/configs/q40_defconfig
> +++ b/arch/m68k/configs/q40_defconfig
> @@ -543,11 +543,10 @@ CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> diff --git a/arch/m68k/configs/sun3_defconfig b/arch/m68k/configs/sun3_defconfig
> index 980843a9ea1e..641bae8492e7 100644
> --- a/arch/m68k/configs/sun3_defconfig
> +++ b/arch/m68k/configs/sun3_defconfig
> @@ -524,11 +524,10 @@ CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> diff --git a/arch/m68k/configs/sun3x_defconfig b/arch/m68k/configs/sun3x_defconfig
> index 38681cc6b598..5b9ac77c0df1 100644
> --- a/arch/m68k/configs/sun3x_defconfig
> +++ b/arch/m68k/configs/sun3x_defconfig
> @@ -524,11 +524,10 @@ CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> diff --git a/arch/mips/configs/decstation_64_defconfig b/arch/mips/configs/decstation_64_defconfig
> index 92a1d0aea38c..5d1e0f36c7cd 100644
> --- a/arch/mips/configs/decstation_64_defconfig
> +++ b/arch/mips/configs/decstation_64_defconfig
> @@ -175,11 +175,10 @@ CONFIG_CRYPTO_CHACHA20POLY1305=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_OFB=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_CMAC=m
> CONFIG_CRYPTO_XCBC=m
> CONFIG_CRYPTO_VMAC=m
> CONFIG_CRYPTO_CRC32=m
> CONFIG_CRYPTO_CRCT10DIF=m
> diff --git a/arch/mips/configs/decstation_defconfig b/arch/mips/configs/decstation_defconfig
> index db214fcebcbe..53699c0e3883 100644
> --- a/arch/mips/configs/decstation_defconfig
> +++ b/arch/mips/configs/decstation_defconfig
> @@ -170,11 +170,10 @@ CONFIG_CRYPTO_CHACHA20POLY1305=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_OFB=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_CMAC=m
> CONFIG_CRYPTO_XCBC=m
> CONFIG_CRYPTO_VMAC=m
> CONFIG_CRYPTO_CRC32=m
> CONFIG_CRYPTO_CRCT10DIF=m
> diff --git a/arch/mips/configs/decstation_r4k_defconfig b/arch/mips/configs/decstation_r4k_defconfig
> index 15b769e96d5b..ce8d9545659c 100644
> --- a/arch/mips/configs/decstation_r4k_defconfig
> +++ b/arch/mips/configs/decstation_r4k_defconfig
> @@ -170,11 +170,10 @@ CONFIG_CRYPTO_CHACHA20POLY1305=m
> CONFIG_CRYPTO_CTS=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_OFB=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_XTS=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_CMAC=m
> CONFIG_CRYPTO_XCBC=m
> CONFIG_CRYPTO_VMAC=m
> CONFIG_CRYPTO_CRC32=m
> CONFIG_CRYPTO_CRCT10DIF=m
> diff --git a/arch/s390/configs/debug_defconfig b/arch/s390/configs/debug_defconfig
> index d8d227ab82de..174a31962d4f 100644
> --- a/arch/s390/configs/debug_defconfig
> +++ b/arch/s390/configs/debug_defconfig
> @@ -768,11 +768,10 @@ CONFIG_CRYPTO_SM4_GENERIC=m
> CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> CONFIG_CRYPTO_GCM=y
> diff --git a/arch/s390/configs/defconfig b/arch/s390/configs/defconfig
> index 6c2f2bb4fbf8..d304d3b723b0 100644
> --- a/arch/s390/configs/defconfig
> +++ b/arch/s390/configs/defconfig
> @@ -754,11 +754,10 @@ CONFIG_CRYPTO_SM4_GENERIC=m
> CONFIG_CRYPTO_TEA=m
> CONFIG_CRYPTO_TWOFISH=m
> CONFIG_CRYPTO_ADIANTUM=m
> CONFIG_CRYPTO_ARC4=m
> CONFIG_CRYPTO_HCTR2=m
> -CONFIG_CRYPTO_KEYWRAP=m
> CONFIG_CRYPTO_LRW=m
> CONFIG_CRYPTO_PCBC=m
> CONFIG_CRYPTO_AEGIS128=m
> CONFIG_CRYPTO_CHACHA20POLY1305=m
> CONFIG_CRYPTO_GCM=y
> diff --git a/crypto/Kconfig b/crypto/Kconfig
> index 6b0bfbccac08..b686f0fe4078 100644
> --- a/crypto/Kconfig
> +++ b/crypto/Kconfig
> @@ -682,18 +682,10 @@ config CRYPTO_HCTR2
> x86 processors with AES-NI and CLMUL, and ARM processors with the
> ARMv8 crypto extensions.
>
> See https://eprint.iacr.org/2021/1441
>
> -config CRYPTO_KEYWRAP
> - tristate "KW (AES Key Wrap)"
> - select CRYPTO_SKCIPHER
> - select CRYPTO_MANAGER
> - help
> - KW (AES Key Wrap) authenticated encryption mode (NIST SP800-38F
> - and RFC3394) without padding.
> -
> config CRYPTO_LRW
> tristate "LRW (Liskov Rivest Wagner)"
> select CRYPTO_LIB_GF128MUL
> select CRYPTO_SKCIPHER
> select CRYPTO_MANAGER
> diff --git a/crypto/Makefile b/crypto/Makefile
> index 77abca715445..e1a27358265c 100644
> --- a/crypto/Makefile
> +++ b/crypto/Makefile
> @@ -93,11 +93,10 @@ obj-$(CONFIG_CRYPTO_CTS) += cts.o
> obj-$(CONFIG_CRYPTO_LRW) += lrw.o
> obj-$(CONFIG_CRYPTO_XTS) += xts.o
> obj-$(CONFIG_CRYPTO_CTR) += ctr.o
> obj-$(CONFIG_CRYPTO_XCTR) += xctr.o
> obj-$(CONFIG_CRYPTO_HCTR2) += hctr2.o
> -obj-$(CONFIG_CRYPTO_KEYWRAP) += keywrap.o
> obj-$(CONFIG_CRYPTO_ADIANTUM) += adiantum.o
> obj-$(CONFIG_CRYPTO_NHPOLY1305) += nhpoly1305.o
> obj-$(CONFIG_CRYPTO_GCM) += gcm.o
> obj-$(CONFIG_CRYPTO_CCM) += ccm.o
> obj-$(CONFIG_CRYPTO_CHACHA20POLY1305) += chacha20poly1305.o
> diff --git a/crypto/keywrap.c b/crypto/keywrap.c
> deleted file mode 100644
> index 5ec4f94d46bd..000000000000
> --- a/crypto/keywrap.c
> +++ /dev/null
> @@ -1,319 +0,0 @@
> -/*
> - * Key Wrapping: RFC3394 / NIST SP800-38F
> - *
> - * Copyright (C) 2015, Stephan Mueller <smueller@xxxxxxxxxx>
> - *
> - * Redistribution and use in source and binary forms, with or without
> - * modification, are permitted provided that the following conditions
> - * are met:
> - * 1. Redistributions of source code must retain the above copyright
> - * notice, and the entire permission notice in its entirety,
> - * including the disclaimer of warranties.
> - * 2. Redistributions in binary form must reproduce the above copyright
> - * notice, this list of conditions and the following disclaimer in the
> - * documentation and/or other materials provided with the distribution.
> - * 3. The name of the author may not be used to endorse or promote
> - * products derived from this software without specific prior
> - * written permission.
> - *
> - * ALTERNATIVELY, this product may be distributed under the terms of
> - * the GNU General Public License, in which case the provisions of the GPL2
> - * are required INSTEAD OF the above restrictions. (This clause is
> - * necessary due to a potential bad interaction between the GPL and
> - * the restrictions contained in a BSD-style copyright.)
> - *
> - * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
> - * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
> - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ALL OF
> - * WHICH ARE HEREBY DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
> - * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
> - * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
> - * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
> - * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
> - * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
> - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
> - * USE OF THIS SOFTWARE, EVEN IF NOT ADVISED OF THE POSSIBILITY OF SUCH
> - * DAMAGE.
> - */
> -
> -/*
> - * Note for using key wrapping:
> - *
> - * * The result of the encryption operation is the ciphertext starting
> - * with the 2nd semiblock. The first semiblock is provided as the IV.
> - * The IV used to start the encryption operation is the default IV.
> - *
> - * * The input for the decryption is the first semiblock handed in as an
> - * IV. The ciphertext is the data starting with the 2nd semiblock. The
> - * return code of the decryption operation will be EBADMSG in case an
> - * integrity error occurs.
> - *
> - * To obtain the full result of an encryption as expected by SP800-38F, the
> - * caller must allocate a buffer of plaintext + 8 bytes:
> - *
> - * unsigned int datalen = ptlen + crypto_skcipher_ivsize(tfm);
> - * u8 data[datalen];
> - * u8 *iv = data;
> - * u8 *pt = data + crypto_skcipher_ivsize(tfm);
> - * <ensure that pt contains the plaintext of size ptlen>
> - * sg_init_one(&sg, pt, ptlen);
> - * skcipher_request_set_crypt(req, &sg, &sg, ptlen, iv);
> - *
> - * ==> After encryption, data now contains full KW result as per SP800-38F.
> - *
> - * In case of decryption, ciphertext now already has the expected length
> - * and must be segmented appropriately:
> - *
> - * unsigned int datalen = CTLEN;
> - * u8 data[datalen];
> - * <ensure that data contains full ciphertext>
> - * u8 *iv = data;
> - * u8 *ct = data + crypto_skcipher_ivsize(tfm);
> - * unsigned int ctlen = datalen - crypto_skcipher_ivsize(tfm);
> - * sg_init_one(&sg, ct, ctlen);
> - * skcipher_request_set_crypt(req, &sg, &sg, ctlen, iv);
> - *
> - * ==> After decryption (which hopefully does not return EBADMSG), the ct
> - * pointer now points to the plaintext of size ctlen.
> - *
> - * Note 2: KWP is not implemented as this would defy in-place operation.
> - * If somebody wants to wrap non-aligned data, he should simply pad
> - * the input with zeros to fill it up to the 8 byte boundary.
> - */
> -
> -#include <linux/module.h>
> -#include <linux/crypto.h>
> -#include <linux/scatterlist.h>
> -#include <crypto/scatterwalk.h>
> -#include <crypto/internal/cipher.h>
> -#include <crypto/internal/skcipher.h>
> -
> -struct crypto_kw_block {
> -#define SEMIBSIZE 8
> - __be64 A;
> - __be64 R;
> -};
> -
> -/*
> - * Fast forward the SGL to the "end" length minus SEMIBSIZE.
> - * The start in the SGL defined by the fast-forward is returned with
> - * the walk variable
> - */
> -static void crypto_kw_scatterlist_ff(struct scatter_walk *walk,
> - struct scatterlist *sg,
> - unsigned int end)
> -{
> - unsigned int skip = 0;
> -
> - /* The caller should only operate on full SEMIBLOCKs. */
> - BUG_ON(end < SEMIBSIZE);
> -
> - skip = end - SEMIBSIZE;
> - while (sg) {
> - if (sg->length > skip) {
> - scatterwalk_start(walk, sg);
> - scatterwalk_advance(walk, skip);
> - break;
> - }
> -
> - skip -= sg->length;
> - sg = sg_next(sg);
> - }
> -}
> -
> -static int crypto_kw_decrypt(struct skcipher_request *req)
> -{
> - struct crypto_skcipher *tfm = crypto_skcipher_reqtfm(req);
> - struct crypto_cipher *cipher = skcipher_cipher_simple(tfm);
> - struct crypto_kw_block block;
> - struct scatterlist *src, *dst;
> - u64 t = 6 * ((req->cryptlen) >> 3);
> - unsigned int i;
> - int ret = 0;
> -
> - /*
> - * Require at least 2 semiblocks (note, the 3rd semiblock that is
> - * required by SP800-38F is the IV.
> - */
> - if (req->cryptlen < (2 * SEMIBSIZE) || req->cryptlen % SEMIBSIZE)
> - return -EINVAL;
> -
> - /* Place the IV into block A */
> - memcpy(&block.A, req->iv, SEMIBSIZE);
> -
> - /*
> - * src scatterlist is read-only. dst scatterlist is r/w. During the
> - * first loop, src points to req->src and dst to req->dst. For any
> - * subsequent round, the code operates on req->dst only.
> - */
> - src = req->src;
> - dst = req->dst;
> -
> - for (i = 0; i < 6; i++) {
> - struct scatter_walk src_walk, dst_walk;
> - unsigned int nbytes = req->cryptlen;
> -
> - while (nbytes) {
> - /* move pointer by nbytes in the SGL */
> - crypto_kw_scatterlist_ff(&src_walk, src, nbytes);
> - /* get the source block */
> - scatterwalk_copychunks(&block.R, &src_walk, SEMIBSIZE,
> - false);
> -
> - /* perform KW operation: modify IV with counter */
> - block.A ^= cpu_to_be64(t);
> - t--;
> - /* perform KW operation: decrypt block */
> - crypto_cipher_decrypt_one(cipher, (u8 *)&block,
> - (u8 *)&block);
> -
> - /* move pointer by nbytes in the SGL */
> - crypto_kw_scatterlist_ff(&dst_walk, dst, nbytes);
> - /* Copy block->R into place */
> - scatterwalk_copychunks(&block.R, &dst_walk, SEMIBSIZE,
> - true);
> -
> - nbytes -= SEMIBSIZE;
> - }
> -
> - /* we now start to operate on the dst SGL only */
> - src = req->dst;
> - dst = req->dst;
> - }
> -
> - /* Perform authentication check */
> - if (block.A != cpu_to_be64(0xa6a6a6a6a6a6a6a6ULL))
> - ret = -EBADMSG;
> -
> - memzero_explicit(&block, sizeof(struct crypto_kw_block));
> -
> - return ret;
> -}
> -
> -static int crypto_kw_encrypt(struct skcipher_request *req)
> -{
> - struct crypto_skcipher *tfm = crypto_skcipher_reqtfm(req);
> - struct crypto_cipher *cipher = skcipher_cipher_simple(tfm);
> - struct crypto_kw_block block;
> - struct scatterlist *src, *dst;
> - u64 t = 1;
> - unsigned int i;
> -
> - /*
> - * Require at least 2 semiblocks (note, the 3rd semiblock that is
> - * required by SP800-38F is the IV that occupies the first semiblock.
> - * This means that the dst memory must be one semiblock larger than src.
> - * Also ensure that the given data is aligned to semiblock.
> - */
> - if (req->cryptlen < (2 * SEMIBSIZE) || req->cryptlen % SEMIBSIZE)
> - return -EINVAL;
> -
> - /*
> - * Place the predefined IV into block A -- for encrypt, the caller
> - * does not need to provide an IV, but he needs to fetch the final IV.
> - */
> - block.A = cpu_to_be64(0xa6a6a6a6a6a6a6a6ULL);
> -
> - /*
> - * src scatterlist is read-only. dst scatterlist is r/w. During the
> - * first loop, src points to req->src and dst to req->dst. For any
> - * subsequent round, the code operates on req->dst only.
> - */
> - src = req->src;
> - dst = req->dst;
> -
> - for (i = 0; i < 6; i++) {
> - struct scatter_walk src_walk, dst_walk;
> - unsigned int nbytes = req->cryptlen;
> -
> - scatterwalk_start(&src_walk, src);
> - scatterwalk_start(&dst_walk, dst);
> -
> - while (nbytes) {
> - /* get the source block */
> - scatterwalk_copychunks(&block.R, &src_walk, SEMIBSIZE,
> - false);
> -
> - /* perform KW operation: encrypt block */
> - crypto_cipher_encrypt_one(cipher, (u8 *)&block,
> - (u8 *)&block);
> - /* perform KW operation: modify IV with counter */
> - block.A ^= cpu_to_be64(t);
> - t++;
> -
> - /* Copy block->R into place */
> - scatterwalk_copychunks(&block.R, &dst_walk, SEMIBSIZE,
> - true);
> -
> - nbytes -= SEMIBSIZE;
> - }
> -
> - /* we now start to operate on the dst SGL only */
> - src = req->dst;
> - dst = req->dst;
> - }
> -
> - /* establish the IV for the caller to pick up */
> - memcpy(req->iv, &block.A, SEMIBSIZE);
> -
> - memzero_explicit(&block, sizeof(struct crypto_kw_block));
> -
> - return 0;
> -}
> -
> -static int crypto_kw_create(struct crypto_template *tmpl, struct rtattr **tb)
> -{
> - struct skcipher_instance *inst;
> - struct crypto_alg *alg;
> - int err;
> -
> - inst = skcipher_alloc_instance_simple(tmpl, tb);
> - if (IS_ERR(inst))
> - return PTR_ERR(inst);
> -
> - alg = skcipher_ialg_simple(inst);
> -
> - err = -EINVAL;
> - /* Section 5.1 requirement for KW */
> - if (alg->cra_blocksize != sizeof(struct crypto_kw_block))
> - goto out_free_inst;
> -
> - inst->alg.base.cra_blocksize = SEMIBSIZE;
> - inst->alg.ivsize = SEMIBSIZE;
> -
> - inst->alg.encrypt = crypto_kw_encrypt;
> - inst->alg.decrypt = crypto_kw_decrypt;
> -
> - err = skcipher_register_instance(tmpl, inst);
> - if (err) {
> -out_free_inst:
> - inst->free(inst);
> - }
> -
> - return err;
> -}
> -
> -static struct crypto_template crypto_kw_tmpl = {
> - .name = "kw",
> - .create = crypto_kw_create,
> - .module = THIS_MODULE,
> -};
> -
> -static int __init crypto_kw_init(void)
> -{
> - return crypto_register_template(&crypto_kw_tmpl);
> -}
> -
> -static void __exit crypto_kw_exit(void)
> -{
> - crypto_unregister_template(&crypto_kw_tmpl);
> -}
> -
> -subsys_initcall(crypto_kw_init);
> -module_exit(crypto_kw_exit);
> -
> -MODULE_LICENSE("Dual BSD/GPL");
> -MODULE_AUTHOR("Stephan Mueller <smueller@xxxxxxxxxx>");
> -MODULE_DESCRIPTION("Key Wrapping (RFC3394 / NIST SP800-38F)");
> -MODULE_ALIAS_CRYPTO("kw");
> -MODULE_IMPORT_NS("CRYPTO_INTERNAL");
> diff --git a/crypto/testmgr.c b/crypto/testmgr.c
> index 1f5f48ab18c7..02088fbeb526 100644
> --- a/crypto/testmgr.c
> +++ b/crypto/testmgr.c
> @@ -2883,22 +2883,15 @@ static int test_skcipher_vec_cfg(int enc, const struct cipher_testvec *vec,
>
> /* The IV must be copied to a buffer, as the algorithm may modify it */
> if (ivsize) {
> if (WARN_ON(ivsize > MAX_IVLEN))
> return -EINVAL;
> - if (vec->generates_iv && !enc)
> - memcpy(iv, vec->iv_out, ivsize);
> - else if (vec->iv)
> + if (vec->iv)
> memcpy(iv, vec->iv, ivsize);
> else
> memset(iv, 0, ivsize);
> } else {
> - if (vec->generates_iv) {
> - pr_err("alg: skcipher: %s has ivsize=0 but test vector %s generates IV!\n",
> - driver, vec_name);
> - return -EINVAL;
> - }
> iv = NULL;
> }
>
> /* Build the src/dst scatterlists */
> input.iov_base = enc ? (void *)vec->ptext : (void *)vec->ctext;
> @@ -3131,14 +3124,10 @@ static int test_skcipher_vs_generic_impl(const char *generic_driver,
> int err;
>
> if (noextratests)
> return 0;
>
> - /* Keywrap isn't supported here yet as it handles its IV differently. */
> - if (strncmp(algname, "kw(", 3) == 0)
> - return 0;
> -
> init_rnd_state(&rng);
>
> if (!generic_driver) { /* Use default naming convention? */
> err = build_generic_driver_name(algname, _generic_driver);
> if (err)
> @@ -5406,17 +5395,10 @@ static const struct alg_test_desc alg_test_descs[] = {
> }
> }, {
> .alg = "jitterentropy_rng",
> .fips_allowed = 1,
> .test = alg_test_null,
> - }, {
> - .alg = "kw(aes)",
> - .test = alg_test_skcipher,
> - .fips_allowed = 1,
> - .suite = {
> - .cipher = __VECS(aes_kw_tv_template)
> - }
> }, {
> .alg = "lrw(aes)",
> .generic_driver = "lrw(ecb(aes-generic))",
> .test = alg_test_skcipher,
> .suite = {
> diff --git a/crypto/testmgr.h b/crypto/testmgr.h
> index 430d33d9ac13..4e279597033e 100644
> --- a/crypto/testmgr.h
> +++ b/crypto/testmgr.h
> @@ -57,12 +57,10 @@ struct hash_testvec {
> * @ctext: Pointer to ciphertext
> * @len: Length of @ptext and @ctext in bytes
> * @wk: Does the test need CRYPTO_TFM_REQ_FORBID_WEAK_KEYS?
> * ( e.g. test needs to fail due to a weak key )
> * @fips_skip: Skip the test vector in FIPS mode
> - * @generates_iv: Encryption should ignore the given IV, and output @iv_out.
> - * Decryption takes @iv_out. Needed for AES Keywrap ("kw(aes)").
> * @setkey_error: Expected error from setkey()
> * @crypt_error: Expected error from encrypt() and decrypt()
> */
> struct cipher_testvec {
> const char *key;
> @@ -72,11 +70,10 @@ struct cipher_testvec {
> const char *ctext;
> unsigned char wk; /* weak key flag */
> unsigned short klen;
> unsigned int len;
> bool fips_skip;
> - bool generates_iv;
> int setkey_error;
> int crypt_error;
> };
>
> /*
> @@ -24346,46 +24343,10 @@ static const struct aead_testvec aegis128_tv_template[] = {
> "\x78\x93\xec\xfc\xf4\xff\xe1\x2d",
> .clen = 24,
> },
> };
>
> -/*
> - * All key wrapping test vectors taken from
> - * http://csrc.nist.gov/groups/STM/cavp/documents/mac/kwtestvectors.zip
> - *
> - * Note: as documented in keywrap.c, the ivout for encryption is the first
> - * semiblock of the ciphertext from the test vector. For decryption, iv is
> - * the first semiblock of the ciphertext.
> - */
> -static const struct cipher_testvec aes_kw_tv_template[] = {
> - {
> - .key = "\x75\x75\xda\x3a\x93\x60\x7c\xc2"
> - "\xbf\xd8\xce\xc7\xaa\xdf\xd9\xa6",
> - .klen = 16,
> - .ptext = "\x42\x13\x6d\x3c\x38\x4a\x3e\xea"
> - "\xc9\x5a\x06\x6f\xd2\x8f\xed\x3f",
> - .ctext = "\xf6\x85\x94\x81\x6f\x64\xca\xa3"
> - "\xf5\x6f\xab\xea\x25\x48\xf5\xfb",
> - .len = 16,
> - .iv_out = "\x03\x1f\x6b\xd7\xe6\x1e\x64\x3d",
> - .generates_iv = true,
> - }, {
> - .key = "\x80\xaa\x99\x73\x27\xa4\x80\x6b"
> - "\x6a\x7a\x41\xa5\x2b\x86\xc3\x71"
> - "\x03\x86\xf9\x32\x78\x6e\xf7\x96"
> - "\x76\xfa\xfb\x90\xb8\x26\x3c\x5f",
> - .klen = 32,
> - .ptext = "\x0a\x25\x6b\xa7\x5c\xfa\x03\xaa"
> - "\xa0\x2b\xa9\x42\x03\xf1\x5b\xaa",
> - .ctext = "\xd3\x3d\x3d\x97\x7b\xf0\xa9\x15"
> - "\x59\xf9\x9c\x8a\xcd\x29\x3d\x43",
> - .len = 16,
> - .iv_out = "\x42\x3c\x96\x0d\x8a\x2a\xc4\xc1",
> - .generates_iv = true,
> - },
> -};
> -
> /*
> * ANSI X9.31 Continuous Pseudo-Random Number Generator (AES mode)
> * test vectors, taken from Appendix B.2.9 and B.2.10:
> * http://csrc.nist.gov/groups/STM/cavp/documents/rng/RNGVS.pdf
> * Only AES-128 is supported at this time.
>
> base-commit: 7b6092ee7a4ce2d03dc65b87537889e8e1e0ab95
> --
> 2.47.1
>
>