]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
crypto: fcrypt - Remove support for FCrypt block cipher
authorEric Biggers <ebiggers@kernel.org>
Fri, 22 May 2026 05:07:35 +0000 (00:07 -0500)
committerJakub Kicinski <kuba@kernel.org>
Wed, 10 Jun 2026 00:03:03 +0000 (17:03 -0700)
Remove the insecure FCrypt block cipher from the crypto API.  Its only
user was net/rxrpc/, but now net/rxrpc/ implements it locally.  The
crypto API implementation is no longer needed.

For some additional context: FCrypt was designed in 1988 and is
essentially a weakened version of DES.  It has the same 56-bit key size
as DES, which is easily brute forced.  Moreover, it's cryptographically
weak and doesn't even provide the intended 56-bit security level.  Its
author considers it to be a mistake, as well
(https://lists.openafs.org/pipermail/openafs-devel/2000-December/005320.html).

But fortunately this 1980s-era homebrew block cipher was never adopted
outside of net/rxrpc/.  So its code can just be kept there.

Acked-by: Geert Uytterhoeven <geert@linux-m68k.org> # m68k
Acked-by: David Howells <dhowells@redhat.com>
Signed-off-by: Eric Biggers <ebiggers@kernel.org>
Tested-by: Marc Dionne <marc.dionne@auristor.com>
Link: https://patch.msgid.link/20260522050740.84561-5-ebiggers@kernel.org
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
39 files changed:
arch/arm/configs/pxa_defconfig
arch/m68k/configs/amiga_defconfig
arch/m68k/configs/apollo_defconfig
arch/m68k/configs/atari_defconfig
arch/m68k/configs/bvme6000_defconfig
arch/m68k/configs/hp300_defconfig
arch/m68k/configs/mac_defconfig
arch/m68k/configs/multi_defconfig
arch/m68k/configs/mvme147_defconfig
arch/m68k/configs/mvme16x_defconfig
arch/m68k/configs/q40_defconfig
arch/m68k/configs/sun3_defconfig
arch/m68k/configs/sun3x_defconfig
arch/mips/configs/bigsur_defconfig
arch/mips/configs/decstation_64_defconfig
arch/mips/configs/decstation_defconfig
arch/mips/configs/decstation_r4k_defconfig
arch/mips/configs/ip22_defconfig
arch/mips/configs/ip27_defconfig
arch/mips/configs/ip30_defconfig
arch/mips/configs/ip32_defconfig
arch/mips/configs/lemote2f_defconfig
arch/mips/configs/malta_defconfig
arch/mips/configs/malta_kvm_defconfig
arch/mips/configs/maltaup_xpa_defconfig
arch/mips/configs/rm200_defconfig
arch/mips/configs/sb1250_swarm_defconfig
arch/parisc/configs/generic-64bit_defconfig
arch/powerpc/configs/ppc6xx_defconfig
arch/s390/configs/debug_defconfig
arch/s390/configs/defconfig
arch/sh/configs/sh2007_defconfig
arch/sparc/configs/sparc64_defconfig
crypto/Kconfig
crypto/Makefile
crypto/fcrypt.c [deleted file]
crypto/tcrypt.c
crypto/testmgr.c
crypto/testmgr.h

index c51ae373ca888d510a4589d04533dfba13c4b6c0..53f1e5820c49f68ddcde6951d3538ad6fde278f2 100644 (file)
@@ -640,7 +640,6 @@ CONFIG_CRYPTO_BENCHMARK=m
 CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index 47e48c18e55c7d5d764927de57d5b2a3103d53ae..ca45670a6af4b250698f1b353dd9e859c66a5539 100644 (file)
@@ -524,7 +524,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index 161586d611ab0f4ad1021d3b809aa5d3b5695bb1..2732a5b8b694c087a1ead78778d8b2a68ca7f338 100644 (file)
@@ -479,7 +479,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index c13c6deeac2243b2deb3319393070c6b63e147a6..242882b05fa484de154aecd5323309262c43fdaf 100644 (file)
@@ -501,7 +501,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index d4f3f94b61ff34d4e2c9acd949276a0465e86507..07e73c78a9e2b7d17d59bb41375513ee65a7a7fe 100644 (file)
@@ -471,7 +471,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index 58288f83349d25d1b1bb4f58cee0ad20f0861f07..7188948da864109f003b87288dacebe61e3f63c6 100644 (file)
@@ -481,7 +481,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index abb369fd1f556302ae972d1acde4d64815c24b55..fa5b04d59aa6f35fd372e264ab3e20b9acf56478 100644 (file)
@@ -500,7 +500,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index cb8de979700fd564592fde3a854a48b46386e779..3bc9911549c0e57bb9507a7d915d4013810b4e57 100644 (file)
@@ -587,7 +587,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index 176540bd5074119bfcebb629653cf04eec3d464b..9f5c8e0a07f39b7c170b7fc4259127cab7873848 100644 (file)
@@ -471,7 +471,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index 8b2e5cf4d2f21d84499e3b11a702e340f713eb5f..e5a6299aeae07b61a8603bd72973afb0937f145d 100644 (file)
@@ -472,7 +472,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index d48f3cf5285bc0cc9ad53c017e533535183f7f37..e79bbb397261a266ded8964c41593ab99713acf6 100644 (file)
@@ -490,7 +490,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index 0b96428f25d4029c1d94f29c313ee6d5490567a1..7aa76de5c472f0b7cd07b08ee0881bb477cef96d 100644 (file)
@@ -469,7 +469,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index 6140e18244a169734e61ca8e59207aad9a0ec3e4..2ecd8bd097ea095221020d2efd05bdb2f54c26cc 100644 (file)
@@ -469,7 +469,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index aa63ada62e2895ae7fd7a8902d103e11efd9e15b..74c6821e4c371618c2addb9ada02e6489378ee40 100644 (file)
@@ -219,7 +219,6 @@ CONFIG_CRYPTO_ANUBIS=m
 CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index 7c43352fac6bd23bd00f7e69b8309677b0eb3e1f..e98d218ed4c1f61c50946f1e9da8563baa787262 100644 (file)
@@ -189,7 +189,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index aee10274f0488aaa1859e56ef0604109608312af..2b4e06cc238bd130f818c1f6ed5c55e2066e9b78 100644 (file)
@@ -184,7 +184,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index a1698049aa7a7123133a1fef572d06c9cd50570c..280553269156fea0354c628a6e42987d7af26f75 100644 (file)
@@ -184,7 +184,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index e123848f94abd98bbf5f5b10060712d29106ec02..50895ed065924249bd593099e43e49523817c84d 100644 (file)
@@ -317,7 +317,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index fea0ccee6948f20a26da21248a3e396cdefaa4de..ff7e06b92f58a0288480d9081a65ab359cea2533 100644 (file)
@@ -309,7 +309,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index 718f3060d9fa8835bacf9dbc53033774a27eb1c8..d9f748f8cfaab7e755e28b588bda0cd887686492 100644 (file)
@@ -166,7 +166,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_SERPENT=m
 CONFIG_CRYPTO_TWOFISH=m
 CONFIG_CRYPTO_CTS=m
index 9020c309dcda2fd26aa81442c02e8af3c18b4b44..4b15f895be63f51b61872331f3014b8889607122 100644 (file)
@@ -169,7 +169,6 @@ CONFIG_CRYPTO_CAMELLIA=y
 CONFIG_CRYPTO_CAST5=y
 CONFIG_CRYPTO_CAST6=y
 CONFIG_CRYPTO_DES=y
-CONFIG_CRYPTO_FCRYPT=y
 CONFIG_CRYPTO_KHAZAD=y
 CONFIG_CRYPTO_SERPENT=y
 CONFIG_CRYPTO_TEA=y
index b9f3e16411053123f974b3e1b48bff182ad27832..bbcdfc8134cb10f61945951188ef578837dbe6f3 100644 (file)
@@ -301,7 +301,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_SERPENT=m
 CONFIG_CRYPTO_TWOFISH=m
 CONFIG_CRYPTO_LRW=m
index 81704ec67f09ca00b4f4b3f98e8917b977c63221..85e7816072997cc6df6d19ecde09a731f2b460ff 100644 (file)
@@ -399,7 +399,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SERPENT=m
 CONFIG_CRYPTO_TEA=m
index 82a97f58bce1a3d0debe0ce8487dc20b7e50b0c8..2db5f50fed3b77808f9a7e432c7b2c67341078c9 100644 (file)
@@ -406,7 +406,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SERPENT=m
 CONFIG_CRYPTO_TEA=m
index 0f9ef20744f9dbbf9121eeddd17889aa79963ce9..865ae23bf11ddc53bad5d565e73adcfce38f48d6 100644 (file)
@@ -405,7 +405,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SERPENT=m
 CONFIG_CRYPTO_TEA=m
index ad9fbd0cbb38414db5fa7a5144b1439ad451138c..7e04a6b1b4ebaddde28b436b9d41d293e1c2420c 100644 (file)
@@ -380,7 +380,6 @@ CONFIG_CRYPTO_ANUBIS=m
 CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SERPENT=m
 CONFIG_CRYPTO_TEA=m
index 4a25b8d3e5078860eb9838637b622b3efc9a77a3..fe8a5a3ff32860e280f6903dd6aa4b5751d61f16 100644 (file)
@@ -92,7 +92,6 @@ CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_SERPENT=m
 CONFIG_CRYPTO_TWOFISH=m
 CONFIG_CRYPTO_DEFLATE=m
index 0c4d54df9cf0dc95e38e9f99d602de56359e3bd5..0503b4ef4c7a43ea2cbad067cbdc23d63e7615e0 100644 (file)
@@ -281,7 +281,6 @@ CONFIG_NLS_ASCII=m
 CONFIG_NLS_ISO8859_1=m
 CONFIG_NLS_ISO8859_2=m
 CONFIG_NLS_UTF8=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_ECB=m
 CONFIG_CRYPTO_PCBC=m
 CONFIG_CRYPTO_MD4=m
index eda1fec7ffd947f421891145163105cf1aafbf43..db3a8da4ccd3e59dae2209cfd66fdef0964a0acb 100644 (file)
@@ -1064,7 +1064,6 @@ CONFIG_CRYPTO_ANUBIS=m
 CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index 730c90b4a87645f2153a3577a7a89bd5d45f41cd..69cbbf3c0f015bfa59df6468bb59feee2edc142b 100644 (file)
@@ -780,7 +780,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index dd5fc1426c8805a6b3e87a2ea9214c64bf548118..2f3f2259cf117561e338664a6b508aa701825819 100644 (file)
@@ -764,7 +764,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
 CONFIG_CRYPTO_DES=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index 5d90804994857cf8a66e4e7e0102616b94a97238..4a67f9c858064a1e19d79750bc65a11cd265fcd1 100644 (file)
@@ -182,7 +182,6 @@ CONFIG_CRYPTO_BLOWFISH=y
 CONFIG_CRYPTO_CAMELLIA=y
 CONFIG_CRYPTO_CAST5=y
 CONFIG_CRYPTO_CAST6=y
-CONFIG_CRYPTO_FCRYPT=y
 CONFIG_CRYPTO_KHAZAD=y
 CONFIG_CRYPTO_SEED=y
 CONFIG_CRYPTO_SERPENT=y
index 632081a262baefe2ab5cf3b82e1e41f49c37475c..c6009ebc806de869b413dee53a5dacd458ed53c2 100644 (file)
@@ -220,7 +220,6 @@ CONFIG_CRYPTO_BLOWFISH=m
 CONFIG_CRYPTO_CAMELLIA=m
 CONFIG_CRYPTO_CAST5=m
 CONFIG_CRYPTO_CAST6=m
-CONFIG_CRYPTO_FCRYPT=m
 CONFIG_CRYPTO_KHAZAD=m
 CONFIG_CRYPTO_SEED=m
 CONFIG_CRYPTO_SERPENT=m
index 103d1f58cb7c21aa9dfcc9fe716cc1ebb5e767c7..0727cd5877da150bef7b1b0994fcb13c79990b22 100644 (file)
@@ -464,15 +464,6 @@ config CRYPTO_DES
          Triple DES EDE (Encrypt/Decrypt/Encrypt) (FIPS 46-3, ISO/IEC 18033-3)
          cipher algorithms
 
-config CRYPTO_FCRYPT
-       tristate "FCrypt"
-       select CRYPTO_ALGAPI
-       select CRYPTO_SKCIPHER
-       help
-         FCrypt algorithm used by RxRPC
-
-         See https://ota.polyonymo.us/fcrypt-paper.txt
-
 config CRYPTO_KHAZAD
        tristate "Khazad"
        depends on CRYPTO_USER_API_ENABLE_OBSOLETE
index 162242593c7c187c414eec2d9b3cd88facaa743d..1827f84192e69786fce530192fbaf4e3e32b01e1 100644 (file)
@@ -126,7 +126,6 @@ CFLAGS_aegis128-neon-inner.o += -isystem $(shell $(CC) -print-file-name=include)
 obj-$(CONFIG_CRYPTO_PCRYPT) += pcrypt.o
 obj-$(CONFIG_CRYPTO_CRYPTD) += cryptd.o
 obj-$(CONFIG_CRYPTO_DES) += des_generic.o
-obj-$(CONFIG_CRYPTO_FCRYPT) += fcrypt.o
 obj-$(CONFIG_CRYPTO_BLOWFISH) += blowfish_generic.o
 obj-$(CONFIG_CRYPTO_BLOWFISH_COMMON) += blowfish_common.o
 obj-$(CONFIG_CRYPTO_TWOFISH) += twofish_generic.o
diff --git a/crypto/fcrypt.c b/crypto/fcrypt.c
deleted file mode 100644 (file)
index 8003683..0000000
+++ /dev/null
@@ -1,420 +0,0 @@
-/* FCrypt encryption algorithm
- *
- * Copyright (C) 2006 Red Hat, Inc. All Rights Reserved.
- * Written by David Howells (dhowells@redhat.com)
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License
- * as published by the Free Software Foundation; either version
- * 2 of the License, or (at your option) any later version.
- *
- * Based on code:
- *
- * Copyright (c) 1995 - 2000 Kungliga Tekniska Högskolan
- * (Royal Institute of Technology, Stockholm, Sweden).
- * All rights reserved.
- *
- * 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, this list of conditions and the following disclaimer.
- *
- * 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. Neither the name of the Institute nor the names of its contributors
- *    may be used to endorse or promote products derived from this software
- *    without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED.  IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS 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 ADVISED OF THE POSSIBILITY OF
- * SUCH DAMAGE.
- */
-
-#include <asm/byteorder.h>
-#include <crypto/algapi.h>
-#include <linux/bitops.h>
-#include <linux/init.h>
-#include <linux/module.h>
-
-#define ROUNDS 16
-
-struct fcrypt_ctx {
-       __be32 sched[ROUNDS];
-};
-
-/* Rotate right two 32 bit numbers as a 56 bit number */
-#define ror56(hi, lo, n)                                       \
-do {                                                           \
-       u32 t = lo & ((1 << n) - 1);                            \
-       lo = (lo >> n) | ((hi & ((1 << n) - 1)) << (32 - n));   \
-       hi = (hi >> n) | (t << (24-n));                         \
-} while (0)
-
-/* Rotate right one 64 bit number as a 56 bit number */
-#define ror56_64(k, n) (k = (k >> n) | ((k & ((1 << n) - 1)) << (56 - n)))
-
-/*
- * Sboxes for Feistel network derived from
- * /afs/transarc.com/public/afsps/afs.rel31b.export-src/rxkad/sboxes.h
- */
-#undef Z
-#define Z(x) cpu_to_be32(x << 3)
-static const __be32 sbox0[256] = {
-       Z(0xea), Z(0x7f), Z(0xb2), Z(0x64), Z(0x9d), Z(0xb0), Z(0xd9), Z(0x11),
-       Z(0xcd), Z(0x86), Z(0x86), Z(0x91), Z(0x0a), Z(0xb2), Z(0x93), Z(0x06),
-       Z(0x0e), Z(0x06), Z(0xd2), Z(0x65), Z(0x73), Z(0xc5), Z(0x28), Z(0x60),
-       Z(0xf2), Z(0x20), Z(0xb5), Z(0x38), Z(0x7e), Z(0xda), Z(0x9f), Z(0xe3),
-       Z(0xd2), Z(0xcf), Z(0xc4), Z(0x3c), Z(0x61), Z(0xff), Z(0x4a), Z(0x4a),
-       Z(0x35), Z(0xac), Z(0xaa), Z(0x5f), Z(0x2b), Z(0xbb), Z(0xbc), Z(0x53),
-       Z(0x4e), Z(0x9d), Z(0x78), Z(0xa3), Z(0xdc), Z(0x09), Z(0x32), Z(0x10),
-       Z(0xc6), Z(0x6f), Z(0x66), Z(0xd6), Z(0xab), Z(0xa9), Z(0xaf), Z(0xfd),
-       Z(0x3b), Z(0x95), Z(0xe8), Z(0x34), Z(0x9a), Z(0x81), Z(0x72), Z(0x80),
-       Z(0x9c), Z(0xf3), Z(0xec), Z(0xda), Z(0x9f), Z(0x26), Z(0x76), Z(0x15),
-       Z(0x3e), Z(0x55), Z(0x4d), Z(0xde), Z(0x84), Z(0xee), Z(0xad), Z(0xc7),
-       Z(0xf1), Z(0x6b), Z(0x3d), Z(0xd3), Z(0x04), Z(0x49), Z(0xaa), Z(0x24),
-       Z(0x0b), Z(0x8a), Z(0x83), Z(0xba), Z(0xfa), Z(0x85), Z(0xa0), Z(0xa8),
-       Z(0xb1), Z(0xd4), Z(0x01), Z(0xd8), Z(0x70), Z(0x64), Z(0xf0), Z(0x51),
-       Z(0xd2), Z(0xc3), Z(0xa7), Z(0x75), Z(0x8c), Z(0xa5), Z(0x64), Z(0xef),
-       Z(0x10), Z(0x4e), Z(0xb7), Z(0xc6), Z(0x61), Z(0x03), Z(0xeb), Z(0x44),
-       Z(0x3d), Z(0xe5), Z(0xb3), Z(0x5b), Z(0xae), Z(0xd5), Z(0xad), Z(0x1d),
-       Z(0xfa), Z(0x5a), Z(0x1e), Z(0x33), Z(0xab), Z(0x93), Z(0xa2), Z(0xb7),
-       Z(0xe7), Z(0xa8), Z(0x45), Z(0xa4), Z(0xcd), Z(0x29), Z(0x63), Z(0x44),
-       Z(0xb6), Z(0x69), Z(0x7e), Z(0x2e), Z(0x62), Z(0x03), Z(0xc8), Z(0xe0),
-       Z(0x17), Z(0xbb), Z(0xc7), Z(0xf3), Z(0x3f), Z(0x36), Z(0xba), Z(0x71),
-       Z(0x8e), Z(0x97), Z(0x65), Z(0x60), Z(0x69), Z(0xb6), Z(0xf6), Z(0xe6),
-       Z(0x6e), Z(0xe0), Z(0x81), Z(0x59), Z(0xe8), Z(0xaf), Z(0xdd), Z(0x95),
-       Z(0x22), Z(0x99), Z(0xfd), Z(0x63), Z(0x19), Z(0x74), Z(0x61), Z(0xb1),
-       Z(0xb6), Z(0x5b), Z(0xae), Z(0x54), Z(0xb3), Z(0x70), Z(0xff), Z(0xc6),
-       Z(0x3b), Z(0x3e), Z(0xc1), Z(0xd7), Z(0xe1), Z(0x0e), Z(0x76), Z(0xe5),
-       Z(0x36), Z(0x4f), Z(0x59), Z(0xc7), Z(0x08), Z(0x6e), Z(0x82), Z(0xa6),
-       Z(0x93), Z(0xc4), Z(0xaa), Z(0x26), Z(0x49), Z(0xe0), Z(0x21), Z(0x64),
-       Z(0x07), Z(0x9f), Z(0x64), Z(0x81), Z(0x9c), Z(0xbf), Z(0xf9), Z(0xd1),
-       Z(0x43), Z(0xf8), Z(0xb6), Z(0xb9), Z(0xf1), Z(0x24), Z(0x75), Z(0x03),
-       Z(0xe4), Z(0xb0), Z(0x99), Z(0x46), Z(0x3d), Z(0xf5), Z(0xd1), Z(0x39),
-       Z(0x72), Z(0x12), Z(0xf6), Z(0xba), Z(0x0c), Z(0x0d), Z(0x42), Z(0x2e)
-};
-
-#undef Z
-#define Z(x) cpu_to_be32(((x & 0x1f) << 27) | (x >> 5))
-static const __be32 sbox1[256] = {
-       Z(0x77), Z(0x14), Z(0xa6), Z(0xfe), Z(0xb2), Z(0x5e), Z(0x8c), Z(0x3e),
-       Z(0x67), Z(0x6c), Z(0xa1), Z(0x0d), Z(0xc2), Z(0xa2), Z(0xc1), Z(0x85),
-       Z(0x6c), Z(0x7b), Z(0x67), Z(0xc6), Z(0x23), Z(0xe3), Z(0xf2), Z(0x89),
-       Z(0x50), Z(0x9c), Z(0x03), Z(0xb7), Z(0x73), Z(0xe6), Z(0xe1), Z(0x39),
-       Z(0x31), Z(0x2c), Z(0x27), Z(0x9f), Z(0xa5), Z(0x69), Z(0x44), Z(0xd6),
-       Z(0x23), Z(0x83), Z(0x98), Z(0x7d), Z(0x3c), Z(0xb4), Z(0x2d), Z(0x99),
-       Z(0x1c), Z(0x1f), Z(0x8c), Z(0x20), Z(0x03), Z(0x7c), Z(0x5f), Z(0xad),
-       Z(0xf4), Z(0xfa), Z(0x95), Z(0xca), Z(0x76), Z(0x44), Z(0xcd), Z(0xb6),
-       Z(0xb8), Z(0xa1), Z(0xa1), Z(0xbe), Z(0x9e), Z(0x54), Z(0x8f), Z(0x0b),
-       Z(0x16), Z(0x74), Z(0x31), Z(0x8a), Z(0x23), Z(0x17), Z(0x04), Z(0xfa),
-       Z(0x79), Z(0x84), Z(0xb1), Z(0xf5), Z(0x13), Z(0xab), Z(0xb5), Z(0x2e),
-       Z(0xaa), Z(0x0c), Z(0x60), Z(0x6b), Z(0x5b), Z(0xc4), Z(0x4b), Z(0xbc),
-       Z(0xe2), Z(0xaf), Z(0x45), Z(0x73), Z(0xfa), Z(0xc9), Z(0x49), Z(0xcd),
-       Z(0x00), Z(0x92), Z(0x7d), Z(0x97), Z(0x7a), Z(0x18), Z(0x60), Z(0x3d),
-       Z(0xcf), Z(0x5b), Z(0xde), Z(0xc6), Z(0xe2), Z(0xe6), Z(0xbb), Z(0x8b),
-       Z(0x06), Z(0xda), Z(0x08), Z(0x15), Z(0x1b), Z(0x88), Z(0x6a), Z(0x17),
-       Z(0x89), Z(0xd0), Z(0xa9), Z(0xc1), Z(0xc9), Z(0x70), Z(0x6b), Z(0xe5),
-       Z(0x43), Z(0xf4), Z(0x68), Z(0xc8), Z(0xd3), Z(0x84), Z(0x28), Z(0x0a),
-       Z(0x52), Z(0x66), Z(0xa3), Z(0xca), Z(0xf2), Z(0xe3), Z(0x7f), Z(0x7a),
-       Z(0x31), Z(0xf7), Z(0x88), Z(0x94), Z(0x5e), Z(0x9c), Z(0x63), Z(0xd5),
-       Z(0x24), Z(0x66), Z(0xfc), Z(0xb3), Z(0x57), Z(0x25), Z(0xbe), Z(0x89),
-       Z(0x44), Z(0xc4), Z(0xe0), Z(0x8f), Z(0x23), Z(0x3c), Z(0x12), Z(0x52),
-       Z(0xf5), Z(0x1e), Z(0xf4), Z(0xcb), Z(0x18), Z(0x33), Z(0x1f), Z(0xf8),
-       Z(0x69), Z(0x10), Z(0x9d), Z(0xd3), Z(0xf7), Z(0x28), Z(0xf8), Z(0x30),
-       Z(0x05), Z(0x5e), Z(0x32), Z(0xc0), Z(0xd5), Z(0x19), Z(0xbd), Z(0x45),
-       Z(0x8b), Z(0x5b), Z(0xfd), Z(0xbc), Z(0xe2), Z(0x5c), Z(0xa9), Z(0x96),
-       Z(0xef), Z(0x70), Z(0xcf), Z(0xc2), Z(0x2a), Z(0xb3), Z(0x61), Z(0xad),
-       Z(0x80), Z(0x48), Z(0x81), Z(0xb7), Z(0x1d), Z(0x43), Z(0xd9), Z(0xd7),
-       Z(0x45), Z(0xf0), Z(0xd8), Z(0x8a), Z(0x59), Z(0x7c), Z(0x57), Z(0xc1),
-       Z(0x79), Z(0xc7), Z(0x34), Z(0xd6), Z(0x43), Z(0xdf), Z(0xe4), Z(0x78),
-       Z(0x16), Z(0x06), Z(0xda), Z(0x92), Z(0x76), Z(0x51), Z(0xe1), Z(0xd4),
-       Z(0x70), Z(0x03), Z(0xe0), Z(0x2f), Z(0x96), Z(0x91), Z(0x82), Z(0x80)
-};
-
-#undef Z
-#define Z(x) cpu_to_be32(x << 11)
-static const __be32 sbox2[256] = {
-       Z(0xf0), Z(0x37), Z(0x24), Z(0x53), Z(0x2a), Z(0x03), Z(0x83), Z(0x86),
-       Z(0xd1), Z(0xec), Z(0x50), Z(0xf0), Z(0x42), Z(0x78), Z(0x2f), Z(0x6d),
-       Z(0xbf), Z(0x80), Z(0x87), Z(0x27), Z(0x95), Z(0xe2), Z(0xc5), Z(0x5d),
-       Z(0xf9), Z(0x6f), Z(0xdb), Z(0xb4), Z(0x65), Z(0x6e), Z(0xe7), Z(0x24),
-       Z(0xc8), Z(0x1a), Z(0xbb), Z(0x49), Z(0xb5), Z(0x0a), Z(0x7d), Z(0xb9),
-       Z(0xe8), Z(0xdc), Z(0xb7), Z(0xd9), Z(0x45), Z(0x20), Z(0x1b), Z(0xce),
-       Z(0x59), Z(0x9d), Z(0x6b), Z(0xbd), Z(0x0e), Z(0x8f), Z(0xa3), Z(0xa9),
-       Z(0xbc), Z(0x74), Z(0xa6), Z(0xf6), Z(0x7f), Z(0x5f), Z(0xb1), Z(0x68),
-       Z(0x84), Z(0xbc), Z(0xa9), Z(0xfd), Z(0x55), Z(0x50), Z(0xe9), Z(0xb6),
-       Z(0x13), Z(0x5e), Z(0x07), Z(0xb8), Z(0x95), Z(0x02), Z(0xc0), Z(0xd0),
-       Z(0x6a), Z(0x1a), Z(0x85), Z(0xbd), Z(0xb6), Z(0xfd), Z(0xfe), Z(0x17),
-       Z(0x3f), Z(0x09), Z(0xa3), Z(0x8d), Z(0xfb), Z(0xed), Z(0xda), Z(0x1d),
-       Z(0x6d), Z(0x1c), Z(0x6c), Z(0x01), Z(0x5a), Z(0xe5), Z(0x71), Z(0x3e),
-       Z(0x8b), Z(0x6b), Z(0xbe), Z(0x29), Z(0xeb), Z(0x12), Z(0x19), Z(0x34),
-       Z(0xcd), Z(0xb3), Z(0xbd), Z(0x35), Z(0xea), Z(0x4b), Z(0xd5), Z(0xae),
-       Z(0x2a), Z(0x79), Z(0x5a), Z(0xa5), Z(0x32), Z(0x12), Z(0x7b), Z(0xdc),
-       Z(0x2c), Z(0xd0), Z(0x22), Z(0x4b), Z(0xb1), Z(0x85), Z(0x59), Z(0x80),
-       Z(0xc0), Z(0x30), Z(0x9f), Z(0x73), Z(0xd3), Z(0x14), Z(0x48), Z(0x40),
-       Z(0x07), Z(0x2d), Z(0x8f), Z(0x80), Z(0x0f), Z(0xce), Z(0x0b), Z(0x5e),
-       Z(0xb7), Z(0x5e), Z(0xac), Z(0x24), Z(0x94), Z(0x4a), Z(0x18), Z(0x15),
-       Z(0x05), Z(0xe8), Z(0x02), Z(0x77), Z(0xa9), Z(0xc7), Z(0x40), Z(0x45),
-       Z(0x89), Z(0xd1), Z(0xea), Z(0xde), Z(0x0c), Z(0x79), Z(0x2a), Z(0x99),
-       Z(0x6c), Z(0x3e), Z(0x95), Z(0xdd), Z(0x8c), Z(0x7d), Z(0xad), Z(0x6f),
-       Z(0xdc), Z(0xff), Z(0xfd), Z(0x62), Z(0x47), Z(0xb3), Z(0x21), Z(0x8a),
-       Z(0xec), Z(0x8e), Z(0x19), Z(0x18), Z(0xb4), Z(0x6e), Z(0x3d), Z(0xfd),
-       Z(0x74), Z(0x54), Z(0x1e), Z(0x04), Z(0x85), Z(0xd8), Z(0xbc), Z(0x1f),
-       Z(0x56), Z(0xe7), Z(0x3a), Z(0x56), Z(0x67), Z(0xd6), Z(0xc8), Z(0xa5),
-       Z(0xf3), Z(0x8e), Z(0xde), Z(0xae), Z(0x37), Z(0x49), Z(0xb7), Z(0xfa),
-       Z(0xc8), Z(0xf4), Z(0x1f), Z(0xe0), Z(0x2a), Z(0x9b), Z(0x15), Z(0xd1),
-       Z(0x34), Z(0x0e), Z(0xb5), Z(0xe0), Z(0x44), Z(0x78), Z(0x84), Z(0x59),
-       Z(0x56), Z(0x68), Z(0x77), Z(0xa5), Z(0x14), Z(0x06), Z(0xf5), Z(0x2f),
-       Z(0x8c), Z(0x8a), Z(0x73), Z(0x80), Z(0x76), Z(0xb4), Z(0x10), Z(0x86)
-};
-
-#undef Z
-#define Z(x) cpu_to_be32(x << 19)
-static const __be32 sbox3[256] = {
-       Z(0xa9), Z(0x2a), Z(0x48), Z(0x51), Z(0x84), Z(0x7e), Z(0x49), Z(0xe2),
-       Z(0xb5), Z(0xb7), Z(0x42), Z(0x33), Z(0x7d), Z(0x5d), Z(0xa6), Z(0x12),
-       Z(0x44), Z(0x48), Z(0x6d), Z(0x28), Z(0xaa), Z(0x20), Z(0x6d), Z(0x57),
-       Z(0xd6), Z(0x6b), Z(0x5d), Z(0x72), Z(0xf0), Z(0x92), Z(0x5a), Z(0x1b),
-       Z(0x53), Z(0x80), Z(0x24), Z(0x70), Z(0x9a), Z(0xcc), Z(0xa7), Z(0x66),
-       Z(0xa1), Z(0x01), Z(0xa5), Z(0x41), Z(0x97), Z(0x41), Z(0x31), Z(0x82),
-       Z(0xf1), Z(0x14), Z(0xcf), Z(0x53), Z(0x0d), Z(0xa0), Z(0x10), Z(0xcc),
-       Z(0x2a), Z(0x7d), Z(0xd2), Z(0xbf), Z(0x4b), Z(0x1a), Z(0xdb), Z(0x16),
-       Z(0x47), Z(0xf6), Z(0x51), Z(0x36), Z(0xed), Z(0xf3), Z(0xb9), Z(0x1a),
-       Z(0xa7), Z(0xdf), Z(0x29), Z(0x43), Z(0x01), Z(0x54), Z(0x70), Z(0xa4),
-       Z(0xbf), Z(0xd4), Z(0x0b), Z(0x53), Z(0x44), Z(0x60), Z(0x9e), Z(0x23),
-       Z(0xa1), Z(0x18), Z(0x68), Z(0x4f), Z(0xf0), Z(0x2f), Z(0x82), Z(0xc2),
-       Z(0x2a), Z(0x41), Z(0xb2), Z(0x42), Z(0x0c), Z(0xed), Z(0x0c), Z(0x1d),
-       Z(0x13), Z(0x3a), Z(0x3c), Z(0x6e), Z(0x35), Z(0xdc), Z(0x60), Z(0x65),
-       Z(0x85), Z(0xe9), Z(0x64), Z(0x02), Z(0x9a), Z(0x3f), Z(0x9f), Z(0x87),
-       Z(0x96), Z(0xdf), Z(0xbe), Z(0xf2), Z(0xcb), Z(0xe5), Z(0x6c), Z(0xd4),
-       Z(0x5a), Z(0x83), Z(0xbf), Z(0x92), Z(0x1b), Z(0x94), Z(0x00), Z(0x42),
-       Z(0xcf), Z(0x4b), Z(0x00), Z(0x75), Z(0xba), Z(0x8f), Z(0x76), Z(0x5f),
-       Z(0x5d), Z(0x3a), Z(0x4d), Z(0x09), Z(0x12), Z(0x08), Z(0x38), Z(0x95),
-       Z(0x17), Z(0xe4), Z(0x01), Z(0x1d), Z(0x4c), Z(0xa9), Z(0xcc), Z(0x85),
-       Z(0x82), Z(0x4c), Z(0x9d), Z(0x2f), Z(0x3b), Z(0x66), Z(0xa1), Z(0x34),
-       Z(0x10), Z(0xcd), Z(0x59), Z(0x89), Z(0xa5), Z(0x31), Z(0xcf), Z(0x05),
-       Z(0xc8), Z(0x84), Z(0xfa), Z(0xc7), Z(0xba), Z(0x4e), Z(0x8b), Z(0x1a),
-       Z(0x19), Z(0xf1), Z(0xa1), Z(0x3b), Z(0x18), Z(0x12), Z(0x17), Z(0xb0),
-       Z(0x98), Z(0x8d), Z(0x0b), Z(0x23), Z(0xc3), Z(0x3a), Z(0x2d), Z(0x20),
-       Z(0xdf), Z(0x13), Z(0xa0), Z(0xa8), Z(0x4c), Z(0x0d), Z(0x6c), Z(0x2f),
-       Z(0x47), Z(0x13), Z(0x13), Z(0x52), Z(0x1f), Z(0x2d), Z(0xf5), Z(0x79),
-       Z(0x3d), Z(0xa2), Z(0x54), Z(0xbd), Z(0x69), Z(0xc8), Z(0x6b), Z(0xf3),
-       Z(0x05), Z(0x28), Z(0xf1), Z(0x16), Z(0x46), Z(0x40), Z(0xb0), Z(0x11),
-       Z(0xd3), Z(0xb7), Z(0x95), Z(0x49), Z(0xcf), Z(0xc3), Z(0x1d), Z(0x8f),
-       Z(0xd8), Z(0xe1), Z(0x73), Z(0xdb), Z(0xad), Z(0xc8), Z(0xc9), Z(0xa9),
-       Z(0xa1), Z(0xc2), Z(0xc5), Z(0xe3), Z(0xba), Z(0xfc), Z(0x0e), Z(0x25)
-};
-
-/*
- * This is a 16 round Feistel network with permutation F_ENCRYPT
- */
-#define F_ENCRYPT(R, L, sched)                                         \
-do {                                                                   \
-       union lc4 { __be32 l; u8 c[4]; } u;                             \
-       u.l = sched ^ R;                                                \
-       L ^= sbox0[u.c[0]] ^ sbox1[u.c[1]] ^ sbox2[u.c[2]] ^ sbox3[u.c[3]]; \
-} while (0)
-
-/*
- * encryptor
- */
-static void fcrypt_encrypt(struct crypto_tfm *tfm, u8 *dst, const u8 *src)
-{
-       const struct fcrypt_ctx *ctx = crypto_tfm_ctx(tfm);
-       struct {
-               __be32 l, r;
-       } X;
-
-       memcpy(&X, src, sizeof(X));
-
-       F_ENCRYPT(X.r, X.l, ctx->sched[0x0]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0x1]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0x2]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0x3]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0x4]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0x5]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0x6]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0x7]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0x8]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0x9]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0xa]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0xb]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0xc]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0xd]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0xe]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0xf]);
-
-       memcpy(dst, &X, sizeof(X));
-}
-
-/*
- * decryptor
- */
-static void fcrypt_decrypt(struct crypto_tfm *tfm, u8 *dst, const u8 *src)
-{
-       const struct fcrypt_ctx *ctx = crypto_tfm_ctx(tfm);
-       struct {
-               __be32 l, r;
-       } X;
-
-       memcpy(&X, src, sizeof(X));
-
-       F_ENCRYPT(X.l, X.r, ctx->sched[0xf]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0xe]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0xd]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0xc]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0xb]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0xa]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0x9]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0x8]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0x7]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0x6]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0x5]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0x4]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0x3]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0x2]);
-       F_ENCRYPT(X.l, X.r, ctx->sched[0x1]);
-       F_ENCRYPT(X.r, X.l, ctx->sched[0x0]);
-
-       memcpy(dst, &X, sizeof(X));
-}
-
-/*
- * Generate a key schedule from key, the least significant bit in each key byte
- * is parity and shall be ignored. This leaves 56 significant bits in the key
- * to scatter over the 16 key schedules. For each schedule extract the low
- * order 32 bits and use as schedule, then rotate right by 11 bits.
- */
-static int fcrypt_setkey(struct crypto_tfm *tfm, const u8 *key, unsigned int keylen)
-{
-       struct fcrypt_ctx *ctx = crypto_tfm_ctx(tfm);
-
-#if BITS_PER_LONG == 64  /* the 64-bit version can also be used for 32-bit
-                         * kernels - it seems to be faster but the code is
-                         * larger */
-
-       u64 k;  /* k holds all 56 non-parity bits */
-
-       /* discard the parity bits */
-       k = (*key++) >> 1;
-       k <<= 7;
-       k |= (*key++) >> 1;
-       k <<= 7;
-       k |= (*key++) >> 1;
-       k <<= 7;
-       k |= (*key++) >> 1;
-       k <<= 7;
-       k |= (*key++) >> 1;
-       k <<= 7;
-       k |= (*key++) >> 1;
-       k <<= 7;
-       k |= (*key++) >> 1;
-       k <<= 7;
-       k |= (*key) >> 1;
-
-       /* Use lower 32 bits for schedule, rotate by 11 each round (16 times) */
-       ctx->sched[0x0] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0x1] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0x2] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0x3] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0x4] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0x5] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0x6] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0x7] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0x8] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0x9] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0xa] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0xb] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0xc] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0xd] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0xe] = cpu_to_be32(k); ror56_64(k, 11);
-       ctx->sched[0xf] = cpu_to_be32(k);
-
-       return 0;
-#else
-       u32 hi, lo;             /* hi is upper 24 bits and lo lower 32, total 56 */
-
-       /* discard the parity bits */
-       lo = (*key++) >> 1;
-       lo <<= 7;
-       lo |= (*key++) >> 1;
-       lo <<= 7;
-       lo |= (*key++) >> 1;
-       lo <<= 7;
-       lo |= (*key++) >> 1;
-       hi = lo >> 4;
-       lo &= 0xf;
-       lo <<= 7;
-       lo |= (*key++) >> 1;
-       lo <<= 7;
-       lo |= (*key++) >> 1;
-       lo <<= 7;
-       lo |= (*key++) >> 1;
-       lo <<= 7;
-       lo |= (*key) >> 1;
-
-       /* Use lower 32 bits for schedule, rotate by 11 each round (16 times) */
-       ctx->sched[0x0] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0x1] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0x2] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0x3] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0x4] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0x5] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0x6] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0x7] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0x8] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0x9] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0xa] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0xb] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0xc] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0xd] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0xe] = cpu_to_be32(lo); ror56(hi, lo, 11);
-       ctx->sched[0xf] = cpu_to_be32(lo);
-       return 0;
-#endif
-}
-
-static struct crypto_alg fcrypt_alg = {
-       .cra_name               =       "fcrypt",
-       .cra_driver_name        =       "fcrypt-generic",
-       .cra_flags              =       CRYPTO_ALG_TYPE_CIPHER,
-       .cra_blocksize          =       8,
-       .cra_ctxsize            =       sizeof(struct fcrypt_ctx),
-       .cra_module             =       THIS_MODULE,
-       .cra_u                  =       { .cipher = {
-       .cia_min_keysize        =       8,
-       .cia_max_keysize        =       8,
-       .cia_setkey             =       fcrypt_setkey,
-       .cia_encrypt            =       fcrypt_encrypt,
-       .cia_decrypt            =       fcrypt_decrypt } }
-};
-
-static int __init fcrypt_mod_init(void)
-{
-       return crypto_register_alg(&fcrypt_alg);
-}
-
-static void __exit fcrypt_mod_fini(void)
-{
-       crypto_unregister_alg(&fcrypt_alg);
-}
-
-module_init(fcrypt_mod_init);
-module_exit(fcrypt_mod_fini);
-
-MODULE_LICENSE("Dual BSD/GPL");
-MODULE_DESCRIPTION("FCrypt Cipher Algorithm");
-MODULE_AUTHOR("David Howells <dhowells@redhat.com>");
-MODULE_ALIAS_CRYPTO("fcrypt");
index e54517605f5fa697122bb24d32259208bba1bc37..61a2501bfe9b6b46bd74bedc58650fb43ec4dcad 100644 (file)
@@ -1600,10 +1600,6 @@ static int do_test(const char *alg, u32 type, u32 mask, int m, u32 num_mb)
                ret = min(ret, tcrypt_test("ecb(xeta)"));
                break;
 
-       case 31:
-               ret = min(ret, tcrypt_test("pcbc(fcrypt)"));
-               break;
-
        case 32:
                ret = min(ret, tcrypt_test("ecb(camellia)"));
                ret = min(ret, tcrypt_test("cbc(camellia)"));
index 4d86efae65b217321caccaf2e1f89a60826bce6a..f392d97fc4698e34ba9aca4b0902bf8d44909104 100644 (file)
@@ -4827,15 +4827,6 @@ static const struct alg_test_desc alg_test_descs[] = {
                .suite = {
                        .cipher = __VECS(des3_ede_tv_template)
                }
-       }, {
-               .alg = "ecb(fcrypt)",
-               .test = alg_test_skcipher,
-               .suite = {
-                       .cipher = {
-                               .vecs = fcrypt_pcbc_tv_template,
-                               .count = 1
-                       }
-               }
        }, {
                .alg = "ecb(khazad)",
                .test = alg_test_skcipher,
@@ -5254,12 +5245,6 @@ static const struct alg_test_desc alg_test_descs[] = {
                .test = alg_test_null,
                .fips_allowed = 1,
        }, {
-               .alg = "pcbc(fcrypt)",
-               .test = alg_test_skcipher,
-               .suite = {
-                       .cipher = __VECS(fcrypt_pcbc_tv_template)
-               }
-       }, {
 #if IS_ENABLED(CONFIG_CRYPTO_PHMAC_S390)
                .alg = "phmac(sha224)",
                .test = alg_test_hash,
index 9b4d7e11c9fd920bc46fc597f3d1c11f74a6e6e2..3f0600bd9c054edfb4ae7dd36cc939fc89e3487b 100644 (file)
@@ -25068,51 +25068,6 @@ static const struct cipher_testvec xeta_tv_template[] = {
        }
 };
 
-/*
- * FCrypt test vectors
- */
-static const struct cipher_testvec fcrypt_pcbc_tv_template[] = {
-       { /* http://www.openafs.org/pipermail/openafs-devel/2000-December/005320.html */
-               .key    = "\x00\x00\x00\x00\x00\x00\x00\x00",
-               .klen   = 8,
-               .iv     = "\x00\x00\x00\x00\x00\x00\x00\x00",
-               .ptext  = "\x00\x00\x00\x00\x00\x00\x00\x00",
-               .ctext  = "\x0E\x09\x00\xC7\x3E\xF7\xED\x41",
-               .len    = 8,
-       }, {
-               .key    = "\x11\x44\x77\xAA\xDD\x00\x33\x66",
-               .klen   = 8,
-               .iv     = "\x00\x00\x00\x00\x00\x00\x00\x00",
-               .ptext  = "\x12\x34\x56\x78\x9A\xBC\xDE\xF0",
-               .ctext  = "\xD8\xED\x78\x74\x77\xEC\x06\x80",
-               .len    = 8,
-       }, { /* From Arla */
-               .key    = "\xf0\xe1\xd2\xc3\xb4\xa5\x96\x87",
-               .klen   = 8,
-               .iv     = "\xfe\xdc\xba\x98\x76\x54\x32\x10",
-               .ptext  = "The quick brown fox jumps over the lazy dogs.\0\0",
-               .ctext  = "\x00\xf0\x0e\x11\x75\xe6\x23\x82"
-                         "\xee\xac\x98\x62\x44\x51\xe4\x84"
-                         "\xc3\x59\xd8\xaa\x64\x60\xae\xf7"
-                         "\xd2\xd9\x13\x79\x72\xa3\x45\x03"
-                         "\x23\xb5\x62\xd7\x0c\xf5\x27\xd1"
-                         "\xf8\x91\x3c\xac\x44\x22\x92\xef",
-               .len    = 48,
-       }, {
-               .key    = "\xfe\xdc\xba\x98\x76\x54\x32\x10",
-               .klen   = 8,
-               .iv     = "\xf0\xe1\xd2\xc3\xb4\xa5\x96\x87",
-               .ptext  = "The quick brown fox jumps over the lazy dogs.\0\0",
-               .ctext  = "\xca\x90\xf5\x9d\xcb\xd4\xd2\x3c"
-                         "\x01\x88\x7f\x3e\x31\x6e\x62\x9d"
-                         "\xd8\xe0\x57\xa3\x06\x3a\x42\x58"
-                         "\x2a\x28\xfe\x72\x52\x2f\xdd\xe0"
-                         "\x19\x89\x09\x1c\x2a\x8e\x8c\x94"
-                         "\xfc\xc7\x68\xe4\x88\xaa\xde\x0f",
-               .len    = 48,
-       }
-};
-
 /*
  * CAMELLIA test vectors.
  */