Commit 3bdd23f8 authored by Kees Cook's avatar Kees Cook Committed by Herbert Xu

crypto: xcbc - Remove VLA usage

In the quest to remove all stack VLA usage from the kernel[1], this uses
the maximum blocksize and adds a sanity check. For xcbc, the blocksize
must always be 16, so use that, since it's already being enforced during
instantiation.

[1] https://lkml.kernel.org/r/CA+55aFzCG-zNmZwX4A2FQpadafLfEzK6CC=qPXydAacU1RqZWA@mail.gmail.comSigned-off-by: default avatarKees Cook <keescook@chromium.org>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent 578bdaab
...@@ -57,15 +57,17 @@ struct xcbc_desc_ctx { ...@@ -57,15 +57,17 @@ struct xcbc_desc_ctx {
u8 ctx[]; u8 ctx[];
}; };
#define XCBC_BLOCKSIZE 16
static int crypto_xcbc_digest_setkey(struct crypto_shash *parent, static int crypto_xcbc_digest_setkey(struct crypto_shash *parent,
const u8 *inkey, unsigned int keylen) const u8 *inkey, unsigned int keylen)
{ {
unsigned long alignmask = crypto_shash_alignmask(parent); unsigned long alignmask = crypto_shash_alignmask(parent);
struct xcbc_tfm_ctx *ctx = crypto_shash_ctx(parent); struct xcbc_tfm_ctx *ctx = crypto_shash_ctx(parent);
int bs = crypto_shash_blocksize(parent);
u8 *consts = PTR_ALIGN(&ctx->ctx[0], alignmask + 1); u8 *consts = PTR_ALIGN(&ctx->ctx[0], alignmask + 1);
int err = 0; int err = 0;
u8 key1[bs]; u8 key1[XCBC_BLOCKSIZE];
int bs = sizeof(key1);
if ((err = crypto_cipher_setkey(ctx->child, inkey, keylen))) if ((err = crypto_cipher_setkey(ctx->child, inkey, keylen)))
return err; return err;
...@@ -212,7 +214,7 @@ static int xcbc_create(struct crypto_template *tmpl, struct rtattr **tb) ...@@ -212,7 +214,7 @@ static int xcbc_create(struct crypto_template *tmpl, struct rtattr **tb)
return PTR_ERR(alg); return PTR_ERR(alg);
switch(alg->cra_blocksize) { switch(alg->cra_blocksize) {
case 16: case XCBC_BLOCKSIZE:
break; break;
default: default:
goto out_put_alg; goto out_put_alg;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment