diff options
Diffstat (limited to 'crypto/kpp.c')
| -rw-r--r-- | crypto/kpp.c | 29 | 
1 files changed, 29 insertions, 0 deletions
diff --git a/crypto/kpp.c b/crypto/kpp.c index 313b2c699963..7aa6ba4b60a4 100644 --- a/crypto/kpp.c +++ b/crypto/kpp.c @@ -68,9 +68,17 @@ static int crypto_kpp_init_tfm(struct crypto_tfm *tfm)  	return 0;  } +static void crypto_kpp_free_instance(struct crypto_instance *inst) +{ +	struct kpp_instance *kpp = kpp_instance(inst); + +	kpp->free(kpp); +} +  static const struct crypto_type crypto_kpp_type = {  	.extsize = crypto_alg_extsize,  	.init_tfm = crypto_kpp_init_tfm, +	.free = crypto_kpp_free_instance,  #ifdef CONFIG_PROC_FS  	.show = crypto_kpp_show,  #endif @@ -87,6 +95,15 @@ struct crypto_kpp *crypto_alloc_kpp(const char *alg_name, u32 type, u32 mask)  }  EXPORT_SYMBOL_GPL(crypto_alloc_kpp); +int crypto_grab_kpp(struct crypto_kpp_spawn *spawn, +		    struct crypto_instance *inst, +		    const char *name, u32 type, u32 mask) +{ +	spawn->base.frontend = &crypto_kpp_type; +	return crypto_grab_spawn(&spawn->base, inst, name, type, mask); +} +EXPORT_SYMBOL_GPL(crypto_grab_kpp); +  static void kpp_prepare_alg(struct kpp_alg *alg)  {  	struct crypto_alg *base = &alg->base; @@ -111,5 +128,17 @@ void crypto_unregister_kpp(struct kpp_alg *alg)  }  EXPORT_SYMBOL_GPL(crypto_unregister_kpp); +int kpp_register_instance(struct crypto_template *tmpl, +			  struct kpp_instance *inst) +{ +	if (WARN_ON(!inst->free)) +		return -EINVAL; + +	kpp_prepare_alg(&inst->alg); + +	return crypto_register_instance(tmpl, kpp_crypto_instance(inst)); +} +EXPORT_SYMBOL_GPL(kpp_register_instance); +  MODULE_LICENSE("GPL");  MODULE_DESCRIPTION("Key-agreement Protocol Primitives");  |