All of lore.kernel.org
 help / color / mirror / Atom feed
From: Hans Verkuil <hverkuil-cisco@xs4all.nl>
To: Benjamin Gaignard <benjamin.gaignard@collabora.com>,
	mchehab@kernel.org, tfiga@chromium.org, m.szyprowski@samsung.com,
	ming.qian@nxp.com, ezequiel@vanguardiasur.com.ar,
	p.zabel@pengutronix.de, gregkh@linuxfoundation.org,
	nicolas.dufresne@collabora.com
Cc: linux-media@vger.kernel.org, linux-kernel@vger.kernel.org,
	linux-arm-kernel@lists.infradead.org,
	linux-mediatek@lists.infradead.org,
	linux-arm-msm@vger.kernel.org,
	linux-rockchip@lists.infradead.org,
	linux-staging@lists.linux.dev, kernel@collabora.com
Subject: Re: [PATCH v9 01/53] media: videobuf2: Rework offset 'cookie' encoding pattern
Date: Mon, 2 Oct 2023 15:46:07 +0200	[thread overview]
Message-ID: <08636b49-9022-4361-96d2-574de2548ab0@xs4all.nl> (raw)
In-Reply-To: <20231002120617.119602-2-benjamin.gaignard@collabora.com>

On 02/10/2023 14:05, Benjamin Gaignard wrote:
> Change how offset 'cookie' field value is computed to make possible
> to use more buffers.
> The maximum number of buffers depends of PAGE_SHIFT value and can
> go up to 0x7fff when PAGE_SHIFT = 12.
> With this encoding pattern we know the maximum number that a queue
> could store so we can check it at  queue init time.
> It also make easier and faster to find buffer and plane from using
> the offset field.
> Change __find_plane_by_offset() prototype to return the video buffer
> itself rather than it index.
> 
> Signed-off-by: Benjamin Gaignard <benjamin.gaignard@collabora.com>
> ---
> changes in version 9:
> - BUFFER_INDEX_MASK now depends on PAGE_SHIFT value to match
>   architectures requirements.
> 
>  .../media/common/videobuf2/videobuf2-core.c   | 71 +++++++++----------
>  1 file changed, 32 insertions(+), 39 deletions(-)
> 
> diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c
> index cf6727d9c81f..a0540b2e461f 100644
> --- a/drivers/media/common/videobuf2/videobuf2-core.c
> +++ b/drivers/media/common/videobuf2/videobuf2-core.c
> @@ -31,6 +31,10 @@
>  
>  #include <trace/events/vb2.h>
>  
> +#define PLANE_INDEX_SHIFT	(PAGE_SHIFT + 3)
> +#define PLANE_INDEX_MASK	0x7
> +#define BUFFER_INDEX_MASK	(BIT_MASK(30 - PLANE_INDEX_SHIFT) - 1)
> +
>  static int debug;
>  module_param(debug, int, 0644);
>  
> @@ -358,21 +362,24 @@ static void __setup_offsets(struct vb2_buffer *vb)
>  	unsigned int plane;
>  	unsigned long off = 0;
>  
> -	if (vb->index) {
> -		struct vb2_buffer *prev = q->bufs[vb->index - 1];
> -		struct vb2_plane *p = &prev->planes[prev->num_planes - 1];
> -
> -		off = PAGE_ALIGN(p->m.offset + p->length);
> -	}
> +	/*
> +	 * Offsets cookies value have the following constraints:
> +	 * - a buffer could have up to 8 planes.

could -> can

> +	 * - v4l2 mem2mem use bit 30 to distinguish between source and destination buffers.

use -> uses

> +	 * - must be page aligned
> +	 * That led to this bit mapping when PAGE_SHIFT = 12:
> +	 * |30                |29        15|14       12|11 0|
> +	 * |DST_QUEUE_OFF_BASE|buffer index|plane index| 0  |
> +	 * where there are 15 bits to store buffer index.

buffer index -> the buffer index

> +	 * Depending on PAGE_SHIFT value we can have else bits to store buffer index.

else bits? You probably mean "fewer bits".

buffer index -> the buffer index

> +	 */
> +	off = vb->index << PLANE_INDEX_SHIFT;
>  
>  	for (plane = 0; plane < vb->num_planes; ++plane) {
> -		vb->planes[plane].m.offset = off;
> +		vb->planes[plane].m.offset = off + (plane << PAGE_SHIFT);
>  
>  		dprintk(q, 3, "buffer %d, plane %d offset 0x%08lx\n",
>  				vb->index, plane, off);
> -
> -		off += vb->planes[plane].length;
> -		off = PAGE_ALIGN(off);
>  	}
>  }

Regards,

	Hans

>  
> @@ -2185,13 +2192,12 @@ int vb2_core_streamoff(struct vb2_queue *q, unsigned int type)
>  EXPORT_SYMBOL_GPL(vb2_core_streamoff);
>  
>  /*
> - * __find_plane_by_offset() - find plane associated with the given offset off
> + * __find_plane_by_offset() - find video buffer and plane associated with the given offset off
>   */
>  static int __find_plane_by_offset(struct vb2_queue *q, unsigned long off,
> -			unsigned int *_buffer, unsigned int *_plane)
> +			struct vb2_buffer **vb, unsigned int *plane)
>  {
> -	struct vb2_buffer *vb;
> -	unsigned int buffer, plane;
> +	unsigned int buffer;
>  
>  	/*
>  	 * Sanity checks to ensure the lock is held, MEMORY_MMAP is
> @@ -2209,24 +2215,15 @@ static int __find_plane_by_offset(struct vb2_queue *q, unsigned long off,
>  		return -EBUSY;
>  	}
>  
> -	/*
> -	 * Go over all buffers and their planes, comparing the given offset
> -	 * with an offset assigned to each plane. If a match is found,
> -	 * return its buffer and plane numbers.
> -	 */
> -	for (buffer = 0; buffer < q->num_buffers; ++buffer) {
> -		vb = q->bufs[buffer];
> +	/* Get buffer and plane from the offset */
> +	buffer = (off >> PLANE_INDEX_SHIFT) & BUFFER_INDEX_MASK;
> +	*plane = (off >> PAGE_SHIFT) & PLANE_INDEX_MASK;
>  
> -		for (plane = 0; plane < vb->num_planes; ++plane) {
> -			if (vb->planes[plane].m.offset == off) {
> -				*_buffer = buffer;
> -				*_plane = plane;
> -				return 0;
> -			}
> -		}
> -	}
> +	if (buffer >= q->num_buffers || *plane >= q->bufs[buffer]->num_planes)
> +		return -EINVAL;
>  
> -	return -EINVAL;
> +	*vb = q->bufs[buffer];
> +	return 0;
>  }
>  
>  int vb2_core_expbuf(struct vb2_queue *q, int *fd, unsigned int type,
> @@ -2306,7 +2303,7 @@ int vb2_mmap(struct vb2_queue *q, struct vm_area_struct *vma)
>  {
>  	unsigned long off = vma->vm_pgoff << PAGE_SHIFT;
>  	struct vb2_buffer *vb;
> -	unsigned int buffer = 0, plane = 0;
> +	unsigned int plane = 0;
>  	int ret;
>  	unsigned long length;
>  
> @@ -2335,12 +2332,10 @@ int vb2_mmap(struct vb2_queue *q, struct vm_area_struct *vma)
>  	 * Find the plane corresponding to the offset passed by userspace. This
>  	 * will return an error if not MEMORY_MMAP or file I/O is in progress.
>  	 */
> -	ret = __find_plane_by_offset(q, off, &buffer, &plane);
> +	ret = __find_plane_by_offset(q, off, &vb, &plane);
>  	if (ret)
>  		goto unlock;
>  
> -	vb = q->bufs[buffer];
> -
>  	/*
>  	 * MMAP requires page_aligned buffers.
>  	 * The buffer length was page_aligned at __vb2_buf_mem_alloc(),
> @@ -2368,7 +2363,7 @@ int vb2_mmap(struct vb2_queue *q, struct vm_area_struct *vma)
>  	if (ret)
>  		return ret;
>  
> -	dprintk(q, 3, "buffer %d, plane %d successfully mapped\n", buffer, plane);
> +	dprintk(q, 3, "buffer %u, plane %d successfully mapped\n", vb->index, plane);
>  	return 0;
>  }
>  EXPORT_SYMBOL_GPL(vb2_mmap);
> @@ -2382,7 +2377,7 @@ unsigned long vb2_get_unmapped_area(struct vb2_queue *q,
>  {
>  	unsigned long off = pgoff << PAGE_SHIFT;
>  	struct vb2_buffer *vb;
> -	unsigned int buffer, plane;
> +	unsigned int plane;
>  	void *vaddr;
>  	int ret;
>  
> @@ -2392,12 +2387,10 @@ unsigned long vb2_get_unmapped_area(struct vb2_queue *q,
>  	 * Find the plane corresponding to the offset passed by userspace. This
>  	 * will return an error if not MEMORY_MMAP or file I/O is in progress.
>  	 */
> -	ret = __find_plane_by_offset(q, off, &buffer, &plane);
> +	ret = __find_plane_by_offset(q, off, &vb, &plane);
>  	if (ret)
>  		goto unlock;
>  
> -	vb = q->bufs[buffer];
> -
>  	vaddr = vb2_plane_vaddr(vb, plane);
>  	mutex_unlock(&q->mmap_lock);
>  	return vaddr ? (unsigned long)vaddr : -EINVAL;


WARNING: multiple messages have this Message-ID (diff)
From: Hans Verkuil <hverkuil-cisco@xs4all.nl>
To: Benjamin Gaignard <benjamin.gaignard@collabora.com>,
	mchehab@kernel.org, tfiga@chromium.org, m.szyprowski@samsung.com,
	ming.qian@nxp.com, ezequiel@vanguardiasur.com.ar,
	p.zabel@pengutronix.de, gregkh@linuxfoundation.org,
	nicolas.dufresne@collabora.com
Cc: linux-media@vger.kernel.org, linux-kernel@vger.kernel.org,
	linux-arm-kernel@lists.infradead.org,
	linux-mediatek@lists.infradead.org,
	linux-arm-msm@vger.kernel.org,
	linux-rockchip@lists.infradead.org,
	linux-staging@lists.linux.dev, kernel@collabora.com
Subject: Re: [PATCH v9 01/53] media: videobuf2: Rework offset 'cookie' encoding pattern
Date: Mon, 2 Oct 2023 15:46:07 +0200	[thread overview]
Message-ID: <08636b49-9022-4361-96d2-574de2548ab0@xs4all.nl> (raw)
In-Reply-To: <20231002120617.119602-2-benjamin.gaignard@collabora.com>

On 02/10/2023 14:05, Benjamin Gaignard wrote:
> Change how offset 'cookie' field value is computed to make possible
> to use more buffers.
> The maximum number of buffers depends of PAGE_SHIFT value and can
> go up to 0x7fff when PAGE_SHIFT = 12.
> With this encoding pattern we know the maximum number that a queue
> could store so we can check it at  queue init time.
> It also make easier and faster to find buffer and plane from using
> the offset field.
> Change __find_plane_by_offset() prototype to return the video buffer
> itself rather than it index.
> 
> Signed-off-by: Benjamin Gaignard <benjamin.gaignard@collabora.com>
> ---
> changes in version 9:
> - BUFFER_INDEX_MASK now depends on PAGE_SHIFT value to match
>   architectures requirements.
> 
>  .../media/common/videobuf2/videobuf2-core.c   | 71 +++++++++----------
>  1 file changed, 32 insertions(+), 39 deletions(-)
> 
> diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c
> index cf6727d9c81f..a0540b2e461f 100644
> --- a/drivers/media/common/videobuf2/videobuf2-core.c
> +++ b/drivers/media/common/videobuf2/videobuf2-core.c
> @@ -31,6 +31,10 @@
>  
>  #include <trace/events/vb2.h>
>  
> +#define PLANE_INDEX_SHIFT	(PAGE_SHIFT + 3)
> +#define PLANE_INDEX_MASK	0x7
> +#define BUFFER_INDEX_MASK	(BIT_MASK(30 - PLANE_INDEX_SHIFT) - 1)
> +
>  static int debug;
>  module_param(debug, int, 0644);
>  
> @@ -358,21 +362,24 @@ static void __setup_offsets(struct vb2_buffer *vb)
>  	unsigned int plane;
>  	unsigned long off = 0;
>  
> -	if (vb->index) {
> -		struct vb2_buffer *prev = q->bufs[vb->index - 1];
> -		struct vb2_plane *p = &prev->planes[prev->num_planes - 1];
> -
> -		off = PAGE_ALIGN(p->m.offset + p->length);
> -	}
> +	/*
> +	 * Offsets cookies value have the following constraints:
> +	 * - a buffer could have up to 8 planes.

could -> can

> +	 * - v4l2 mem2mem use bit 30 to distinguish between source and destination buffers.

use -> uses

> +	 * - must be page aligned
> +	 * That led to this bit mapping when PAGE_SHIFT = 12:
> +	 * |30                |29        15|14       12|11 0|
> +	 * |DST_QUEUE_OFF_BASE|buffer index|plane index| 0  |
> +	 * where there are 15 bits to store buffer index.

buffer index -> the buffer index

> +	 * Depending on PAGE_SHIFT value we can have else bits to store buffer index.

else bits? You probably mean "fewer bits".

buffer index -> the buffer index

> +	 */
> +	off = vb->index << PLANE_INDEX_SHIFT;
>  
>  	for (plane = 0; plane < vb->num_planes; ++plane) {
> -		vb->planes[plane].m.offset = off;
> +		vb->planes[plane].m.offset = off + (plane << PAGE_SHIFT);
>  
>  		dprintk(q, 3, "buffer %d, plane %d offset 0x%08lx\n",
>  				vb->index, plane, off);
> -
> -		off += vb->planes[plane].length;
> -		off = PAGE_ALIGN(off);
>  	}
>  }

Regards,

	Hans

>  
> @@ -2185,13 +2192,12 @@ int vb2_core_streamoff(struct vb2_queue *q, unsigned int type)
>  EXPORT_SYMBOL_GPL(vb2_core_streamoff);
>  
>  /*
> - * __find_plane_by_offset() - find plane associated with the given offset off
> + * __find_plane_by_offset() - find video buffer and plane associated with the given offset off
>   */
>  static int __find_plane_by_offset(struct vb2_queue *q, unsigned long off,
> -			unsigned int *_buffer, unsigned int *_plane)
> +			struct vb2_buffer **vb, unsigned int *plane)
>  {
> -	struct vb2_buffer *vb;
> -	unsigned int buffer, plane;
> +	unsigned int buffer;
>  
>  	/*
>  	 * Sanity checks to ensure the lock is held, MEMORY_MMAP is
> @@ -2209,24 +2215,15 @@ static int __find_plane_by_offset(struct vb2_queue *q, unsigned long off,
>  		return -EBUSY;
>  	}
>  
> -	/*
> -	 * Go over all buffers and their planes, comparing the given offset
> -	 * with an offset assigned to each plane. If a match is found,
> -	 * return its buffer and plane numbers.
> -	 */
> -	for (buffer = 0; buffer < q->num_buffers; ++buffer) {
> -		vb = q->bufs[buffer];
> +	/* Get buffer and plane from the offset */
> +	buffer = (off >> PLANE_INDEX_SHIFT) & BUFFER_INDEX_MASK;
> +	*plane = (off >> PAGE_SHIFT) & PLANE_INDEX_MASK;
>  
> -		for (plane = 0; plane < vb->num_planes; ++plane) {
> -			if (vb->planes[plane].m.offset == off) {
> -				*_buffer = buffer;
> -				*_plane = plane;
> -				return 0;
> -			}
> -		}
> -	}
> +	if (buffer >= q->num_buffers || *plane >= q->bufs[buffer]->num_planes)
> +		return -EINVAL;
>  
> -	return -EINVAL;
> +	*vb = q->bufs[buffer];
> +	return 0;
>  }
>  
>  int vb2_core_expbuf(struct vb2_queue *q, int *fd, unsigned int type,
> @@ -2306,7 +2303,7 @@ int vb2_mmap(struct vb2_queue *q, struct vm_area_struct *vma)
>  {
>  	unsigned long off = vma->vm_pgoff << PAGE_SHIFT;
>  	struct vb2_buffer *vb;
> -	unsigned int buffer = 0, plane = 0;
> +	unsigned int plane = 0;
>  	int ret;
>  	unsigned long length;
>  
> @@ -2335,12 +2332,10 @@ int vb2_mmap(struct vb2_queue *q, struct vm_area_struct *vma)
>  	 * Find the plane corresponding to the offset passed by userspace. This
>  	 * will return an error if not MEMORY_MMAP or file I/O is in progress.
>  	 */
> -	ret = __find_plane_by_offset(q, off, &buffer, &plane);
> +	ret = __find_plane_by_offset(q, off, &vb, &plane);
>  	if (ret)
>  		goto unlock;
>  
> -	vb = q->bufs[buffer];
> -
>  	/*
>  	 * MMAP requires page_aligned buffers.
>  	 * The buffer length was page_aligned at __vb2_buf_mem_alloc(),
> @@ -2368,7 +2363,7 @@ int vb2_mmap(struct vb2_queue *q, struct vm_area_struct *vma)
>  	if (ret)
>  		return ret;
>  
> -	dprintk(q, 3, "buffer %d, plane %d successfully mapped\n", buffer, plane);
> +	dprintk(q, 3, "buffer %u, plane %d successfully mapped\n", vb->index, plane);
>  	return 0;
>  }
>  EXPORT_SYMBOL_GPL(vb2_mmap);
> @@ -2382,7 +2377,7 @@ unsigned long vb2_get_unmapped_area(struct vb2_queue *q,
>  {
>  	unsigned long off = pgoff << PAGE_SHIFT;
>  	struct vb2_buffer *vb;
> -	unsigned int buffer, plane;
> +	unsigned int plane;
>  	void *vaddr;
>  	int ret;
>  
> @@ -2392,12 +2387,10 @@ unsigned long vb2_get_unmapped_area(struct vb2_queue *q,
>  	 * Find the plane corresponding to the offset passed by userspace. This
>  	 * will return an error if not MEMORY_MMAP or file I/O is in progress.
>  	 */
> -	ret = __find_plane_by_offset(q, off, &buffer, &plane);
> +	ret = __find_plane_by_offset(q, off, &vb, &plane);
>  	if (ret)
>  		goto unlock;
>  
> -	vb = q->bufs[buffer];
> -
>  	vaddr = vb2_plane_vaddr(vb, plane);
>  	mutex_unlock(&q->mmap_lock);
>  	return vaddr ? (unsigned long)vaddr : -EINVAL;


_______________________________________________
Linux-rockchip mailing list
Linux-rockchip@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-rockchip

WARNING: multiple messages have this Message-ID (diff)
From: Hans Verkuil <hverkuil-cisco@xs4all.nl>
To: Benjamin Gaignard <benjamin.gaignard@collabora.com>,
	mchehab@kernel.org, tfiga@chromium.org, m.szyprowski@samsung.com,
	ming.qian@nxp.com, ezequiel@vanguardiasur.com.ar,
	p.zabel@pengutronix.de, gregkh@linuxfoundation.org,
	nicolas.dufresne@collabora.com
Cc: linux-media@vger.kernel.org, linux-kernel@vger.kernel.org,
	linux-arm-kernel@lists.infradead.org,
	linux-mediatek@lists.infradead.org,
	linux-arm-msm@vger.kernel.org,
	linux-rockchip@lists.infradead.org,
	linux-staging@lists.linux.dev, kernel@collabora.com
Subject: Re: [PATCH v9 01/53] media: videobuf2: Rework offset 'cookie' encoding pattern
Date: Mon, 2 Oct 2023 15:46:07 +0200	[thread overview]
Message-ID: <08636b49-9022-4361-96d2-574de2548ab0@xs4all.nl> (raw)
In-Reply-To: <20231002120617.119602-2-benjamin.gaignard@collabora.com>

On 02/10/2023 14:05, Benjamin Gaignard wrote:
> Change how offset 'cookie' field value is computed to make possible
> to use more buffers.
> The maximum number of buffers depends of PAGE_SHIFT value and can
> go up to 0x7fff when PAGE_SHIFT = 12.
> With this encoding pattern we know the maximum number that a queue
> could store so we can check it at  queue init time.
> It also make easier and faster to find buffer and plane from using
> the offset field.
> Change __find_plane_by_offset() prototype to return the video buffer
> itself rather than it index.
> 
> Signed-off-by: Benjamin Gaignard <benjamin.gaignard@collabora.com>
> ---
> changes in version 9:
> - BUFFER_INDEX_MASK now depends on PAGE_SHIFT value to match
>   architectures requirements.
> 
>  .../media/common/videobuf2/videobuf2-core.c   | 71 +++++++++----------
>  1 file changed, 32 insertions(+), 39 deletions(-)
> 
> diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c
> index cf6727d9c81f..a0540b2e461f 100644
> --- a/drivers/media/common/videobuf2/videobuf2-core.c
> +++ b/drivers/media/common/videobuf2/videobuf2-core.c
> @@ -31,6 +31,10 @@
>  
>  #include <trace/events/vb2.h>
>  
> +#define PLANE_INDEX_SHIFT	(PAGE_SHIFT + 3)
> +#define PLANE_INDEX_MASK	0x7
> +#define BUFFER_INDEX_MASK	(BIT_MASK(30 - PLANE_INDEX_SHIFT) - 1)
> +
>  static int debug;
>  module_param(debug, int, 0644);
>  
> @@ -358,21 +362,24 @@ static void __setup_offsets(struct vb2_buffer *vb)
>  	unsigned int plane;
>  	unsigned long off = 0;
>  
> -	if (vb->index) {
> -		struct vb2_buffer *prev = q->bufs[vb->index - 1];
> -		struct vb2_plane *p = &prev->planes[prev->num_planes - 1];
> -
> -		off = PAGE_ALIGN(p->m.offset + p->length);
> -	}
> +	/*
> +	 * Offsets cookies value have the following constraints:
> +	 * - a buffer could have up to 8 planes.

could -> can

> +	 * - v4l2 mem2mem use bit 30 to distinguish between source and destination buffers.

use -> uses

> +	 * - must be page aligned
> +	 * That led to this bit mapping when PAGE_SHIFT = 12:
> +	 * |30                |29        15|14       12|11 0|
> +	 * |DST_QUEUE_OFF_BASE|buffer index|plane index| 0  |
> +	 * where there are 15 bits to store buffer index.

buffer index -> the buffer index

> +	 * Depending on PAGE_SHIFT value we can have else bits to store buffer index.

else bits? You probably mean "fewer bits".

buffer index -> the buffer index

> +	 */
> +	off = vb->index << PLANE_INDEX_SHIFT;
>  
>  	for (plane = 0; plane < vb->num_planes; ++plane) {
> -		vb->planes[plane].m.offset = off;
> +		vb->planes[plane].m.offset = off + (plane << PAGE_SHIFT);
>  
>  		dprintk(q, 3, "buffer %d, plane %d offset 0x%08lx\n",
>  				vb->index, plane, off);
> -
> -		off += vb->planes[plane].length;
> -		off = PAGE_ALIGN(off);
>  	}
>  }

Regards,

	Hans

>  
> @@ -2185,13 +2192,12 @@ int vb2_core_streamoff(struct vb2_queue *q, unsigned int type)
>  EXPORT_SYMBOL_GPL(vb2_core_streamoff);
>  
>  /*
> - * __find_plane_by_offset() - find plane associated with the given offset off
> + * __find_plane_by_offset() - find video buffer and plane associated with the given offset off
>   */
>  static int __find_plane_by_offset(struct vb2_queue *q, unsigned long off,
> -			unsigned int *_buffer, unsigned int *_plane)
> +			struct vb2_buffer **vb, unsigned int *plane)
>  {
> -	struct vb2_buffer *vb;
> -	unsigned int buffer, plane;
> +	unsigned int buffer;
>  
>  	/*
>  	 * Sanity checks to ensure the lock is held, MEMORY_MMAP is
> @@ -2209,24 +2215,15 @@ static int __find_plane_by_offset(struct vb2_queue *q, unsigned long off,
>  		return -EBUSY;
>  	}
>  
> -	/*
> -	 * Go over all buffers and their planes, comparing the given offset
> -	 * with an offset assigned to each plane. If a match is found,
> -	 * return its buffer and plane numbers.
> -	 */
> -	for (buffer = 0; buffer < q->num_buffers; ++buffer) {
> -		vb = q->bufs[buffer];
> +	/* Get buffer and plane from the offset */
> +	buffer = (off >> PLANE_INDEX_SHIFT) & BUFFER_INDEX_MASK;
> +	*plane = (off >> PAGE_SHIFT) & PLANE_INDEX_MASK;
>  
> -		for (plane = 0; plane < vb->num_planes; ++plane) {
> -			if (vb->planes[plane].m.offset == off) {
> -				*_buffer = buffer;
> -				*_plane = plane;
> -				return 0;
> -			}
> -		}
> -	}
> +	if (buffer >= q->num_buffers || *plane >= q->bufs[buffer]->num_planes)
> +		return -EINVAL;
>  
> -	return -EINVAL;
> +	*vb = q->bufs[buffer];
> +	return 0;
>  }
>  
>  int vb2_core_expbuf(struct vb2_queue *q, int *fd, unsigned int type,
> @@ -2306,7 +2303,7 @@ int vb2_mmap(struct vb2_queue *q, struct vm_area_struct *vma)
>  {
>  	unsigned long off = vma->vm_pgoff << PAGE_SHIFT;
>  	struct vb2_buffer *vb;
> -	unsigned int buffer = 0, plane = 0;
> +	unsigned int plane = 0;
>  	int ret;
>  	unsigned long length;
>  
> @@ -2335,12 +2332,10 @@ int vb2_mmap(struct vb2_queue *q, struct vm_area_struct *vma)
>  	 * Find the plane corresponding to the offset passed by userspace. This
>  	 * will return an error if not MEMORY_MMAP or file I/O is in progress.
>  	 */
> -	ret = __find_plane_by_offset(q, off, &buffer, &plane);
> +	ret = __find_plane_by_offset(q, off, &vb, &plane);
>  	if (ret)
>  		goto unlock;
>  
> -	vb = q->bufs[buffer];
> -
>  	/*
>  	 * MMAP requires page_aligned buffers.
>  	 * The buffer length was page_aligned at __vb2_buf_mem_alloc(),
> @@ -2368,7 +2363,7 @@ int vb2_mmap(struct vb2_queue *q, struct vm_area_struct *vma)
>  	if (ret)
>  		return ret;
>  
> -	dprintk(q, 3, "buffer %d, plane %d successfully mapped\n", buffer, plane);
> +	dprintk(q, 3, "buffer %u, plane %d successfully mapped\n", vb->index, plane);
>  	return 0;
>  }
>  EXPORT_SYMBOL_GPL(vb2_mmap);
> @@ -2382,7 +2377,7 @@ unsigned long vb2_get_unmapped_area(struct vb2_queue *q,
>  {
>  	unsigned long off = pgoff << PAGE_SHIFT;
>  	struct vb2_buffer *vb;
> -	unsigned int buffer, plane;
> +	unsigned int plane;
>  	void *vaddr;
>  	int ret;
>  
> @@ -2392,12 +2387,10 @@ unsigned long vb2_get_unmapped_area(struct vb2_queue *q,
>  	 * Find the plane corresponding to the offset passed by userspace. This
>  	 * will return an error if not MEMORY_MMAP or file I/O is in progress.
>  	 */
> -	ret = __find_plane_by_offset(q, off, &buffer, &plane);
> +	ret = __find_plane_by_offset(q, off, &vb, &plane);
>  	if (ret)
>  		goto unlock;
>  
> -	vb = q->bufs[buffer];
> -
>  	vaddr = vb2_plane_vaddr(vb, plane);
>  	mutex_unlock(&q->mmap_lock);
>  	return vaddr ? (unsigned long)vaddr : -EINVAL;


_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

  reply	other threads:[~2023-10-02 13:46 UTC|newest]

Thread overview: 171+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-10-02 12:05 [PATCH v9 00/53] Add DELETE_BUF ioctl Benjamin Gaignard
2023-10-02 12:05 ` Benjamin Gaignard
2023-10-02 12:05 ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 01/53] media: videobuf2: Rework offset 'cookie' encoding pattern Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 13:46   ` Hans Verkuil [this message]
2023-10-02 13:46     ` Hans Verkuil
2023-10-02 13:46     ` Hans Verkuil
2023-10-02 13:57   ` Hans Verkuil
2023-10-02 13:57     ` Hans Verkuil
2023-10-02 13:57     ` Hans Verkuil
2023-10-02 12:05 ` [PATCH v9 02/53] media: videobuf2: Stop spamming kernel log with all queue counter Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 03/53] media: videobuf2: Use vb2_buffer instead of index Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 04/53] media: amphion: Use vb2_get_buffer() instead of directly access to buffers array Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 05/53] media: mediatek: jpeg: " Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 06/53] media: mediatek: vdec: Remove useless loop Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 07/53] media: sti: hva: Use vb2_get_buffer() instead of directly access to buffers array Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 08/53] media: visl: " Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 09/53] media: atomisp: " Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 10/53] media: dvb-core: " Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 11/53] media: videobuf2: Access vb2_queue bufs array through helper functions Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 12/53] media: videobuf2: Be more flexible on the number of queue stored buffers Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 13/53] media: Report the maximum possible number of buffers for the queue Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 14/53] media: test-drivers: vivid: Increase max supported buffers for capture queues Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 15/53] media: test-drivers: vicodec: Increase max supported capture queue buffers Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 16/53] media: verisilicon: Refactor postprocessor to store more buffers Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 17/53] media: verisilicon: Store chroma and motion vectors offset Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 18/53] media: verisilicon: g2: Use common helpers to compute chroma and mv offsets Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 19/53] media: verisilicon: vp9: Allow to change resolution while streaming Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 20/53] media: Remove duplicated index vs q->num_buffers check Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 21/53] media: core: Add helper to get queue number of buffers Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 22/53] media: dvb-core: Do not initialize twice queue num_buffer field Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 23/53] media: dvb-frontends: rtl2832_srd: Use queue min_buffers_needed field Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 24/53] media: video-i2c: Set min_buffers_needed to 2 Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 25/53] media: pci: cx18: Set correct value to min_buffers_needed field Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 26/53] media: pci: dt3155: Remove useless check Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 27/53] media: pci: netup_unidvb: Remove useless number of buffers check Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 28/53] media: pci: tw68: Stop direct calls to queue num_buffers field Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 29/53] media: pci: tw686x: Set min_buffers_needed to 3 Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 30/53] media: amphion: Stop direct calls to queue num_buffers field Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 31/53] media: coda: " Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 32/53] media: mediatek: vcodec: " Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 33/53] media: nxp: " Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 34/53] media: renesas: Set min_buffers_needed to 16 Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05 ` [PATCH v9 35/53] media: ti: Use queue min_buffers_needed field to set the min number of buffers Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:05   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 36/53] media: verisilicon: Stop direct calls to queue num_buffers field Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 37/53] media: test-drivers: " Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 38/53] media: usb: airspy: Set min_buffers_needed to 8 Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 39/53] media: usb: cx231xx: Set min_buffers_needed to CX231XX_MIN_BUF Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 40/53] media: usb: hackrf: Set min_buffers_needed to 8 Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 41/53] media: usb: usbtv: Set min_buffers_needed to 2 Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 42/53] media: atomisp: Stop direct calls to queue num_buffers field Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 43/53] media: imx: " Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 44/53] media: meson: vdec: " Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 45/53] touchscreen: sur40: " Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 46/53] sample: v4l: " Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 47/53] media: cedrus: " Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 48/53] media: core: Rework how create_buf index returned value is computed Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 49/53] media: core: Add bitmap manage bufs array entries Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 50/53] media: core: Free range of buffers Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 51/53] media: v4l2: Add DELETE_BUFS ioctl Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 52/53] media: v4l2: Add mem2mem helpers for " Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06 ` [PATCH v9 53/53] media: test-drivers: Use helper " Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 12:06   ` Benjamin Gaignard
2023-10-02 14:46 ` [PATCH v9 00/53] Add DELETE_BUF ioctl Hans Verkuil
2023-10-02 14:46   ` Hans Verkuil
2023-10-02 14:46   ` Hans Verkuil

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=08636b49-9022-4361-96d2-574de2548ab0@xs4all.nl \
    --to=hverkuil-cisco@xs4all.nl \
    --cc=benjamin.gaignard@collabora.com \
    --cc=ezequiel@vanguardiasur.com.ar \
    --cc=gregkh@linuxfoundation.org \
    --cc=kernel@collabora.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-arm-msm@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-media@vger.kernel.org \
    --cc=linux-mediatek@lists.infradead.org \
    --cc=linux-rockchip@lists.infradead.org \
    --cc=linux-staging@lists.linux.dev \
    --cc=m.szyprowski@samsung.com \
    --cc=mchehab@kernel.org \
    --cc=ming.qian@nxp.com \
    --cc=nicolas.dufresne@collabora.com \
    --cc=p.zabel@pengutronix.de \
    --cc=tfiga@chromium.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.