aboutsummaryrefslogtreecommitdiffstats
path: root/crypto
diff options
context:
space:
mode:
authorHerbert Xu <herbert@gondor.apana.org.au>2007-11-17 09:09:38 -0500
committerHerbert Xu <herbert@gondor.apana.org.au>2007-11-23 06:32:09 -0500
commit38cb2419f544ad413c7f7aa8c17fd7377610cdd8 (patch)
treef54bcb1294d2f8dfe87d42cb3603c4dd4ac13d74 /crypto
parentf347c4facfee3d11eb9cd1c070ab471a8fb7401e (diff)
[CRYPTO] api: Fix potential race in crypto_remove_spawn
As it is crypto_remove_spawn may try to unregister an instance which is yet to be registered. This patch fixes this by checking whether the instance has been registered before attempting to remove it. It also removes a bogus cra_destroy check in crypto_register_instance as 1) it's outside the mutex; 2) we have a check in __crypto_register_alg already. Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'crypto')
-rw-r--r--crypto/algapi.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/crypto/algapi.c b/crypto/algapi.c
index 8ff8c2656d9c..8383282de1dd 100644
--- a/crypto/algapi.c
+++ b/crypto/algapi.c
@@ -95,6 +95,9 @@ static void crypto_remove_spawn(struct crypto_spawn *spawn,
95 return; 95 return;
96 96
97 inst->alg.cra_flags |= CRYPTO_ALG_DEAD; 97 inst->alg.cra_flags |= CRYPTO_ALG_DEAD;
98 if (hlist_unhashed(&inst->list))
99 return;
100
98 if (!tmpl || !crypto_tmpl_get(tmpl)) 101 if (!tmpl || !crypto_tmpl_get(tmpl))
99 return; 102 return;
100 103
@@ -335,9 +338,6 @@ int crypto_register_instance(struct crypto_template *tmpl,
335 LIST_HEAD(list); 338 LIST_HEAD(list);
336 int err = -EINVAL; 339 int err = -EINVAL;
337 340
338 if (inst->alg.cra_destroy)
339 goto err;
340
341 err = crypto_check_alg(&inst->alg); 341 err = crypto_check_alg(&inst->alg);
342 if (err) 342 if (err)
343 goto err; 343 goto err;