diff options
Diffstat (limited to 'arch/x86/crypto/cast6_avx_glue.c')
-rw-r--r-- | arch/x86/crypto/cast6_avx_glue.c | 91 |
1 files changed, 51 insertions, 40 deletions
diff --git a/arch/x86/crypto/cast6_avx_glue.c b/arch/x86/crypto/cast6_avx_glue.c index 92f7ca24790a..8d0dfb86a559 100644 --- a/arch/x86/crypto/cast6_avx_glue.c +++ b/arch/x86/crypto/cast6_avx_glue.c | |||
@@ -4,6 +4,8 @@ | |||
4 | * Copyright (C) 2012 Johannes Goetzfried | 4 | * Copyright (C) 2012 Johannes Goetzfried |
5 | * <Johannes.Goetzfried@informatik.stud.uni-erlangen.de> | 5 | * <Johannes.Goetzfried@informatik.stud.uni-erlangen.de> |
6 | * | 6 | * |
7 | * Copyright © 2013 Jussi Kivilinna <jussi.kivilinna@iki.fi> | ||
8 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | 9 | * This program is free software; you can redistribute it and/or modify |
8 | * it under the terms of the GNU General Public License as published by | 10 | * it under the terms of the GNU General Public License as published by |
9 | * the Free Software Foundation; either version 2 of the License, or | 11 | * the Free Software Foundation; either version 2 of the License, or |
@@ -50,6 +52,23 @@ asmlinkage void cast6_cbc_dec_8way(struct cast6_ctx *ctx, u8 *dst, | |||
50 | asmlinkage void cast6_ctr_8way(struct cast6_ctx *ctx, u8 *dst, const u8 *src, | 52 | asmlinkage void cast6_ctr_8way(struct cast6_ctx *ctx, u8 *dst, const u8 *src, |
51 | le128 *iv); | 53 | le128 *iv); |
52 | 54 | ||
55 | asmlinkage void cast6_xts_enc_8way(struct cast6_ctx *ctx, u8 *dst, | ||
56 | const u8 *src, le128 *iv); | ||
57 | asmlinkage void cast6_xts_dec_8way(struct cast6_ctx *ctx, u8 *dst, | ||
58 | const u8 *src, le128 *iv); | ||
59 | |||
60 | static void cast6_xts_enc(void *ctx, u128 *dst, const u128 *src, le128 *iv) | ||
61 | { | ||
62 | glue_xts_crypt_128bit_one(ctx, dst, src, iv, | ||
63 | GLUE_FUNC_CAST(__cast6_encrypt)); | ||
64 | } | ||
65 | |||
66 | static void cast6_xts_dec(void *ctx, u128 *dst, const u128 *src, le128 *iv) | ||
67 | { | ||
68 | glue_xts_crypt_128bit_one(ctx, dst, src, iv, | ||
69 | GLUE_FUNC_CAST(__cast6_decrypt)); | ||
70 | } | ||
71 | |||
53 | static void cast6_crypt_ctr(void *ctx, u128 *dst, const u128 *src, le128 *iv) | 72 | static void cast6_crypt_ctr(void *ctx, u128 *dst, const u128 *src, le128 *iv) |
54 | { | 73 | { |
55 | be128 ctrblk; | 74 | be128 ctrblk; |
@@ -87,6 +106,19 @@ static const struct common_glue_ctx cast6_ctr = { | |||
87 | } } | 106 | } } |
88 | }; | 107 | }; |
89 | 108 | ||
109 | static const struct common_glue_ctx cast6_enc_xts = { | ||
110 | .num_funcs = 2, | ||
111 | .fpu_blocks_limit = CAST6_PARALLEL_BLOCKS, | ||
112 | |||
113 | .funcs = { { | ||
114 | .num_blocks = CAST6_PARALLEL_BLOCKS, | ||
115 | .fn_u = { .xts = GLUE_XTS_FUNC_CAST(cast6_xts_enc_8way) } | ||
116 | }, { | ||
117 | .num_blocks = 1, | ||
118 | .fn_u = { .xts = GLUE_XTS_FUNC_CAST(cast6_xts_enc) } | ||
119 | } } | ||
120 | }; | ||
121 | |||
90 | static const struct common_glue_ctx cast6_dec = { | 122 | static const struct common_glue_ctx cast6_dec = { |
91 | .num_funcs = 2, | 123 | .num_funcs = 2, |
92 | .fpu_blocks_limit = CAST6_PARALLEL_BLOCKS, | 124 | .fpu_blocks_limit = CAST6_PARALLEL_BLOCKS, |
@@ -113,6 +145,19 @@ static const struct common_glue_ctx cast6_dec_cbc = { | |||
113 | } } | 145 | } } |
114 | }; | 146 | }; |
115 | 147 | ||
148 | static const struct common_glue_ctx cast6_dec_xts = { | ||
149 | .num_funcs = 2, | ||
150 | .fpu_blocks_limit = CAST6_PARALLEL_BLOCKS, | ||
151 | |||
152 | .funcs = { { | ||
153 | .num_blocks = CAST6_PARALLEL_BLOCKS, | ||
154 | .fn_u = { .xts = GLUE_XTS_FUNC_CAST(cast6_xts_dec_8way) } | ||
155 | }, { | ||
156 | .num_blocks = 1, | ||
157 | .fn_u = { .xts = GLUE_XTS_FUNC_CAST(cast6_xts_dec) } | ||
158 | } } | ||
159 | }; | ||
160 | |||
116 | static int ecb_encrypt(struct blkcipher_desc *desc, struct scatterlist *dst, | 161 | static int ecb_encrypt(struct blkcipher_desc *desc, struct scatterlist *dst, |
117 | struct scatterlist *src, unsigned int nbytes) | 162 | struct scatterlist *src, unsigned int nbytes) |
118 | { | 163 | { |
@@ -307,54 +352,20 @@ static int xts_encrypt(struct blkcipher_desc *desc, struct scatterlist *dst, | |||
307 | struct scatterlist *src, unsigned int nbytes) | 352 | struct scatterlist *src, unsigned int nbytes) |
308 | { | 353 | { |
309 | struct cast6_xts_ctx *ctx = crypto_blkcipher_ctx(desc->tfm); | 354 | struct cast6_xts_ctx *ctx = crypto_blkcipher_ctx(desc->tfm); |
310 | be128 buf[CAST6_PARALLEL_BLOCKS]; | ||
311 | struct crypt_priv crypt_ctx = { | ||
312 | .ctx = &ctx->crypt_ctx, | ||
313 | .fpu_enabled = false, | ||
314 | }; | ||
315 | struct xts_crypt_req req = { | ||
316 | .tbuf = buf, | ||
317 | .tbuflen = sizeof(buf), | ||
318 | 355 | ||
319 | .tweak_ctx = &ctx->tweak_ctx, | 356 | return glue_xts_crypt_128bit(&cast6_enc_xts, desc, dst, src, nbytes, |
320 | .tweak_fn = XTS_TWEAK_CAST(__cast6_encrypt), | 357 | XTS_TWEAK_CAST(__cast6_encrypt), |
321 | .crypt_ctx = &crypt_ctx, | 358 | &ctx->tweak_ctx, &ctx->crypt_ctx); |
322 | .crypt_fn = encrypt_callback, | ||
323 | }; | ||
324 | int ret; | ||
325 | |||
326 | desc->flags &= ~CRYPTO_TFM_REQ_MAY_SLEEP; | ||
327 | ret = xts_crypt(desc, dst, src, nbytes, &req); | ||
328 | cast6_fpu_end(crypt_ctx.fpu_enabled); | ||
329 | |||
330 | return ret; | ||
331 | } | 359 | } |
332 | 360 | ||
333 | static int xts_decrypt(struct blkcipher_desc *desc, struct scatterlist *dst, | 361 | static int xts_decrypt(struct blkcipher_desc *desc, struct scatterlist *dst, |
334 | struct scatterlist *src, unsigned int nbytes) | 362 | struct scatterlist *src, unsigned int nbytes) |
335 | { | 363 | { |
336 | struct cast6_xts_ctx *ctx = crypto_blkcipher_ctx(desc->tfm); | 364 | struct cast6_xts_ctx *ctx = crypto_blkcipher_ctx(desc->tfm); |
337 | be128 buf[CAST6_PARALLEL_BLOCKS]; | ||
338 | struct crypt_priv crypt_ctx = { | ||
339 | .ctx = &ctx->crypt_ctx, | ||
340 | .fpu_enabled = false, | ||
341 | }; | ||
342 | struct xts_crypt_req req = { | ||
343 | .tbuf = buf, | ||
344 | .tbuflen = sizeof(buf), | ||
345 | |||
346 | .tweak_ctx = &ctx->tweak_ctx, | ||
347 | .tweak_fn = XTS_TWEAK_CAST(__cast6_encrypt), | ||
348 | .crypt_ctx = &crypt_ctx, | ||
349 | .crypt_fn = decrypt_callback, | ||
350 | }; | ||
351 | int ret; | ||
352 | 365 | ||
353 | desc->flags &= ~CRYPTO_TFM_REQ_MAY_SLEEP; | 366 | return glue_xts_crypt_128bit(&cast6_dec_xts, desc, dst, src, nbytes, |
354 | ret = xts_crypt(desc, dst, src, nbytes, &req); | 367 | XTS_TWEAK_CAST(__cast6_encrypt), |
355 | cast6_fpu_end(crypt_ctx.fpu_enabled); | 368 | &ctx->tweak_ctx, &ctx->crypt_ctx); |
356 | |||
357 | return ret; | ||
358 | } | 369 | } |
359 | 370 | ||
360 | static struct crypto_alg cast6_algs[10] = { { | 371 | static struct crypto_alg cast6_algs[10] = { { |