crypto: cavium/nitrox - Fix 'nitrox_get_first_device()' when ndevlist is fully iterated
authorChristophe JAILLET <christophe.jaillet@wanadoo.fr>
Sat, 30 May 2020 13:35:37 +0000 (15:35 +0200)
committerHerbert Xu <herbert@gondor.apana.org.au>
Thu, 4 Jun 2020 12:06:26 +0000 (22:06 +1000)
When a list is completely iterated with 'list_for_each_entry(x, ...)', x is
not NULL at the end.

While at it, remove a useless initialization of the ndev variable. It
is overridden by 'list_for_each_entry'.

Fixes: f2663872f073 ("crypto: cavium - Register the CNN55XX supported crypto algorithms.")
Cc: <stable@vger.kernel.org>
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
drivers/crypto/cavium/nitrox/nitrox_main.c

index 788c660..cee2a27 100644 (file)
@@ -278,7 +278,7 @@ static void nitrox_remove_from_devlist(struct nitrox_device *ndev)
 
 struct nitrox_device *nitrox_get_first_device(void)
 {
-       struct nitrox_device *ndev = NULL;
+       struct nitrox_device *ndev;
 
        mutex_lock(&devlist_lock);
        list_for_each_entry(ndev, &ndevlist, list) {
@@ -286,7 +286,7 @@ struct nitrox_device *nitrox_get_first_device(void)
                        break;
        }
        mutex_unlock(&devlist_lock);
-       if (!ndev)
+       if (&ndev->list == &ndevlist)
                return NULL;
 
        refcount_inc(&ndev->refcnt);