1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef ASM_X86_CAMELLIA_H
3 #define ASM_X86_CAMELLIA_H
4
5 #include <crypto/b128ops.h>
6 #include <linux/crypto.h>
7 #include <linux/kernel.h>
8
9 #define CAMELLIA_MIN_KEY_SIZE 16
10 #define CAMELLIA_MAX_KEY_SIZE 32
11 #define CAMELLIA_BLOCK_SIZE 16
12 #define CAMELLIA_TABLE_BYTE_LEN 272
13 #define CAMELLIA_PARALLEL_BLOCKS 2
14
15 struct crypto_skcipher;
16
17 struct camellia_ctx {
18 u64 key_table[CAMELLIA_TABLE_BYTE_LEN / sizeof(u64)];
19 u32 key_length;
20 };
21
22 extern int __camellia_setkey(struct camellia_ctx *cctx,
23 const unsigned char *key,
24 unsigned int key_len);
25
26 /* regular block cipher functions */
27 asmlinkage void __camellia_enc_blk(const void *ctx, u8 *dst, const u8 *src,
28 bool xor);
29 asmlinkage void camellia_dec_blk(const void *ctx, u8 *dst, const u8 *src);
30
31 /* 2-way parallel cipher functions */
32 asmlinkage void __camellia_enc_blk_2way(const void *ctx, u8 *dst, const u8 *src,
33 bool xor);
34 asmlinkage void camellia_dec_blk_2way(const void *ctx, u8 *dst, const u8 *src);
35
36 /* 16-way parallel cipher functions (avx/aes-ni) */
37 asmlinkage void camellia_ecb_enc_16way(const void *ctx, u8 *dst, const u8 *src);
38 asmlinkage void camellia_ecb_dec_16way(const void *ctx, u8 *dst, const u8 *src);
39
40 asmlinkage void camellia_cbc_dec_16way(const void *ctx, u8 *dst, const u8 *src);
41
camellia_enc_blk(const void * ctx,u8 * dst,const u8 * src)42 static inline void camellia_enc_blk(const void *ctx, u8 *dst, const u8 *src)
43 {
44 __camellia_enc_blk(ctx, dst, src, false);
45 }
46
camellia_enc_blk_xor(const void * ctx,u8 * dst,const u8 * src)47 static inline void camellia_enc_blk_xor(const void *ctx, u8 *dst, const u8 *src)
48 {
49 __camellia_enc_blk(ctx, dst, src, true);
50 }
51
camellia_enc_blk_2way(const void * ctx,u8 * dst,const u8 * src)52 static inline void camellia_enc_blk_2way(const void *ctx, u8 *dst,
53 const u8 *src)
54 {
55 __camellia_enc_blk_2way(ctx, dst, src, false);
56 }
57
camellia_enc_blk_xor_2way(const void * ctx,u8 * dst,const u8 * src)58 static inline void camellia_enc_blk_xor_2way(const void *ctx, u8 *dst,
59 const u8 *src)
60 {
61 __camellia_enc_blk_2way(ctx, dst, src, true);
62 }
63
64 /* glue helpers */
65 extern void camellia_decrypt_cbc_2way(const void *ctx, u8 *dst, const u8 *src);
66
67 #endif /* ASM_X86_CAMELLIA_H */
68