Skip to content

Commit

Permalink
[CRYPTO] api: Fix potential race in crypto_remove_spawn
Browse files Browse the repository at this point in the history
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 <[email protected]>
  • Loading branch information
herbertx committed Nov 23, 2007
1 parent f347c4f commit 38cb241
Showing 1 changed file with 3 additions and 3 deletions.
6 changes: 3 additions & 3 deletions crypto/algapi.c
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,9 @@ static void crypto_remove_spawn(struct crypto_spawn *spawn,
return;

inst->alg.cra_flags |= CRYPTO_ALG_DEAD;
if (hlist_unhashed(&inst->list))
return;

if (!tmpl || !crypto_tmpl_get(tmpl))
return;

Expand Down Expand Up @@ -335,9 +338,6 @@ int crypto_register_instance(struct crypto_template *tmpl,
LIST_HEAD(list);
int err = -EINVAL;

if (inst->alg.cra_destroy)
goto err;

err = crypto_check_alg(&inst->alg);
if (err)
goto err;
Expand Down

0 comments on commit 38cb241

Please sign in to comment.