// SPDX-License-Identifier: GPL-2.0-or-later
/* Kernel cryptographic api.
* cast5.c - Cast5 cipher algorithm (rfc2144).
*
* Derived from GnuPG implementation of cast5.
*
* Major Changes.
* Complete conformance to rfc2144.
* Supports key size from 40 to 128 bits.
*
* Copyright (C) 1998, 1999, 2000, 2001 Free Software Foundation, Inc.
* Copyright (C) 2003 Kartikey Mahendra Bhatt <kartik_me@hotmail.com>.
*/
#include <linux/unaligned.h>
#include <crypto/algapi.h>
#include <linux/init.h>
#include <linux/module.h>
#include <linux/errno.h>
#include <linux/string.h>
#include <linux/types.h>
#include <crypto/cast5.h>
static const u32 s5[256 ] = {
0 x7ec90c04, 0 x2c6e74b9, 0 x9b0e66df, 0 xa6337911, 0 xb86a7fff,
0 x1dd358f5, 0 x44dd9d44, 0 x1731167f,
0 x08fbf1fa, 0 xe7f511cc, 0 xd2051b00, 0 x735aba00, 0 x2ab722d8,
0 x386381cb, 0 xacf6243a, 0 x69befd7a,
0 xe6a2e77f, 0 xf0c720cd, 0 xc4494816, 0 xccf5c180, 0 x38851640,
0 x15b0a848, 0 xe68b18cb, 0 x4caadeff,
0 x5f480a01, 0 x0412b2aa, 0 x259814fc, 0 x41d0efe2, 0 x4e40b48d,
0 x248eb6fb, 0 x8dba1cfe, 0 x41a99b02,
0 x1a550a04, 0 xba8f65cb, 0 x7251f4e7, 0 x95a51725, 0 xc106ecd7,
0 x97a5980a, 0 xc539b9aa, 0 x4d79fe6a,
0 xf2f3f763, 0 x68af8040, 0 xed0c9e56, 0 x11b4958b, 0 xe1eb5a88,
0 x8709e6b0, 0 xd7e07156, 0 x4e29fea7,
0 x6366e52d, 0 x02d1c000, 0 xc4ac8e05, 0 x9377f571, 0 x0c05372a,
0 x578535f2, 0 x2261be02, 0 xd642a0c9,
0 xdf13a280, 0 x74b55bd2, 0 x682199c0, 0 xd421e5ec, 0 x53fb3ce8,
0 xc8adedb3, 0 x28a87fc9, 0 x3d959981,
0 x5c1ff900, 0 xfe38d399, 0 x0c4eff0b, 0 x062407ea, 0 xaa2f4fb1,
0 x4fb96976, 0 x90c79505, 0 xb0a8a774,
0 xef55a1ff, 0 xe59ca2c2, 0 xa6b62d27, 0 xe66a4263, 0 xdf65001f,
0 x0ec50966, 0 xdfdd55bc, 0 x29de0655,
0 x911e739a, 0 x17af8975, 0 x32c7911c, 0 x89f89468, 0 x0d01e980,
0 x524755f4, 0 x03b63cc9, 0 x0cc844b2,
0 xbcf3f0aa, 0 x87ac36e9, 0 xe53a7426, 0 x01b3d82b, 0 x1a9e7449,
0 x64ee2d7e, 0 xcddbb1da, 0 x01c94910,
0 xb868bf80, 0 x0d26f3fd, 0 x9342ede7, 0 x04a5c284, 0 x636737b6,
0 x50f5b616, 0 xf24766e3, 0 x8eca36c1,
0 x136e05db, 0 xfef18391, 0 xfb887a37, 0 xd6e7f7d4, 0 xc7fb7dc9,
0 x3063fcdf, 0 xb6f589de, 0 xec2941da,
0 x26e46695, 0 xb7566419, 0 xf654efc5, 0 xd08d58b7, 0 x48925401,
0 xc1bacb7f, 0 xe5ff550f, 0 xb6083049,
0 x5bb5d0e8, 0 x87d72e5a, 0 xab6a6ee1, 0 x223a66ce, 0 xc62bf3cd,
0 x9e0885f9, 0 x68cb3e47, 0 x086c010f,
0 xa21de820, 0 xd18b69de, 0 xf3f65777, 0 xfa02c3f6, 0 x407edac3,
0 xcbb3d550, 0 x1793084d, 0 xb0d70eba,
0 x0ab378d5, 0 xd951fb0c, 0 xded7da56, 0 x4124bbe4, 0 x94ca0b56,
0 x0f5755d1, 0 xe0e1e56e, 0 x6184b5be,
0 x580a249f, 0 x94f74bc0, 0 xe327888e, 0 x9f7b5561, 0 xc3dc0280,
0 x05687715, 0 x646c6bd7, 0 x44904db3,
0 x66b4f0a3, 0 xc0f1648a, 0 x697ed5af, 0 x49e92ff6, 0 x309e374f,
0 x2cb6356a, 0 x85808573, 0 x4991f840,
0 x76f0ae02, 0 x083be84d, 0 x28421c9a, 0 x44489406, 0 x736e4cb8,
0 xc1092910, 0 x8bc95fc6, 0 x7d869cf4,
0 x134f616f, 0 x2e77118d, 0 xb31b2be1, 0 xaa90b472, 0 x3ca5d717,
0 x7d161bba, 0 x9cad9010, 0 xaf462ba2,
0 x9fe459d2, 0 x45d34559, 0 xd9f2da13, 0 xdbc65487, 0 xf3e4f94e,
0 x176d486f, 0 x097c13ea, 0 x631da5c7,
0 x445f7382, 0 x175683f4, 0 xcdc66a97, 0 x70be0288, 0 xb3cdcf72,
0 x6e5dd2f3, 0 x20936079, 0 x459b80a5,
0 xbe60e2db, 0 xa9c23101, 0 xeba5315c, 0 x224e42f2, 0 x1c5c1572,
0 xf6721b2c, 0 x1ad2fff3, 0 x8c25404e,
0 x324ed72f, 0 x4067b7fd, 0 x0523138e, 0 x5ca3bc78, 0 xdc0fd66e,
0 x75922283, 0 x784d6b17, 0 x58ebb16e,
0 x44094f85, 0 x3f481d87, 0 xfcfeae7b, 0 x77b5ff76, 0 x8c2302bf,
0 xaaf47556, 0 x5f46b02a, 0 x2b092801,
0 x3d38f5f7, 0 x0ca81f36, 0 x52af4a8a, 0 x66d5e7c0, 0 xdf3b0874,
0 x95055110, 0 x1b5ad7a8, 0 xf61ed5ad,
0 x6cf6e479, 0 x20758184, 0 xd0cefa65, 0 x88f7be58, 0 x4a046826,
0 x0ff6f8f3, 0 xa09c7f70, 0 x5346aba0,
0 x5ce96c28, 0 xe176eda3, 0 x6bac307f, 0 x376829d2, 0 x85360fa9,
0 x17e3fe2a, 0 x24b79767, 0 xf5a96b20,
0 xd6cd2595, 0 x68ff1ebf, 0 x7555442c, 0 xf19f06be, 0 xf9e0659a,
0 xeeb9491d, 0 x34010718, 0 xbb30cab8,
0 xe822fe15, 0 x88570983, 0 x750e6249, 0 xda627e55, 0 x5e76ffa8,
0 xb1534546, 0 x6d47de08, 0 xefe9e7d4
};
static const u32 s6[256 ] = {
0 xf6fa8f9d, 0 x2cac6ce1, 0 x4ca34867, 0 xe2337f7c, 0 x95db08e7,
0 x016843b4, 0 xeced5cbc, 0 x325553ac,
0 xbf9f0960, 0 xdfa1e2ed, 0 x83f0579d, 0 x63ed86b9, 0 x1ab6a6b8,
0 xde5ebe39, 0 xf38ff732, 0 x8989b138,
0 x33f14961, 0 xc01937bd, 0 xf506c6da, 0 xe4625e7e, 0 xa308ea99,
0 x4e23e33c, 0 x79cbd7cc, 0 x48a14367,
0 xa3149619, 0 xfec94bd5, 0 xa114174a, 0 xeaa01866, 0 xa084db2d,
0 x09a8486f, 0 xa888614a, 0 x2900af98,
0 x01665991, 0 xe1992863, 0 xc8f30c60, 0 x2e78ef3c, 0 xd0d51932,
0 xcf0fec14, 0 xf7ca07d2, 0 xd0a82072,
0 xfd41197e, 0 x9305a6b0, 0 xe86be3da, 0 x74bed3cd, 0 x372da53c,
0 x4c7f4448, 0 xdab5d440, 0 x6dba0ec3,
0 x083919a7, 0 x9fbaeed9, 0 x49dbcfb0, 0 x4e670c53, 0 x5c3d9c01,
0 x64bdb941, 0 x2c0e636a, 0 xba7dd9cd,
0 xea6f7388, 0 xe70bc762, 0 x35f29adb, 0 x5c4cdd8d, 0 xf0d48d8c,
0 xb88153e2, 0 x08a19866, 0 x1ae2eac8,
0 x284caf89, 0 xaa928223, 0 x9334be53, 0 x3b3a21bf, 0 x16434be3,
0 x9aea3906, 0 xefe8c36e, 0 xf890cdd9,
0 x80226dae, 0 xc340a4a3, 0 xdf7e9c09, 0 xa694a807, 0 x5b7c5ecc,
0 x221db3a6, 0 x9a69a02f, 0 x68818a54,
0 xceb2296f, 0 x53c0843a, 0 xfe893655, 0 x25bfe68a, 0 xb4628abc,
0 xcf222ebf, 0 x25ac6f48, 0 xa9a99387,
0 x53bddb65, 0 xe76ffbe7, 0 xe967fd78, 0 x0ba93563, 0 x8e342bc1,
0 xe8a11be9, 0 x4980740d, 0 xc8087dfc,
0 x8de4bf99, 0 xa11101a0, 0 x7fd37975, 0 xda5a26c0, 0 xe81f994f,
0 x9528cd89, 0 xfd339fed, 0 xb87834bf,
0 x5f04456d, 0 x22258698, 0 xc9c4c83b, 0 x2dc156be, 0 x4f628daa,
0 x57f55ec5, 0 xe2220abe, 0 xd2916ebf,
0 x4ec75b95, 0 x24f2c3c0, 0 x42d15d99, 0 xcd0d7fa0, 0 x7b6e27ff,
0 xa8dc8af0, 0 x7345c106, 0 xf41e232f,
0 x35162386, 0 xe6ea8926, 0 x3333b094, 0 x157ec6f2, 0 x372b74af,
0 x692573e4, 0 xe9a9d848, 0 xf3160289,
0 x3a62ef1d, 0 xa787e238, 0 xf3a5f676, 0 x74364853, 0 x20951063,
0 x4576698d, 0 xb6fad407, 0 x592af950,
0 x36f73523, 0 x4cfb6e87, 0 x7da4cec0, 0 x6c152daa, 0 xcb0396a8,
0 xc50dfe5d, 0 xfcd707ab, 0 x0921c42f,
0 x89dff0bb, 0 x5fe2be78, 0 x448f4f33, 0 x754613c9, 0 x2b05d08d,
0 x48b9d585, 0 xdc049441, 0 xc8098f9b,
0 x7dede786, 0 xc39a3373, 0 x42410005, 0 x6a091751, 0 x0ef3c8a6,
0 x890072d6, 0 x28207682, 0 xa9a9f7be,
0 xbf32679d, 0 xd45b5b75, 0 xb353fd00, 0 xcbb0e358, 0 x830f220a,
0 x1f8fb214, 0 xd372cf08, 0 xcc3c4a13,
0 x8cf63166, 0 x061c87be, 0 x88c98f88, 0 x6062e397, 0 x47cf8e7a,
0 xb6c85283, 0 x3cc2acfb, 0 x3fc06976,
0 x4e8f0252, 0 x64d8314d, 0 xda3870e3, 0 x1e665459, 0 xc10908f0,
0 x513021a5, 0 x6c5b68b7, 0 x822f8aa0,
0 x3007cd3e, 0 x74719eef, 0 xdc872681, 0 x073340d4, 0 x7e432fd9,
0 x0c5ec241, 0 x8809286c, 0 xf592d891,
0 x08a930f6, 0 x957ef305, 0 xb7fbffbd, 0 xc266e96f, 0 x6fe4ac98,
0 xb173ecc0, 0 xbc60b42a, 0 x953498da,
0 xfba1ae12, 0 x2d4bd736, 0 x0f25faab, 0 xa4f3fceb, 0 xe2969123,
0 x257f0c3d, 0 x9348af49, 0 x361400bc,
0 xe8816f4a, 0 x3814f200, 0 xa3f94043, 0 x9c7a54c2, 0 xbc704f57,
0 xda41e7f9, 0 xc25ad33a, 0 x54f4a084,
0 xb17f5505, 0 x59357cbe, 0 xedbd15c8, 0 x7f97c5ab, 0 xba5ac7b5,
0 xb6f6deaf, 0 x3a479c3a, 0 x5302da25,
0 x653d7e6a, 0 x54268d49, 0 x51a477ea, 0 x5017d55b, 0 xd7d25d88,
0 x44136c76, 0 x0404a8c8, 0 xb8e5a121,
0 xb81a928a, 0 x60ed5869, 0 x97c55b96, 0 xeaec991b, 0 x29935913,
0 x01fdb7f1, 0 x088e8dfa, 0 x9ab6f6f5,
0 x3b4cbf9f, 0 x4a5de3ab, 0 xe6051d35, 0 xa0e1d855, 0 xd36b4cf1,
0 xf544edeb, 0 xb0e93524, 0 xbebb8fbd,
0 xa2d762cf, 0 x49c92f54, 0 x38b5f331, 0 x7128a454, 0 x48392905,
0 xa65b1db8, 0 x851c97bd, 0 xd675cf2f
};
static const u32 s7[256 ] = {
0 x85e04019, 0 x332bf567, 0 x662dbfff, 0 xcfc65693, 0 x2a8d7f6f,
0 xab9bc912, 0 xde6008a1, 0 x2028da1f,
0 x0227bce7, 0 x4d642916, 0 x18fac300, 0 x50f18b82, 0 x2cb2cb11,
0 xb232e75c, 0 x4b3695f2, 0 xb28707de,
0 xa05fbcf6, 0 xcd4181e9, 0 xe150210c, 0 xe24ef1bd, 0 xb168c381,
0 xfde4e789, 0 x5c79b0d8, 0 x1e8bfd43,
0 x4d495001, 0 x38be4341, 0 x913cee1d, 0 x92a79c3f, 0 x089766be,
0 xbaeeadf4, 0 x1286becf, 0 xb6eacb19,
0 x2660c200, 0 x7565bde4, 0 x64241f7a, 0 x8248dca9, 0 xc3b3ad66,
0 x28136086, 0 x0bd8dfa8, 0 x356d1cf2,
0 x107789be, 0 xb3b2e9ce, 0 x0502aa8f, 0 x0bc0351e, 0 x166bf52a,
0 xeb12ff82, 0 xe3486911, 0 xd34d7516,
0 x4e7b3aff, 0 x5f43671b, 0 x9cf6e037, 0 x4981ac83, 0 x334266ce,
0 x8c9341b7, 0 xd0d854c0, 0 xcb3a6c88,
0 x47bc2829, 0 x4725ba37, 0 xa66ad22b, 0 x7ad61f1e, 0 x0c5cbafa,
0 x4437f107, 0 xb6e79962, 0 x42d2d816,
0 x0a961288, 0 xe1a5c06e, 0 x13749e67, 0 x72fc081a, 0 xb1d139f7,
0 xf9583745, 0 xcf19df58, 0 xbec3f756,
0 xc06eba30, 0 x07211b24, 0 x45c28829, 0 xc95e317f, 0 xbc8ec511,
0 x38bc46e9, 0 xc6e6fa14, 0 xbae8584a,
0 xad4ebc46, 0 x468f508b, 0 x7829435f, 0 xf124183b, 0 x821dba9f,
0 xaff60ff4, 0 xea2c4e6d, 0 x16e39264,
0 x92544a8b, 0 x009b4fc3, 0 xaba68ced, 0 x9ac96f78, 0 x06a5b79a,
0 xb2856e6e, 0 x1aec3ca9, 0 xbe838688,
0 x0e0804e9, 0 x55f1be56, 0 xe7e5363b, 0 xb3a1f25d, 0 xf7debb85,
0 x61fe033c, 0 x16746233, 0 x3c034c28,
0 xda6d0c74, 0 x79aac56c, 0 x3ce4e1ad, 0 x51f0c802, 0 x98f8f35a,
0 x1626a49f, 0 xeed82b29, 0 x1d382fe3,
0 x0c4fb99a, 0 xbb325778, 0 x3ec6d97b, 0 x6e77a6a9, 0 xcb658b5c,
0 xd45230c7, 0 x2bd1408b, 0 x60c03eb7,
0 xb9068d78, 0 xa33754f4, 0 xf430c87d, 0 xc8a71302, 0 xb96d8c32,
0 xebd4e7be, 0 xbe8b9d2d, 0 x7979fb06,
0 xe7225308, 0 x8b75cf77, 0 x11ef8da4, 0 xe083c858, 0 x8d6b786f,
0 x5a6317a6, 0 xfa5cf7a0, 0 x5dda0033,
0 xf28ebfb0, 0 xf5b9c310, 0 xa0eac280, 0 x08b9767a, 0 xa3d9d2b0,
0 x79d34217, 0 x021a718d, 0 x9ac6336a,
0 x2711fd60, 0 x438050e3, 0 x069908a8, 0 x3d7fedc4, 0 x826d2bef,
0 x4eeb8476, 0 x488dcf25, 0 x36c9d566,
0 x28e74e41, 0 xc2610aca, 0 x3d49a9cf, 0 xbae3b9df, 0 xb65f8de6,
0 x92aeaf64, 0 x3ac7d5e6, 0 x9ea80509,
0 xf22b017d, 0 xa4173f70, 0 xdd1e16c3, 0 x15e0d7f9, 0 x50b1b887,
0 x2b9f4fd5, 0 x625aba82, 0 x6a017962,
0 x2ec01b9c, 0 x15488aa9, 0 xd716e740, 0 x40055a2c, 0 x93d29a22,
0 xe32dbf9a, 0 x058745b9, 0 x3453dc1e,
0 xd699296e, 0 x496cff6f, 0 x1c9f4986, 0 xdfe2ed07, 0 xb87242d1,
0 x19de7eae, 0 x053e561a, 0 x15ad6f8c,
0 x66626c1c, 0 x7154c24c, 0 xea082b2a, 0 x93eb2939, 0 x17dcb0f0,
0 x58d4f2ae, 0 x9ea294fb, 0 x52cf564c,
0 x9883fe66, 0 x2ec40581, 0 x763953c3, 0 x01d6692e, 0 xd3a0c108,
0 xa1e7160e, 0 xe4f2dfa6, 0 x693ed285,
0 x74904698, 0 x4c2b0edd, 0 x4f757656, 0 x5d393378, 0 xa132234f,
0 x3d321c5d, 0 xc3f5e194, 0 x4b269301,
0 xc79f022f, 0 x3c997e7e, 0 x5e4f9504, 0 x3ffafbbd, 0 x76f7ad0e,
0 x296693f4, 0 x3d1fce6f, 0 xc61e45be,
0 xd3b5ab34, 0 xf72bf9b7, 0 x1b0434c0, 0 x4e72b567, 0 x5592a33d,
0 xb5229301, 0 xcfd2a87f, 0 x60aeb767,
0 x1814386b, 0 x30bcc33d, 0 x38a0c07d, 0 xfd1606f2, 0 xc363519b,
0 x589dd390, 0 x5479f8e6, 0 x1cb8d647,
0 x97fd61a9, 0 xea7759f4, 0 x2d57539d, 0 x569a58cf, 0 xe84e63ad,
0 x462e1b78, 0 x6580f87e, 0 xf3817914,
0 x91da55f4, 0 x40a230f3, 0 xd1988f35, 0 xb6e318d2, 0 x3ffa50bc,
0 x3d40f021, 0 xc3c0bdae, 0 x4958c24c,
0 x518f36b2, 0 x84b1d370, 0 x0fedce83, 0 x878ddada, 0 xf2a279c7,
0 x94e01be8, 0 x90716f4b, 0 x954b8aa3
};
static const u32 sb8[256 ] = {
0 xe216300d, 0 xbbddfffc, 0 xa7ebdabd, 0 x35648095, 0 x7789f8b7,
0 xe6c1121b, 0 x0e241600, 0 x052ce8b5,
0 x11a9cfb0, 0 xe5952f11, 0 xece7990a, 0 x9386d174, 0 x2a42931c,
0 x76e38111, 0 xb12def3a, 0 x37ddddfc,
0 xde9adeb1, 0 x0a0cc32c, 0 xbe197029, 0 x84a00940, 0 xbb243a0f,
0 xb4d137cf, 0 xb44e79f0, 0 x049eedfd,
0 x0b15a15d, 0 x480d3168, 0 x8bbbde5a, 0 x669ded42, 0 xc7ece831,
0 x3f8f95e7, 0 x72df191b, 0 x7580330d,
0 x94074251, 0 x5c7dcdfa, 0 xabbe6d63, 0 xaa402164, 0 xb301d40a,
0 x02e7d1ca, 0 x53571dae, 0 x7a3182a2,
0 x12a8ddec, 0 xfdaa335d, 0 x176f43e8, 0 x71fb46d4, 0 x38129022,
0 xce949ad4, 0 xb84769ad, 0 x965bd862,
0 x82f3d055, 0 x66fb9767, 0 x15b80b4e, 0 x1d5b47a0, 0 x4cfde06f,
0 xc28ec4b8, 0 x57e8726e, 0 x647a78fc,
0 x99865d44, 0 x608bd593, 0 x6c200e03, 0 x39dc5ff6, 0 x5d0b00a3,
0 xae63aff2, 0 x7e8bd632, 0 x70108c0c,
0 xbbd35049, 0 x2998df04, 0 x980cf42a, 0 x9b6df491, 0 x9e7edd53,
0 x06918548, 0 x58cb7e07, 0 x3b74ef2e,
0 x522fffb1, 0 xd24708cc, 0 x1c7e27cd, 0 xa4eb215b, 0 x3cf1d2e2,
0 x19b47a38, 0 x424f7618, 0 x35856039,
0 x9d17dee7, 0 x27eb35e6, 0 xc9aff67b, 0 x36baf5b8, 0 x09c467cd,
0 xc18910b1, 0 xe11dbf7b, 0 x06cd1af8,
0 x7170c608, 0 x2d5e3354, 0 xd4de495a, 0 x64c6d006, 0 xbcc0c62c,
0 x3dd00db3, 0 x708f8f34, 0 x77d51b42,
0 x264f620f, 0 x24b8d2bf, 0 x15c1b79e, 0 x46a52564, 0 xf8d7e54e,
0 x3e378160, 0 x7895cda5, 0 x859c15a5,
0 xe6459788, 0 xc37bc75f, 0 xdb07ba0c, 0 x0676a3ab, 0 x7f229b1e,
0 x31842e7b, 0 x24259fd7, 0 xf8bef472,
0 x835ffcb8, 0 x6df4c1f2, 0 x96f5b195, 0 xfd0af0fc, 0 xb0fe134c,
0 xe2506d3d, 0 x4f9b12ea, 0 xf215f225,
0 xa223736f, 0 x9fb4c428, 0 x25d04979, 0 x34c713f8, 0 xc4618187,
0 xea7a6e98, 0 x7cd16efc, 0 x1436876c,
0 xf1544107, 0 xbedeee14, 0 x56e9af27, 0 xa04aa441, 0 x3cf7c899,
0 x92ecbae6, 0 xdd67016d, 0 x151682eb,
0 xa842eedf, 0 xfdba60b4, 0 xf1907b75, 0 x20e3030f, 0 x24d8c29e,
0 xe139673b, 0 xefa63fb8, 0 x71873054,
0 xb6f2cf3b, 0 x9f326442, 0 xcb15a4cc, 0 xb01a4504, 0 xf1e47d8d,
0 x844a1be5, 0 xbae7dfdc, 0 x42cbda70,
0 xcd7dae0a, 0 x57e85b7a, 0 xd53f5af6, 0 x20cf4d8c, 0 xcea4d428,
0 x79d130a4, 0 x3486ebfb, 0 x33d3cddc,
0 x77853b53, 0 x37effcb5, 0 xc5068778, 0 xe580b3e6, 0 x4e68b8f4,
0 xc5c8b37e, 0 x0d809ea2, 0 x398feb7c,
0 x132a4f94, 0 x43b7950e, 0 x2fee7d1c, 0 x223613bd, 0 xdd06caa2,
0 x37df932b, 0 xc4248289, 0 xacf3ebc3,
0 x5715f6b7, 0 xef3478dd, 0 xf267616f, 0 xc148cbe4, 0 x9052815e,
0 x5e410fab, 0 xb48a2465, 0 x2eda7fa4,
0 xe87b40e4, 0 xe98ea084, 0 x5889e9e1, 0 xefd390fc, 0 xdd07d35b,
0 xdb485694, 0 x38d7e5b2, 0 x57720101,
0 x730edebc, 0 x5b643113, 0 x94917e4f, 0 x503c2fba, 0 x646f1282,
0 x7523d24a, 0 xe0779695, 0 xf9c17a8f,
0 x7a5b2121, 0 xd187b896, 0 x29263a4d, 0 xba510cdf, 0 x81f47c9f,
0 xad1163ed, 0 xea7b5965, 0 x1a00726e,
0 x11403092, 0 x00da6d77, 0 x4a0cdd61, 0 xad1f4603, 0 x605bdfb0,
0 x9eedc364, 0 x22ebe6a8, 0 xcee7d28a,
0 xa0e736a0, 0 x5564a6b9, 0 x10853209, 0 xc7eb8f37, 0 x2de705ca,
0 x8951570f, 0 xdf09822b, 0 xbd691a6c,
0 xaa12e4f2, 0 x87451c0f, 0 xe0f6a27a, 0 x3ada4819, 0 x4cf1764f,
0 x0d771c2b, 0 x67cdb156, 0 x350d8384,
0 x5938fa0f, 0 x42399ef3, 0 x36997b07, 0 x0e84093d, 0 x4aa93e61,
0 x8360d87b, 0 x1fa98b0c, 0 x1149382c,
0 xe97625a5, 0 x0614d1b7, 0 x0e25244b, 0 x0c768347, 0 x589e8d82,
0 x0d2059d1, 0 xa466bb1e, 0 xf8da0a82,
0 x04f19130, 0 xba6e4ec0, 0 x99265164, 0 x1ee7230d, 0 x50b2ad80,
0 xeaee6801, 0 x8db2a283, 0 xea8bf59e
};
#define s1 cast_s1
#define s2 cast_s2
#define s3 cast_s3
#define s4 cast_s4
#define F1(D, m, r) ((I = ((m) + (D))), (I = rol32(I, (r))), \
(((s1[I >> 24 ] ^ s2[(I>>16 )&0 xff]) - s3[(I>>8 )&0 xff]) + s4[I&0 xff]))
#define F2(D, m, r) ((I = ((m) ^ (D))), (I = rol32(I, (r))), \
(((s1[I >> 24 ] - s2[(I>>16 )&0 xff]) + s3[(I>>8 )&0 xff]) ^ s4[I&0 xff]))
#define F3(D, m, r) ((I = ((m) - (D))), (I = rol32(I, (r))), \
(((s1[I >> 24 ] + s2[(I>>16 )&0 xff]) ^ s3[(I>>8 )&0 xff]) - s4[I&0 xff]))
void __cast5_encrypt(struct cast5_ctx *c, u8 *outbuf, const u8 *inbuf)
{
u32 l, r, t;
u32 I; /* used by the Fx macros */
u32 *Km;
u8 *Kr;
Km = c->Km;
Kr = c->Kr;
/* (L0,R0) <-- (m1...m64). (Split the plaintext into left and
* right 32-bit halves L0 = m1...m32 and R0 = m33...m64.)
*/
l = get_unaligned_be32(inbuf);
r = get_unaligned_be32(inbuf + 4 );
/* (16 rounds) for i from 1 to 16, compute Li and Ri as follows:
* Li = Ri-1;
* Ri = Li-1 ^ f(Ri-1,Kmi,Kri), where f is defined in Section 2.2
* Rounds 1, 4, 7, 10, 13, and 16 use f function Type 1.
* Rounds 2, 5, 8, 11, and 14 use f function Type 2.
* Rounds 3, 6, 9, 12, and 15 use f function Type 3.
*/
t = l; l = r; r = t ^ F1(r, Km[0 ], Kr[0 ]);
t = l; l = r; r = t ^ F2(r, Km[1 ], Kr[1 ]);
t = l; l = r; r = t ^ F3(r, Km[2 ], Kr[2 ]);
t = l; l = r; r = t ^ F1(r, Km[3 ], Kr[3 ]);
t = l; l = r; r = t ^ F2(r, Km[4 ], Kr[4 ]);
t = l; l = r; r = t ^ F3(r, Km[5 ], Kr[5 ]);
t = l; l = r; r = t ^ F1(r, Km[6 ], Kr[6 ]);
t = l; l = r; r = t ^ F2(r, Km[7 ], Kr[7 ]);
t = l; l = r; r = t ^ F3(r, Km[8 ], Kr[8 ]);
t = l; l = r; r = t ^ F1(r, Km[9 ], Kr[9 ]);
t = l; l = r; r = t ^ F2(r, Km[10 ], Kr[10 ]);
t = l; l = r; r = t ^ F3(r, Km[11 ], Kr[11 ]);
if (!(c->rr)) {
t = l; l = r; r = t ^ F1(r, Km[12 ], Kr[12 ]);
t = l; l = r; r = t ^ F2(r, Km[13 ], Kr[13 ]);
t = l; l = r; r = t ^ F3(r, Km[14 ], Kr[14 ]);
t = l; l = r; r = t ^ F1(r, Km[15 ], Kr[15 ]);
}
/* c1...c64 <-- (R16,L16). (Exchange final blocks L16, R16 and
* concatenate to form the ciphertext.) */
put_unaligned_be32(r, outbuf);
put_unaligned_be32(l, outbuf + 4 );
}
EXPORT_SYMBOL_GPL(__cast5_encrypt);
static void cast5_encrypt(struct crypto_tfm *tfm, u8 *outbuf, const u8 *inbuf)
{
__cast5_encrypt(crypto_tfm_ctx(tfm), outbuf, inbuf);
}
void __cast5_decrypt(struct cast5_ctx *c, u8 *outbuf, const u8 *inbuf)
{
u32 l, r, t;
u32 I;
u32 *Km;
u8 *Kr;
Km = c->Km;
Kr = c->Kr;
l = get_unaligned_be32(inbuf);
r = get_unaligned_be32(inbuf + 4 );
if (!(c->rr)) {
t = l; l = r; r = t ^ F1(r, Km[15 ], Kr[15 ]);
t = l; l = r; r = t ^ F3(r, Km[14 ], Kr[14 ]);
t = l; l = r; r = t ^ F2(r, Km[13 ], Kr[13 ]);
t = l; l = r; r = t ^ F1(r, Km[12 ], Kr[12 ]);
}
t = l; l = r; r = t ^ F3(r, Km[11 ], Kr[11 ]);
t = l; l = r; r = t ^ F2(r, Km[10 ], Kr[10 ]);
t = l; l = r; r = t ^ F1(r, Km[9 ], Kr[9 ]);
t = l; l = r; r = t ^ F3(r, Km[8 ], Kr[8 ]);
t = l; l = r; r = t ^ F2(r, Km[7 ], Kr[7 ]);
t = l; l = r; r = t ^ F1(r, Km[6 ], Kr[6 ]);
t = l; l = r; r = t ^ F3(r, Km[5 ], Kr[5 ]);
t = l; l = r; r = t ^ F2(r, Km[4 ], Kr[4 ]);
t = l; l = r; r = t ^ F1(r, Km[3 ], Kr[3 ]);
t = l; l = r; r = t ^ F3(r, Km[2 ], Kr[2 ]);
t = l; l = r; r = t ^ F2(r, Km[1 ], Kr[1 ]);
t = l; l = r; r = t ^ F1(r, Km[0 ], Kr[0 ]);
put_unaligned_be32(r, outbuf);
put_unaligned_be32(l, outbuf + 4 );
}
EXPORT_SYMBOL_GPL(__cast5_decrypt);
static void cast5_decrypt(struct crypto_tfm *tfm, u8 *outbuf, const u8 *inbuf)
{
__cast5_decrypt(crypto_tfm_ctx(tfm), outbuf, inbuf);
}
static void key_schedule(u32 *x, u32 *z, u32 *k)
{
#define xi(i) ((x[(i)/4 ] >> (8 *(3 -((i)%4 )))) & 0 xff)
#define zi(i) ((z[(i)/4 ] >> (8 *(3 -((i)%4 )))) & 0 xff)
z[0 ] = x[0 ] ^ s5[xi(13 )] ^ s6[xi(15 )] ^ s7[xi(12 )] ^ sb8[xi(14 )] ^
s7[xi(8 )];
z[1 ] = x[2 ] ^ s5[zi(0 )] ^ s6[zi(2 )] ^ s7[zi(1 )] ^ sb8[zi(3 )] ^
sb8[xi(10 )];
z[2 ] = x[3 ] ^ s5[zi(7 )] ^ s6[zi(6 )] ^ s7[zi(5 )] ^ sb8[zi(4 )] ^
s5[xi(9 )];
z[3 ] = x[1 ] ^ s5[zi(10 )] ^ s6[zi(9 )] ^ s7[zi(11 )] ^ sb8[zi(8 )] ^
s6[xi(11 )];
k[0 ] = s5[zi(8 )] ^ s6[zi(9 )] ^ s7[zi(7 )] ^ sb8[zi(6 )] ^ s5[zi(2 )];
k[1 ] = s5[zi(10 )] ^ s6[zi(11 )] ^ s7[zi(5 )] ^ sb8[zi(4 )] ^
s6[zi(6 )];
k[2 ] = s5[zi(12 )] ^ s6[zi(13 )] ^ s7[zi(3 )] ^ sb8[zi(2 )] ^
s7[zi(9 )];
k[3 ] = s5[zi(14 )] ^ s6[zi(15 )] ^ s7[zi(1 )] ^ sb8[zi(0 )] ^
sb8[zi(12 )];
x[0 ] = z[2 ] ^ s5[zi(5 )] ^ s6[zi(7 )] ^ s7[zi(4 )] ^ sb8[zi(6 )] ^
s7[zi(0 )];
x[1 ] = z[0 ] ^ s5[xi(0 )] ^ s6[xi(2 )] ^ s7[xi(1 )] ^ sb8[xi(3 )] ^
sb8[zi(2 )];
x[2 ] = z[1 ] ^ s5[xi(7 )] ^ s6[xi(6 )] ^ s7[xi(5 )] ^ sb8[xi(4 )] ^
s5[zi(1 )];
x[3 ] = z[3 ] ^ s5[xi(10 )] ^ s6[xi(9 )] ^ s7[xi(11 )] ^ sb8[xi(8 )] ^
s6[zi(3 )];
k[4 ] = s5[xi(3 )] ^ s6[xi(2 )] ^ s7[xi(12 )] ^ sb8[xi(13 )] ^
s5[xi(8 )];
k[5 ] = s5[xi(1 )] ^ s6[xi(0 )] ^ s7[xi(14 )] ^ sb8[xi(15 )] ^
s6[xi(13 )];
k[6 ] = s5[xi(7 )] ^ s6[xi(6 )] ^ s7[xi(8 )] ^ sb8[xi(9 )] ^ s7[xi(3 )];
k[7 ] = s5[xi(5 )] ^ s6[xi(4 )] ^ s7[xi(10 )] ^ sb8[xi(11 )] ^
sb8[xi(7 )];
z[0 ] = x[0 ] ^ s5[xi(13 )] ^ s6[xi(15 )] ^ s7[xi(12 )] ^ sb8[xi(14 )] ^
s7[xi(8 )];
z[1 ] = x[2 ] ^ s5[zi(0 )] ^ s6[zi(2 )] ^ s7[zi(1 )] ^ sb8[zi(3 )] ^
sb8[xi(10 )];
z[2 ] = x[3 ] ^ s5[zi(7 )] ^ s6[zi(6 )] ^ s7[zi(5 )] ^ sb8[zi(4 )] ^
s5[xi(9 )];
z[3 ] = x[1 ] ^ s5[zi(10 )] ^ s6[zi(9 )] ^ s7[zi(11 )] ^ sb8[zi(8 )] ^
s6[xi(11 )];
k[8 ] = s5[zi(3 )] ^ s6[zi(2 )] ^ s7[zi(12 )] ^ sb8[zi(13 )] ^
s5[zi(9 )];
k[9 ] = s5[zi(1 )] ^ s6[zi(0 )] ^ s7[zi(14 )] ^ sb8[zi(15 )] ^
s6[zi(12 )];
k[10 ] = s5[zi(7 )] ^ s6[zi(6 )] ^ s7[zi(8 )] ^ sb8[zi(9 )] ^ s7[zi(2 )];
k[11 ] = s5[zi(5 )] ^ s6[zi(4 )] ^ s7[zi(10 )] ^ sb8[zi(11 )] ^
sb8[zi(6 )];
x[0 ] = z[2 ] ^ s5[zi(5 )] ^ s6[zi(7 )] ^ s7[zi(4 )] ^ sb8[zi(6 )] ^
s7[zi(0 )];
x[1 ] = z[0 ] ^ s5[xi(0 )] ^ s6[xi(2 )] ^ s7[xi(1 )] ^ sb8[xi(3 )] ^
sb8[zi(2 )];
x[2 ] = z[1 ] ^ s5[xi(7 )] ^ s6[xi(6 )] ^ s7[xi(5 )] ^ sb8[xi(4 )] ^
s5[zi(1 )];
x[3 ] = z[3 ] ^ s5[xi(10 )] ^ s6[xi(9 )] ^ s7[xi(11 )] ^ sb8[xi(8 )] ^
s6[zi(3 )];
k[12 ] = s5[xi(8 )] ^ s6[xi(9 )] ^ s7[xi(7 )] ^ sb8[xi(6 )] ^ s5[xi(3 )];
k[13 ] = s5[xi(10 )] ^ s6[xi(11 )] ^ s7[xi(5 )] ^ sb8[xi(4 )] ^
s6[xi(7 )];
k[14 ] = s5[xi(12 )] ^ s6[xi(13 )] ^ s7[xi(3 )] ^ sb8[xi(2 )] ^
s7[xi(8 )];
k[15 ] = s5[xi(14 )] ^ s6[xi(15 )] ^ s7[xi(1 )] ^ sb8[xi(0 )] ^
sb8[xi(13 )];
#undef xi
#undef zi
}
int cast5_setkey(struct crypto_tfm *tfm, const u8 *key, unsigned int key_len)
{
struct cast5_ctx *c = crypto_tfm_ctx(tfm);
int i;
u32 x[4 ];
u32 z[4 ];
u32 k[16 ];
__be32 p_key[4 ];
c->rr = key_len <= 10 ? 1 : 0 ;
memset(p_key, 0 , 16 );
memcpy(p_key, key, key_len);
x[0 ] = be32_to_cpu(p_key[0 ]);
x[1 ] = be32_to_cpu(p_key[1 ]);
x[2 ] = be32_to_cpu(p_key[2 ]);
x[3 ] = be32_to_cpu(p_key[3 ]);
key_schedule(x, z, k);
for (i = 0 ; i < 16 ; i++)
c->Km[i] = k[i];
key_schedule(x, z, k);
for (i = 0 ; i < 16 ; i++)
c->Kr[i] = k[i] & 0 x1f;
return 0 ;
}
EXPORT_SYMBOL_GPL(cast5_setkey);
static struct crypto_alg alg = {
.cra_name = "cast5" ,
.cra_driver_name = "cast5-generic" ,
.cra_priority = 100 ,
.cra_flags = CRYPTO_ALG_TYPE_CIPHER,
.cra_blocksize = CAST5_BLOCK_SIZE,
.cra_ctxsize = sizeof (struct cast5_ctx),
.cra_module = THIS_MODULE,
.cra_u = {
.cipher = {
.cia_min_keysize = CAST5_MIN_KEY_SIZE,
.cia_max_keysize = CAST5_MAX_KEY_SIZE,
.cia_setkey = cast5_setkey,
.cia_encrypt = cast5_encrypt,
.cia_decrypt = cast5_decrypt
}
}
};
static int __init cast5_mod_init(void )
{
return crypto_register_alg(&alg);
}
static void __exit cast5_mod_fini(void )
{
crypto_unregister_alg(&alg);
}
module_init(cast5_mod_init);
module_exit(cast5_mod_fini);
MODULE_LICENSE("GPL" );
MODULE_DESCRIPTION("Cast5 Cipher Algorithm" );
MODULE_ALIAS_CRYPTO("cast5" );
MODULE_ALIAS_CRYPTO("cast5-generic" );
Messung V0.5 in Prozent C=92 H=96 G=93
¤ Dauer der Verarbeitung: 0.18 Sekunden
(vorverarbeitet am 2026-06-07)
¤
*© Formatika GbR, Deutschland