diff options
author | Herbert Xu <herbert@gondor.apana.org.au> | 2008-09-13 21:19:03 -0400 |
---|---|---|
committer | Herbert Xu <herbert@gondor.apana.org.au> | 2008-12-24 19:01:23 -0500 |
commit | 4a7794860ba2b56693b1d89fd485fd08cdc763e3 (patch) | |
tree | d97f46fe980ac79e226b429a61c5328fae9bf882 /crypto/api.c | |
parent | 2566578a6feb9d9e39da41326afe8ed6022db3c5 (diff) |
crypto: api - Move type exit function into crypto_tfm
The type exit function needs to undo any allocations done by the type
init function. However, the type init function may differ depending
on the upper-level type of the transform (e.g., a crypto_blkcipher
instantiated as a crypto_ablkcipher).
So we need to move the exit function out of the lower-level
structure and into crypto_tfm itself.
As it stands this is a no-op since nobody uses exit functions at
all. However, all cases where a lower-level type is instantiated
as a different upper-level type (such as blkcipher as ablkcipher)
will be converted such that they allocate the underlying transform
and use that instead of casting (e.g., crypto_ablkcipher casted
into crypto_blkcipher). That will need to use a different exit
function depending on the upper-level type.
This patch also allows the type init/exit functions to call (or not)
cra_init/cra_exit instead of always calling them from the top level.
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'crypto/api.c')
-rw-r--r-- | crypto/api.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/crypto/api.c b/crypto/api.c index 0444d242e985..cbaaf346ad13 100644 --- a/crypto/api.c +++ b/crypto/api.c | |||
@@ -300,8 +300,8 @@ static void crypto_exit_ops(struct crypto_tfm *tfm) | |||
300 | const struct crypto_type *type = tfm->__crt_alg->cra_type; | 300 | const struct crypto_type *type = tfm->__crt_alg->cra_type; |
301 | 301 | ||
302 | if (type) { | 302 | if (type) { |
303 | if (type->exit) | 303 | if (tfm->exit) |
304 | type->exit(tfm); | 304 | tfm->exit(tfm); |
305 | return; | 305 | return; |
306 | } | 306 | } |
307 | 307 | ||
@@ -379,17 +379,16 @@ struct crypto_tfm *__crypto_alloc_tfm(struct crypto_alg *alg, u32 type, | |||
379 | if (err) | 379 | if (err) |
380 | goto out_free_tfm; | 380 | goto out_free_tfm; |
381 | 381 | ||
382 | if (alg->cra_init && (err = alg->cra_init(tfm))) { | 382 | if (!tfm->exit && alg->cra_init && (err = alg->cra_init(tfm))) |
383 | if (err == -EAGAIN) | ||
384 | crypto_shoot_alg(alg); | ||
385 | goto cra_init_failed; | 383 | goto cra_init_failed; |
386 | } | ||
387 | 384 | ||
388 | goto out; | 385 | goto out; |
389 | 386 | ||
390 | cra_init_failed: | 387 | cra_init_failed: |
391 | crypto_exit_ops(tfm); | 388 | crypto_exit_ops(tfm); |
392 | out_free_tfm: | 389 | out_free_tfm: |
390 | if (err == -EAGAIN) | ||
391 | crypto_shoot_alg(alg); | ||
393 | kfree(tfm); | 392 | kfree(tfm); |
394 | out_err: | 393 | out_err: |
395 | tfm = ERR_PTR(err); | 394 | tfm = ERR_PTR(err); |
@@ -469,7 +468,7 @@ void crypto_free_tfm(struct crypto_tfm *tfm) | |||
469 | alg = tfm->__crt_alg; | 468 | alg = tfm->__crt_alg; |
470 | size = sizeof(*tfm) + alg->cra_ctxsize; | 469 | size = sizeof(*tfm) + alg->cra_ctxsize; |
471 | 470 | ||
472 | if (alg->cra_exit) | 471 | if (!tfm->exit && alg->cra_exit) |
473 | alg->cra_exit(tfm); | 472 | alg->cra_exit(tfm); |
474 | crypto_exit_ops(tfm); | 473 | crypto_exit_ops(tfm); |
475 | crypto_mod_put(alg); | 474 | crypto_mod_put(alg); |