Commit 57327b08 authored by Laurent Pinchart's avatar Laurent Pinchart Committed by Mauro Carvalho Chehab

media: staging: media: imx: imx7-media-csi: Decouple from imx_media_dma_buf

Decouple from the imx_media_dma_buf structure defined in shared helpers
by duplicating it in the imx7-media-csi driver, along with the two small
alloc and free functions. No functional change intended.
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Acked-by: default avatarRui Miguel Silva <rmfrfs@gmail.com>
Tested-by: default avatarAlexander Stein <alexander.stein@ew.tq-group.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@kernel.org>
parent 0cc432b7
...@@ -184,6 +184,12 @@ to_imx7_csi_vb2_buffer(struct vb2_buffer *vb) ...@@ -184,6 +184,12 @@ to_imx7_csi_vb2_buffer(struct vb2_buffer *vb)
return container_of(vbuf, struct imx7_csi_vb2_buffer, vbuf); return container_of(vbuf, struct imx7_csi_vb2_buffer, vbuf);
} }
struct imx7_csi_dma_buf {
void *virt;
dma_addr_t phys;
unsigned long len;
};
struct imx7_csi { struct imx7_csi {
struct device *dev; struct device *dev;
...@@ -227,7 +233,7 @@ struct imx7_csi { ...@@ -227,7 +233,7 @@ struct imx7_csi {
/* Buffers and streaming state */ /* Buffers and streaming state */
struct imx7_csi_vb2_buffer *active_vb2_buf[2]; struct imx7_csi_vb2_buffer *active_vb2_buf[2];
struct imx_media_dma_buf underrun_buf; struct imx7_csi_dma_buf underrun_buf;
bool is_streaming; bool is_streaming;
int buf_num; int buf_num;
...@@ -415,11 +421,37 @@ static void imx7_csi_dma_unsetup_vb2_buf(struct imx7_csi *csi, ...@@ -415,11 +421,37 @@ static void imx7_csi_dma_unsetup_vb2_buf(struct imx7_csi *csi,
} }
} }
static void imx7_csi_free_dma_buf(struct imx7_csi *csi,
struct imx7_csi_dma_buf *buf)
{
if (buf->virt)
dma_free_coherent(csi->dev, buf->len, buf->virt, buf->phys);
buf->virt = NULL;
buf->phys = 0;
}
static int imx7_csi_alloc_dma_buf(struct imx7_csi *csi,
struct imx7_csi_dma_buf *buf, int size)
{
imx7_csi_free_dma_buf(csi, buf);
buf->len = PAGE_ALIGN(size);
buf->virt = dma_alloc_coherent(csi->dev, buf->len, &buf->phys,
GFP_DMA | GFP_KERNEL);
if (!buf->virt) {
dev_err(csi->dev, "%s: failed\n", __func__);
return -ENOMEM;
}
return 0;
}
static int imx7_csi_dma_setup(struct imx7_csi *csi) static int imx7_csi_dma_setup(struct imx7_csi *csi)
{ {
int ret; int ret;
ret = imx_media_alloc_dma_buf(csi->dev, &csi->underrun_buf, ret = imx7_csi_alloc_dma_buf(csi, &csi->underrun_buf,
csi->vdev_fmt.sizeimage); csi->vdev_fmt.sizeimage);
if (ret < 0) { if (ret < 0) {
v4l2_warn(&csi->sd, "consider increasing the CMA area\n"); v4l2_warn(&csi->sd, "consider increasing the CMA area\n");
...@@ -439,7 +471,7 @@ static void imx7_csi_dma_cleanup(struct imx7_csi *csi, ...@@ -439,7 +471,7 @@ static void imx7_csi_dma_cleanup(struct imx7_csi *csi,
enum vb2_buffer_state return_status) enum vb2_buffer_state return_status)
{ {
imx7_csi_dma_unsetup_vb2_buf(csi, return_status); imx7_csi_dma_unsetup_vb2_buf(csi, return_status);
imx_media_free_dma_buf(csi->dev, &csi->underrun_buf); imx7_csi_free_dma_buf(csi, &csi->underrun_buf);
} }
static void imx7_csi_dma_stop(struct imx7_csi *csi) static void imx7_csi_dma_stop(struct imx7_csi *csi)
......
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