diff options
author | Herbert Xu <herbert@gondor.apana.org.au> | 2009-06-25 14:46:31 +0800 |
---|---|---|
committer | Herbert Xu <herbert@gondor.apana.org.au> | 2009-06-25 14:46:31 +0800 |
commit | 435578aeaad5859dda8657e3ed2c1a5bc1e524ec (patch) | |
tree | 546a3a613f4656b66d217e49a238961f7e3b2c28 /crypto | |
parent | 409a736336b560798f84d71ad6477c8fad20b523 (diff) | |
download | op-kernel-dev-435578aeaad5859dda8657e3ed2c1a5bc1e524ec.zip op-kernel-dev-435578aeaad5859dda8657e3ed2c1a5bc1e524ec.tar.gz |
crypto: skcipher - Fix request for sync algorithms
When a sync givcipher algorithm is requested, if an async version
of the same algorithm already exists, then we will loop forever
without ever constructing the sync version based on a blkcipher.
This is because we did not include the requested type/mask when
getting a larval for the geniv algorithm that is to be constructed.
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'crypto')
-rw-r--r-- | crypto/ablkcipher.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/crypto/ablkcipher.c b/crypto/ablkcipher.c index e11ce37..43fc8fb 100644 --- a/crypto/ablkcipher.c +++ b/crypto/ablkcipher.c @@ -201,8 +201,9 @@ static int crypto_givcipher_default(struct crypto_alg *alg, u32 type, u32 mask) int err; larval = crypto_larval_lookup(alg->cra_driver_name, + (type & ~CRYPTO_ALG_TYPE_MASK) | CRYPTO_ALG_TYPE_GIVCIPHER, - CRYPTO_ALG_TYPE_MASK); + mask | CRYPTO_ALG_TYPE_MASK); err = PTR_ERR(larval); if (IS_ERR(larval)) goto out; |