summaryrefslogtreecommitdiffstats
path: root/include/media
diff options
context:
space:
mode:
authorYunke Cao <yunkec@chromium.org>2024-08-14 04:06:43 +0200
committerHans Verkuil <hverkuil-cisco@xs4all.nl>2024-08-14 10:05:32 +0200
commit03a979b74dc1ad5aeed8026a84d8771842cb1631 (patch)
tree2b0b11358f539afb70f3f255c4a1cd8fedd5d9c7 /include/media
parentmedia: videobuf2-core: reverse the iteration order in __vb2_buf_dmabuf_put (diff)
downloadlinux-03a979b74dc1ad5aeed8026a84d8771842cb1631.tar.xz
linux-03a979b74dc1ad5aeed8026a84d8771842cb1631.zip
media: videobuf2-core: attach once if multiple planes share the same dbuf
When multiple planes use the same dma buf, each plane will have its own dma buf attachment and mapping. It is a waste of IOVA space. This patch adds a dbuf_duplicated boolean in vb2_plane. If a plane's dbuf is the same as an existing plane, do not create another attachment and mapping. Signed-off-by: Yunke Cao <yunkec@chromium.org> Acked-by: Tomasz Figa <tfiga@chromium.org> Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Diffstat (limited to 'include/media')
-rw-r--r--include/media/videobuf2-core.h3
1 files changed, 3 insertions, 0 deletions
diff --git a/include/media/videobuf2-core.h b/include/media/videobuf2-core.h
index 955237ac503d..9b02aeba4108 100644
--- a/include/media/videobuf2-core.h
+++ b/include/media/videobuf2-core.h
@@ -154,6 +154,8 @@ struct vb2_mem_ops {
* @mem_priv: private data with this plane.
* @dbuf: dma_buf - shared buffer object.
* @dbuf_mapped: flag to show whether dbuf is mapped or not
+ * @dbuf_duplicated: boolean to show whether dbuf is duplicated with a
+ * previous plane of the buffer.
* @bytesused: number of bytes occupied by data in the plane (payload).
* @length: size of this plane (NOT the payload) in bytes. The maximum
* valid size is MAX_UINT - PAGE_SIZE.
@@ -179,6 +181,7 @@ struct vb2_plane {
void *mem_priv;
struct dma_buf *dbuf;
unsigned int dbuf_mapped;
+ bool dbuf_duplicated;
unsigned int bytesused;
unsigned int length;
unsigned int min_length;