Commit b2744dfd authored by Alex Porosanu's avatar Alex Porosanu Committed by Herbert Xu

crypto: caam - fix hash, alg and rng registration if CAAM driver not initialized

If the CAAM driver initialization failed (due to various reasons, e.g. RNG4
initialization failed), then the registration of hash/algorithms/rng shouldn't
take place. This patch adds the necessary code to prevent this registration.
Signed-off-by: default avatarAlex Porosanu <alexandru.porosanu@freescale.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent d5e4e999
...@@ -2209,6 +2209,13 @@ static int __init caam_algapi_init(void) ...@@ -2209,6 +2209,13 @@ static int __init caam_algapi_init(void)
priv = dev_get_drvdata(ctrldev); priv = dev_get_drvdata(ctrldev);
of_node_put(dev_node); of_node_put(dev_node);
/*
* If priv is NULL, it's probably because the caam driver wasn't
* properly initialized (e.g. RNG4 init failed). Thus, bail out here.
*/
if (!priv)
return -ENODEV;
INIT_LIST_HEAD(&priv->alg_list); INIT_LIST_HEAD(&priv->alg_list);
atomic_set(&priv->tfm_count, -1); atomic_set(&priv->tfm_count, -1);
......
...@@ -1833,6 +1833,13 @@ static int __init caam_algapi_hash_init(void) ...@@ -1833,6 +1833,13 @@ static int __init caam_algapi_hash_init(void)
priv = dev_get_drvdata(ctrldev); priv = dev_get_drvdata(ctrldev);
of_node_put(dev_node); of_node_put(dev_node);
/*
* If priv is NULL, it's probably because the caam driver wasn't
* properly initialized (e.g. RNG4 init failed). Thus, bail out here.
*/
if (!priv)
return -ENODEV;
INIT_LIST_HEAD(&priv->hash_list); INIT_LIST_HEAD(&priv->hash_list);
atomic_set(&priv->tfm_count, -1); atomic_set(&priv->tfm_count, -1);
......
...@@ -298,6 +298,13 @@ static int __init caam_rng_init(void) ...@@ -298,6 +298,13 @@ static int __init caam_rng_init(void)
priv = dev_get_drvdata(ctrldev); priv = dev_get_drvdata(ctrldev);
of_node_put(dev_node); of_node_put(dev_node);
/*
* If priv is NULL, it's probably because the caam driver wasn't
* properly initialized (e.g. RNG4 init failed). Thus, bail out here.
*/
if (!priv)
return -ENODEV;
caam_init_rng(&rng_ctx, priv->jrdev[0]); caam_init_rng(&rng_ctx, priv->jrdev[0]);
dev_info(priv->jrdev[0], "registering rng-caam\n"); dev_info(priv->jrdev[0], "registering rng-caam\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment