]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
media: omap3isp: use sgtable-based scatterlist wrappers
authorMarek Szyprowski <m.szyprowski@samsung.com>
Wed, 7 May 2025 16:09:13 +0000 (18:09 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 17 Jul 2025 16:27:39 +0000 (18:27 +0200)
[ Upstream commit 3de572fe2189a4a0bd80295e1f478401e739498e ]

Use common wrappers operating directly on the struct sg_table objects to
fix incorrect use of scatterlists sync calls. dma_sync_sg_for_*()
functions have to be called with the number of elements originally passed
to dma_map_sg_*() function, not the one returned in sgtable's nents.

Fixes: d33186d0be18 ("[media] omap3isp: ccdc: Use the DMA API for LSC")
Fixes: 0e24e90f2ca7 ("[media] omap3isp: stat: Use the DMA API")
CC: stable@vger.kernel.org
Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: Hans Verkuil <hverkuil@xs4all.nl>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/media/platform/omap3isp/ispccdc.c
drivers/media/platform/omap3isp/ispstat.c

index 0fbb2aa6dd2c02be0eca5b31fb5c78c8ca26fb41..6f46e239895323a3d27847469f6fa8c43311ce39 100644 (file)
@@ -446,8 +446,8 @@ static int ccdc_lsc_config(struct isp_ccdc_device *ccdc,
                if (ret < 0)
                        goto done;
 
-               dma_sync_sg_for_cpu(isp->dev, req->table.sgt.sgl,
-                                   req->table.sgt.nents, DMA_TO_DEVICE);
+               dma_sync_sgtable_for_cpu(isp->dev, &req->table.sgt,
+                                        DMA_TO_DEVICE);
 
                if (copy_from_user(req->table.addr, config->lsc,
                                   req->config.size)) {
@@ -455,8 +455,8 @@ static int ccdc_lsc_config(struct isp_ccdc_device *ccdc,
                        goto done;
                }
 
-               dma_sync_sg_for_device(isp->dev, req->table.sgt.sgl,
-                                      req->table.sgt.nents, DMA_TO_DEVICE);
+               dma_sync_sgtable_for_device(isp->dev, &req->table.sgt,
+                                           DMA_TO_DEVICE);
        }
 
        spin_lock_irqsave(&ccdc->lsc.req_lock, flags);
index 5b9b57f4d9bf838db22ca99c162593703bdc8884..e8a1837b1b74f3208e18956bcf9ee3d0bd3483fb 100644 (file)
@@ -161,8 +161,7 @@ static void isp_stat_buf_sync_for_device(struct ispstat *stat,
        if (ISP_STAT_USES_DMAENGINE(stat))
                return;
 
-       dma_sync_sg_for_device(stat->isp->dev, buf->sgt.sgl,
-                              buf->sgt.nents, DMA_FROM_DEVICE);
+       dma_sync_sgtable_for_device(stat->isp->dev, &buf->sgt, DMA_FROM_DEVICE);
 }
 
 static void isp_stat_buf_sync_for_cpu(struct ispstat *stat,
@@ -171,8 +170,7 @@ static void isp_stat_buf_sync_for_cpu(struct ispstat *stat,
        if (ISP_STAT_USES_DMAENGINE(stat))
                return;
 
-       dma_sync_sg_for_cpu(stat->isp->dev, buf->sgt.sgl,
-                           buf->sgt.nents, DMA_FROM_DEVICE);
+       dma_sync_sgtable_for_cpu(stat->isp->dev, &buf->sgt, DMA_FROM_DEVICE);
 }
 
 static void isp_stat_buf_clear(struct ispstat *stat)