#include <crypto/algapi.h>
#include <linux/init.h>
#include <linux/module.h>
#include <linux/errno.h>
#include <linux/unaligned.h>
#include <linux/types.h>
#include <crypto/serpent.h>
#define PHI …
#define keyiter(a, b, c, d, i, j) …
#define loadkeys(x0, x1, x2, x3, i) …
#define storekeys(x0, x1, x2, x3, i) …
#define store_and_load_keys(x0, x1, x2, x3, s, l) …
#define K(x0, x1, x2, x3, i) …
#define LK(x0, x1, x2, x3, x4, i) …
#define KL(x0, x1, x2, x3, x4, i) …
#define S0(x0, x1, x2, x3, x4) …
#define S1(x0, x1, x2, x3, x4) …
#define S2(x0, x1, x2, x3, x4) …
#define S3(x0, x1, x2, x3, x4) …
#define S4(x0, x1, x2, x3, x4) …
#define S5(x0, x1, x2, x3, x4) …
#define S6(x0, x1, x2, x3, x4) …
#define S7(x0, x1, x2, x3, x4) …
#define SI0(x0, x1, x2, x3, x4) …
#define SI1(x0, x1, x2, x3, x4) …
#define SI2(x0, x1, x2, x3, x4) …
#define SI3(x0, x1, x2, x3, x4) …
#define SI4(x0, x1, x2, x3, x4) …
#define SI5(x0, x1, x2, x3, x4) …
#define SI6(x0, x1, x2, x3, x4) …
#define SI7(x0, x1, x2, x3, x4) …
static noinline void __serpent_setkey_sbox(u32 r0, u32 r1, u32 r2,
u32 r3, u32 r4, u32 *k)
{ … }
int __serpent_setkey(struct serpent_ctx *ctx, const u8 *key,
unsigned int keylen)
{ … }
EXPORT_SYMBOL_GPL(…);
int serpent_setkey(struct crypto_tfm *tfm, const u8 *key, unsigned int keylen)
{ … }
EXPORT_SYMBOL_GPL(…);
void __serpent_encrypt(const void *c, u8 *dst, const u8 *src)
{ … }
EXPORT_SYMBOL_GPL(…);
static void serpent_encrypt(struct crypto_tfm *tfm, u8 *dst, const u8 *src)
{ … }
void __serpent_decrypt(const void *c, u8 *dst, const u8 *src)
{ … }
EXPORT_SYMBOL_GPL(…);
static void serpent_decrypt(struct crypto_tfm *tfm, u8 *dst, const u8 *src)
{ … }
static struct crypto_alg srp_alg = …;
static int __init serpent_mod_init(void)
{ … }
static void __exit serpent_mod_fini(void)
{ … }
subsys_initcall(serpent_mod_init);
module_exit(serpent_mod_fini);
MODULE_LICENSE(…) …;
MODULE_DESCRIPTION(…) …;
MODULE_AUTHOR(…) …;
MODULE_ALIAS_CRYPTO(…) …;
MODULE_ALIAS_CRYPTO(…) …;