From: Steffen Klassert Subject: [PATCH v2 03/15] crypto: Add a report function pointer to crypto_type Date: Wed, 17 Aug 2011 14:10:48 +0200 Message-ID: <20110817121048.GA16877@secunet.com> References: <20110817120859.GX16877@secunet.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: linux-crypto@vger.kernel.org To: Herbert Xu Return-path: Received: from a.mx.secunet.com ([195.81.216.161]:41238 "EHLO a.mx.secunet.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752390Ab1HQMJ4 (ORCPT ); Wed, 17 Aug 2011 08:09:56 -0400 Content-Disposition: inline In-Reply-To: <20110817120859.GX16877@secunet.com> Sender: linux-crypto-owner@vger.kernel.org List-ID: We add a report function pointer to struct crypto_type. This function pointer is used from the crypto userspace configuration API to report crypto algorithms to userspace. Signed-off-by: Steffen Klassert --- crypto/crypto_user.c | 8 ++++++++ include/crypto/algapi.h | 2 ++ 2 files changed, 10 insertions(+), 0 deletions(-) diff --git a/crypto/crypto_user.c b/crypto/crypto_user.c index 4edd015..cb3a722 100644 --- a/crypto/crypto_user.c +++ b/crypto/crypto_user.c @@ -81,7 +81,15 @@ static int crypto_report_one(struct crypto_alg *alg, rb->priority = alg->cra_priority; rb->refcnt = atomic_read(&alg->cra_refcnt); + if (alg->cra_type && alg->cra_type->report) { + if (alg->cra_type->report(skb, alg)) + goto nla_put_failure; + } + return 0; + +nla_put_failure: + return -EMSGSIZE; } static int crypto_report_alg(struct crypto_alg *alg, diff --git a/include/crypto/algapi.h b/include/crypto/algapi.h index 59c3e5b..ecc721d 100644 --- a/include/crypto/algapi.h +++ b/include/crypto/algapi.h @@ -15,6 +15,7 @@ #include #include #include +#include struct module; struct rtattr; @@ -26,6 +27,7 @@ struct crypto_type { int (*init)(struct crypto_tfm *tfm, u32 type, u32 mask); int (*init_tfm)(struct crypto_tfm *tfm); void (*show)(struct seq_file *m, struct crypto_alg *alg); + int (*report)(struct sk_buff *skb, struct crypto_alg *alg); struct crypto_alg *(*lookup)(const char *name, u32 type, u32 mask); unsigned int type; -- 1.7.0.4