crypto: sahara - fix error handling in sahara_hw_descriptor_create()
authorOvidiu Panait <ovidiu.panait@windriver.com>
Fri, 1 Dec 2023 17:06:23 +0000 (19:06 +0200)
committerHerbert Xu <herbert@gondor.apana.org.au>
Fri, 8 Dec 2023 03:59:45 +0000 (11:59 +0800)
Do not call dma_unmap_sg() for scatterlists that were not mapped
successfully.

Fixes: 5de8875281e1 ("crypto: sahara - Add driver for SAHARA2 accelerator.")
Signed-off-by: Ovidiu Panait <ovidiu.panait@windriver.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
drivers/crypto/sahara.c

index cbb7153e4162c15de2cd589c717eaf6695685c3a..c4eb66d2e08d027e9184dba59dccdddce7681560 100644 (file)
@@ -483,13 +483,14 @@ static int sahara_hw_descriptor_create(struct sahara_dev *dev)
                         DMA_TO_DEVICE);
        if (!ret) {
                dev_err(dev->device, "couldn't map in sg\n");
-               goto unmap_in;
+               return -EINVAL;
        }
+
        ret = dma_map_sg(dev->device, dev->out_sg, dev->nb_out_sg,
                         DMA_FROM_DEVICE);
        if (!ret) {
                dev_err(dev->device, "couldn't map out sg\n");
-               goto unmap_out;
+               goto unmap_in;
        }
 
        /* Create input links */
@@ -537,9 +538,6 @@ static int sahara_hw_descriptor_create(struct sahara_dev *dev)
 
        return 0;
 
-unmap_out:
-       dma_unmap_sg(dev->device, dev->out_sg, dev->nb_out_sg,
-               DMA_FROM_DEVICE);
 unmap_in:
        dma_unmap_sg(dev->device, dev->in_sg, dev->nb_in_sg,
                DMA_TO_DEVICE);