提交 caab9461 编写于 作者: H Herbert Xu

crypto: aead - Add multiple algorithm registration interface

This patch adds the helpers that allow the registration and removal
of multiple algorithms.
Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
上级 43615369
...@@ -896,6 +896,35 @@ void crypto_unregister_aead(struct aead_alg *alg) ...@@ -896,6 +896,35 @@ void crypto_unregister_aead(struct aead_alg *alg)
} }
EXPORT_SYMBOL_GPL(crypto_unregister_aead); EXPORT_SYMBOL_GPL(crypto_unregister_aead);
int crypto_register_aeads(struct aead_alg *algs, int count)
{
int i, ret;
for (i = 0; i < count; i++) {
ret = crypto_register_aead(&algs[i]);
if (ret)
goto err;
}
return 0;
err:
for (--i; i >= 0; --i)
crypto_unregister_aead(&algs[i]);
return ret;
}
EXPORT_SYMBOL_GPL(crypto_register_aeads);
void crypto_unregister_aeads(struct aead_alg *algs, int count)
{
int i;
for (i = count - 1; i >= 0; --i)
crypto_unregister_aead(&algs[i]);
}
EXPORT_SYMBOL_GPL(crypto_unregister_aeads);
int aead_register_instance(struct crypto_template *tmpl, int aead_register_instance(struct crypto_template *tmpl,
struct aead_instance *inst) struct aead_instance *inst)
{ {
......
...@@ -152,6 +152,8 @@ static inline unsigned int crypto_aead_maxauthsize(struct crypto_aead *aead) ...@@ -152,6 +152,8 @@ static inline unsigned int crypto_aead_maxauthsize(struct crypto_aead *aead)
int crypto_register_aead(struct aead_alg *alg); int crypto_register_aead(struct aead_alg *alg);
void crypto_unregister_aead(struct aead_alg *alg); void crypto_unregister_aead(struct aead_alg *alg);
int crypto_register_aeads(struct aead_alg *algs, int count);
void crypto_unregister_aeads(struct aead_alg *algs, int count);
int aead_register_instance(struct crypto_template *tmpl, int aead_register_instance(struct crypto_template *tmpl,
struct aead_instance *inst); struct aead_instance *inst);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册