summaryrefslogtreecommitdiff
path: root/crypto
diff options
context:
space:
mode:
authorHerbert Xu <herbert@gondor.apana.org.au>2025-10-02 17:45:39 +0800
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2025-10-12 12:57:19 +0200
commitc5c703b50e91dd4748769f4c5ab50d9ad60be370 (patch)
tree3a85236308a6924be5d473158c0846117ec635c0 /crypto
parent77dd0e6cb9f9771a6e0bbebbb6cec6f3da1cdbb1 (diff)
crypto: rng - Ensure set_ent is always present
commit c0d36727bf39bb16ef0a67ed608e279535ebf0da upstream. Ensure that set_ent is always set since only drbg provides it. Fixes: 77ebdabe8de7 ("crypto: af_alg - add extra parameters for DRBG interface") Reported-by: Yiqi Sun <sunyiqixm@gmail.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'crypto')
-rw-r--r--crypto/rng.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/crypto/rng.c b/crypto/rng.c
index 9d8804e46422..72da96fdfb5d 100644
--- a/crypto/rng.c
+++ b/crypto/rng.c
@@ -167,6 +167,11 @@ out:
EXPORT_SYMBOL_GPL(crypto_del_default_rng);
#endif
+static void rng_default_set_ent(struct crypto_rng *tfm, const u8 *data,
+ unsigned int len)
+{
+}
+
int crypto_register_rng(struct rng_alg *alg)
{
struct crypto_alg *base = &alg->base;
@@ -178,6 +183,9 @@ int crypto_register_rng(struct rng_alg *alg)
base->cra_flags &= ~CRYPTO_ALG_TYPE_MASK;
base->cra_flags |= CRYPTO_ALG_TYPE_RNG;
+ if (!alg->set_ent)
+ alg->set_ent = rng_default_set_ent;
+
return crypto_register_alg(base);
}
EXPORT_SYMBOL_GPL(crypto_register_rng);