summaryrefslogtreecommitdiffstats
path: root/crypto/algapi.c
diff options
context:
space:
mode:
authorHerbert Xu <herbert@gondor.apana.org.au>2015-05-11 05:47:39 -0400
committerHerbert Xu <herbert@gondor.apana.org.au>2015-05-12 22:31:25 -0400
commitd6ef2f198d4c9d95b77ee4918b97fc8a53c8a7b7 (patch)
tree4926330410a3ab29a0e2802120d4be77d7175b9f /crypto/algapi.c
parent6499e8cfaa8f5d041b20af24d8409dec9f3ac3d0 (diff)
crypto: api - Add crypto_grab_spawn primitive
This patch adds a new primitive crypto_grab_spawn which is meant to replace crypto_init_spawn and crypto_init_spawn2. Under the new scheme the user no longer has to worry about reference counting the alg object before it is subsumed by the spawn. It is pretty much an exact copy of crypto_grab_aead. Prior to calling this function spawn->frontend and spawn->inst must have been set. Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'crypto/algapi.c')
-rw-r--r--crypto/algapi.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/crypto/algapi.c b/crypto/algapi.c
index 3103e6a1282e..abf100c054e0 100644
--- a/crypto/algapi.c
+++ b/crypto/algapi.c
@@ -612,6 +612,22 @@ out:
612} 612}
613EXPORT_SYMBOL_GPL(crypto_init_spawn2); 613EXPORT_SYMBOL_GPL(crypto_init_spawn2);
614 614
615int crypto_grab_spawn(struct crypto_spawn *spawn, const char *name,
616 u32 type, u32 mask)
617{
618 struct crypto_alg *alg;
619 int err;
620
621 alg = crypto_find_alg(name, spawn->frontend, type, mask);
622 if (IS_ERR(alg))
623 return PTR_ERR(alg);
624
625 err = crypto_init_spawn(spawn, alg, spawn->inst, mask);
626 crypto_mod_put(alg);
627 return err;
628}
629EXPORT_SYMBOL_GPL(crypto_grab_spawn);
630
615void crypto_drop_spawn(struct crypto_spawn *spawn) 631void crypto_drop_spawn(struct crypto_spawn *spawn)
616{ 632{
617 if (!spawn->alg) 633 if (!spawn->alg)