crypto: talitos - Simplify key parsing
Use the common helper function crypto_authenc_extractkeys() for key parsing. Cc: Kim Phillips <kim.phillips@freescale.com> Cc: Herbert Xu <herbert@gondor.apana.org.au> Cc: "David S. Miller" <davem@davemloft.net> Signed-off-by: Mathias Krause <mathias.krause@secunet.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
This commit is contained in:
parent
ab827fb399
commit
c306a98d63
@ -671,39 +671,20 @@ static int aead_setkey(struct crypto_aead *authenc,
|
|||||||
const u8 *key, unsigned int keylen)
|
const u8 *key, unsigned int keylen)
|
||||||
{
|
{
|
||||||
struct talitos_ctx *ctx = crypto_aead_ctx(authenc);
|
struct talitos_ctx *ctx = crypto_aead_ctx(authenc);
|
||||||
struct rtattr *rta = (void *)key;
|
struct crypto_authenc_keys keys;
|
||||||
struct crypto_authenc_key_param *param;
|
|
||||||
unsigned int authkeylen;
|
|
||||||
unsigned int enckeylen;
|
|
||||||
|
|
||||||
if (!RTA_OK(rta, keylen))
|
if (crypto_authenc_extractkeys(&keys, key, keylen) != 0)
|
||||||
goto badkey;
|
goto badkey;
|
||||||
|
|
||||||
if (rta->rta_type != CRYPTO_AUTHENC_KEYA_PARAM)
|
if (keys.authkeylen + keys.enckeylen > TALITOS_MAX_KEY_SIZE)
|
||||||
goto badkey;
|
goto badkey;
|
||||||
|
|
||||||
if (RTA_PAYLOAD(rta) < sizeof(*param))
|
memcpy(ctx->key, keys.authkey, keys.authkeylen);
|
||||||
goto badkey;
|
memcpy(&ctx->key[keys.authkeylen], keys.enckey, keys.enckeylen);
|
||||||
|
|
||||||
param = RTA_DATA(rta);
|
ctx->keylen = keys.authkeylen + keys.enckeylen;
|
||||||
enckeylen = be32_to_cpu(param->enckeylen);
|
ctx->enckeylen = keys.enckeylen;
|
||||||
|
ctx->authkeylen = keys.authkeylen;
|
||||||
key += RTA_ALIGN(rta->rta_len);
|
|
||||||
keylen -= RTA_ALIGN(rta->rta_len);
|
|
||||||
|
|
||||||
if (keylen < enckeylen)
|
|
||||||
goto badkey;
|
|
||||||
|
|
||||||
authkeylen = keylen - enckeylen;
|
|
||||||
|
|
||||||
if (keylen > TALITOS_MAX_KEY_SIZE)
|
|
||||||
goto badkey;
|
|
||||||
|
|
||||||
memcpy(&ctx->key, key, keylen);
|
|
||||||
|
|
||||||
ctx->keylen = keylen;
|
|
||||||
ctx->enckeylen = enckeylen;
|
|
||||||
ctx->authkeylen = authkeylen;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user