]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
crypto: omap - add omap_sham_unregister_algs helper
authorThorsten Blum <thorsten.blum@linux.dev>
Mon, 27 Apr 2026 17:20:20 +0000 (19:20 +0200)
committerHerbert Xu <herbert@gondor.apana.org.au>
Thu, 7 May 2026 08:10:02 +0000 (16:10 +0800)
Add a new helper omap_sham_unregister_algs() and replace two for loops
in omap_sham_probe() and omap_sham_remove(), which also ensure
->registered is reset to 0.

Signed-off-by: Thorsten Blum <thorsten.blum@linux.dev>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
drivers/crypto/omap-sham.c

index b8c416c5ee70e7502d18f0443a48b8161c2a17fb..be1ac640ee592f82037cf1f5764526560d352221 100644 (file)
@@ -2042,6 +2042,20 @@ static struct attribute *omap_sham_attrs[] = {
 };
 ATTRIBUTE_GROUPS(omap_sham);
 
+static void omap_sham_unregister_algs(const struct omap_sham_pdata *pdata)
+{
+       struct omap_sham_algs_info *alg_info;
+       int i;
+
+       for (i = pdata->algs_info_size - 1; i >= 0; i--) {
+               alg_info = &pdata->algs_info[i];
+
+               crypto_engine_unregister_ahashes(alg_info->algs_list,
+                                                alg_info->registered);
+               alg_info->registered = 0;
+       }
+}
+
 static int omap_sham_probe(struct platform_device *pdev)
 {
        struct omap_sham_dev *dd;
@@ -2158,10 +2172,7 @@ static int omap_sham_probe(struct platform_device *pdev)
        return 0;
 
 err_algs:
-       for (i = dd->pdata->algs_info_size - 1; i >= 0; i--)
-               for (j = dd->pdata->algs_info[i].registered - 1; j >= 0; j--)
-                       crypto_engine_unregister_ahash(
-                                       &dd->pdata->algs_info[i].algs_list[j]);
+       omap_sham_unregister_algs(dd->pdata);
 err_engine_start:
        crypto_engine_exit(dd->engine);
 err_engine:
@@ -2182,19 +2193,13 @@ data_err:
 static void omap_sham_remove(struct platform_device *pdev)
 {
        struct omap_sham_dev *dd;
-       int i, j;
 
        dd = platform_get_drvdata(pdev);
 
        spin_lock_bh(&sham.lock);
        list_del(&dd->list);
        spin_unlock_bh(&sham.lock);
-       for (i = dd->pdata->algs_info_size - 1; i >= 0; i--)
-               for (j = dd->pdata->algs_info[i].registered - 1; j >= 0; j--) {
-                       crypto_engine_unregister_ahash(
-                                       &dd->pdata->algs_info[i].algs_list[j]);
-                       dd->pdata->algs_info[i].registered--;
-               }
+       omap_sham_unregister_algs(dd->pdata);
        cancel_work_sync(&dd->done_task);
        pm_runtime_dont_use_autosuspend(&pdev->dev);
        pm_runtime_disable(&pdev->dev);