summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHerbert Xu <herbert@gondor.apana.org.au>2016-06-15 22:27:05 +0800
committerHerbert Xu <herbert@gondor.apana.org.au>2016-06-20 19:24:37 +0800
commitb30bdfa86431afbafe15284a3ad5ac19b49b88e3 (patch)
tree05d3353e30ef94880acc1649c55f3198d185bb71
parent88f1d316b9d0a213a9590fb5da6a72c0ec7012de (diff)
downloadlinux-stable-b30bdfa86431afbafe15284a3ad5ac19b49b88e3.tar.gz
linux-stable-b30bdfa86431afbafe15284a3ad5ac19b49b88e3.tar.bz2
linux-stable-b30bdfa86431afbafe15284a3ad5ac19b49b88e3.zip
crypto: gcm - Filter out async ghash if necessary
As it is if you ask for a sync gcm you may actually end up with an async one because it does not filter out async implementations of ghash. This patch fixes this by adding the necessary filter when looking for ghash. Cc: stable@vger.kernel.org Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
-rw-r--r--crypto/gcm.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/crypto/gcm.c b/crypto/gcm.c
index bec329b3de8d..d9ea5f9c0574 100644
--- a/crypto/gcm.c
+++ b/crypto/gcm.c
@@ -639,7 +639,9 @@ static int crypto_gcm_create_common(struct crypto_template *tmpl,
ghash_alg = crypto_find_alg(ghash_name, &crypto_ahash_type,
CRYPTO_ALG_TYPE_HASH,
- CRYPTO_ALG_TYPE_AHASH_MASK);
+ CRYPTO_ALG_TYPE_AHASH_MASK |
+ crypto_requires_sync(algt->type,
+ algt->mask));
if (IS_ERR(ghash_alg))
return PTR_ERR(ghash_alg);