diff mbox series

[v8,02/10] media: v4l2-mem2mem: extend m2m APIs for more accurate buffer management

Message ID 1493370837-19793-3-git-send-email-stanimir.varbanov@linaro.org
State Superseded
Headers show
Series [v8,01/10] firmware: qcom_scm: Fix to allow COMPILE_TEST-ing | expand

Commit Message

Stanimir Varbanov April 28, 2017, 9:13 a.m. UTC
this add functions for:
  - remove buffers from src/dst queue by index
  - remove exact buffer from src/dst queue

also extends m2m API to iterate over a list of src/dst buffers
in safely and non-safely manner.

Signed-off-by: Stanimir Varbanov <stanimir.varbanov@linaro.org>

---
 drivers/media/v4l2-core/v4l2-mem2mem.c | 37 ++++++++++++++
 include/media/v4l2-mem2mem.h           | 92 ++++++++++++++++++++++++++++++++++
 2 files changed, 129 insertions(+)

-- 
2.7.4

Comments

Hans Verkuil May 5, 2017, 11:36 a.m. UTC | #1
On 04/28/17 11:13, Stanimir Varbanov wrote:
> this add functions for:

>   - remove buffers from src/dst queue by index

>   - remove exact buffer from src/dst queue

> 

> also extends m2m API to iterate over a list of src/dst buffers

> in safely and non-safely manner.

> 

> Signed-off-by: Stanimir Varbanov <stanimir.varbanov@linaro.org>


Reviewed-by: Hans Verkuil <hans.verkuil@cisco.com>


Thanks!

	Hans

> ---

>  drivers/media/v4l2-core/v4l2-mem2mem.c | 37 ++++++++++++++

>  include/media/v4l2-mem2mem.h           | 92 ++++++++++++++++++++++++++++++++++

>  2 files changed, 129 insertions(+)

> 

> diff --git a/drivers/media/v4l2-core/v4l2-mem2mem.c b/drivers/media/v4l2-core/v4l2-mem2mem.c

> index 6bc27e7b2a33..f62e68aa04c4 100644

> --- a/drivers/media/v4l2-core/v4l2-mem2mem.c

> +++ b/drivers/media/v4l2-core/v4l2-mem2mem.c

> @@ -126,6 +126,43 @@ void *v4l2_m2m_buf_remove(struct v4l2_m2m_queue_ctx *q_ctx)

>  }

>  EXPORT_SYMBOL_GPL(v4l2_m2m_buf_remove);

>  

> +void v4l2_m2m_buf_remove_by_buf(struct v4l2_m2m_queue_ctx *q_ctx,

> +				struct vb2_v4l2_buffer *vbuf)

> +{

> +	struct v4l2_m2m_buffer *b;

> +	unsigned long flags;

> +

> +	spin_lock_irqsave(&q_ctx->rdy_spinlock, flags);

> +	b = container_of(vbuf, struct v4l2_m2m_buffer, vb);

> +	list_del(&b->list);

> +	q_ctx->num_rdy--;

> +	spin_unlock_irqrestore(&q_ctx->rdy_spinlock, flags);

> +}

> +EXPORT_SYMBOL_GPL(v4l2_m2m_buf_remove_by_buf);

> +

> +struct vb2_v4l2_buffer *

> +v4l2_m2m_buf_remove_by_idx(struct v4l2_m2m_queue_ctx *q_ctx, unsigned int idx)

> +

> +{

> +	struct v4l2_m2m_buffer *b, *tmp;

> +	struct vb2_v4l2_buffer *ret = NULL;

> +	unsigned long flags;

> +

> +	spin_lock_irqsave(&q_ctx->rdy_spinlock, flags);

> +	list_for_each_entry_safe(b, tmp, &q_ctx->rdy_queue, list) {

> +		if (b->vb.vb2_buf.index == idx) {

> +			list_del(&b->list);

> +			q_ctx->num_rdy--;

> +			ret = &b->vb;

> +			break;

> +		}

> +	}

> +	spin_unlock_irqrestore(&q_ctx->rdy_spinlock, flags);

> +

> +	return ret;

> +}

> +EXPORT_SYMBOL_GPL(v4l2_m2m_buf_remove_by_idx);

> +

>  /*

>   * Scheduling handlers

>   */

> diff --git a/include/media/v4l2-mem2mem.h b/include/media/v4l2-mem2mem.h

> index 3ccd01bd245e..e157d5c9b224 100644

> --- a/include/media/v4l2-mem2mem.h

> +++ b/include/media/v4l2-mem2mem.h

> @@ -437,6 +437,47 @@ static inline void *v4l2_m2m_next_dst_buf(struct v4l2_m2m_ctx *m2m_ctx)

>  }

>  

>  /**

> + * v4l2_m2m_for_each_dst_buf() - iterate over a list of destination ready

> + * buffers

> + *

> + * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx

> + * @b: current buffer of type struct v4l2_m2m_buffer

> + */

> +#define v4l2_m2m_for_each_dst_buf(m2m_ctx, b)	\

> +	list_for_each_entry(b, &m2m_ctx->cap_q_ctx.rdy_queue, list)

> +

> +/**

> + * v4l2_m2m_for_each_src_buf() - iterate over a list of source ready buffers

> + *

> + * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx

> + * @b: current buffer of type struct v4l2_m2m_buffer

> + */

> +#define v4l2_m2m_for_each_src_buf(m2m_ctx, b)	\

> +	list_for_each_entry(b, &m2m_ctx->out_q_ctx.rdy_queue, list)

> +

> +/**

> + * v4l2_m2m_for_each_dst_buf_safe() - iterate over a list of destination ready

> + * buffers safely

> + *

> + * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx

> + * @b: current buffer of type struct v4l2_m2m_buffer

> + * @n: used as temporary storage

> + */

> +#define v4l2_m2m_for_each_dst_buf_safe(m2m_ctx, b, n)	\

> +	list_for_each_entry_safe(b, n, &m2m_ctx->cap_q_ctx.rdy_queue, list)

> +

> +/**

> + * v4l2_m2m_for_each_src_buf_safe() - iterate over a list of source ready

> + * buffers safely

> + *

> + * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx

> + * @b: current buffer of type struct v4l2_m2m_buffer

> + * @n: used as temporary storage

> + */

> +#define v4l2_m2m_for_each_src_buf_safe(m2m_ctx, b, n)	\

> +	list_for_each_entry_safe(b, n, &m2m_ctx->out_q_ctx.rdy_queue, list)

> +

> +/**

>   * v4l2_m2m_get_src_vq() - return vb2_queue for source buffers

>   *

>   * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx

> @@ -488,6 +529,57 @@ static inline void *v4l2_m2m_dst_buf_remove(struct v4l2_m2m_ctx *m2m_ctx)

>  	return v4l2_m2m_buf_remove(&m2m_ctx->cap_q_ctx);

>  }

>  

> +/**

> + * v4l2_m2m_buf_remove_by_buf() - take off exact buffer from the list of ready

> + * buffers

> + *

> + * @q_ctx: pointer to struct @v4l2_m2m_queue_ctx

> + * @vbuf: the buffer to be removed

> + */

> +void v4l2_m2m_buf_remove_by_buf(struct v4l2_m2m_queue_ctx *q_ctx,

> +				struct vb2_v4l2_buffer *vbuf);

> +

> +/**

> + * v4l2_m2m_src_buf_remove_by_buf() - take off exact source buffer from the list

> + * of ready buffers

> + *

> + * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx

> + * @vbuf: the buffer to be removed

> + */

> +static inline void v4l2_m2m_src_buf_remove_by_buf(struct v4l2_m2m_ctx *m2m_ctx,

> +						  struct vb2_v4l2_buffer *vbuf)

> +{

> +	v4l2_m2m_buf_remove_by_buf(&m2m_ctx->out_q_ctx, vbuf);

> +}

> +

> +/**

> + * v4l2_m2m_dst_buf_remove_by_buf() - take off exact destination buffer from the

> + * list of ready buffers

> + *

> + * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx

> + * @vbuf: the buffer to be removed

> + */

> +static inline void v4l2_m2m_dst_buf_remove_by_buf(struct v4l2_m2m_ctx *m2m_ctx,

> +						  struct vb2_v4l2_buffer *vbuf)

> +{

> +	v4l2_m2m_buf_remove_by_buf(&m2m_ctx->cap_q_ctx, vbuf);

> +}

> +

> +struct vb2_v4l2_buffer *

> +v4l2_m2m_buf_remove_by_idx(struct v4l2_m2m_queue_ctx *q_ctx, unsigned int idx);

> +

> +static inline struct vb2_v4l2_buffer *

> +v4l2_m2m_src_buf_remove_by_idx(struct v4l2_m2m_ctx *m2m_ctx, unsigned int idx)

> +{

> +	return v4l2_m2m_buf_remove_by_idx(&m2m_ctx->out_q_ctx, idx);

> +}

> +

> +static inline struct vb2_v4l2_buffer *

> +v4l2_m2m_dst_buf_remove_by_idx(struct v4l2_m2m_ctx *m2m_ctx, unsigned int idx)

> +{

> +	return v4l2_m2m_buf_remove_by_idx(&m2m_ctx->cap_q_ctx, idx);

> +}

> +

>  /* v4l2 ioctl helpers */

>  

>  int v4l2_m2m_ioctl_reqbufs(struct file *file, void *priv,

>
diff mbox series

Patch

diff --git a/drivers/media/v4l2-core/v4l2-mem2mem.c b/drivers/media/v4l2-core/v4l2-mem2mem.c
index 6bc27e7b2a33..f62e68aa04c4 100644
--- a/drivers/media/v4l2-core/v4l2-mem2mem.c
+++ b/drivers/media/v4l2-core/v4l2-mem2mem.c
@@ -126,6 +126,43 @@  void *v4l2_m2m_buf_remove(struct v4l2_m2m_queue_ctx *q_ctx)
 }
 EXPORT_SYMBOL_GPL(v4l2_m2m_buf_remove);
 
+void v4l2_m2m_buf_remove_by_buf(struct v4l2_m2m_queue_ctx *q_ctx,
+				struct vb2_v4l2_buffer *vbuf)
+{
+	struct v4l2_m2m_buffer *b;
+	unsigned long flags;
+
+	spin_lock_irqsave(&q_ctx->rdy_spinlock, flags);
+	b = container_of(vbuf, struct v4l2_m2m_buffer, vb);
+	list_del(&b->list);
+	q_ctx->num_rdy--;
+	spin_unlock_irqrestore(&q_ctx->rdy_spinlock, flags);
+}
+EXPORT_SYMBOL_GPL(v4l2_m2m_buf_remove_by_buf);
+
+struct vb2_v4l2_buffer *
+v4l2_m2m_buf_remove_by_idx(struct v4l2_m2m_queue_ctx *q_ctx, unsigned int idx)
+
+{
+	struct v4l2_m2m_buffer *b, *tmp;
+	struct vb2_v4l2_buffer *ret = NULL;
+	unsigned long flags;
+
+	spin_lock_irqsave(&q_ctx->rdy_spinlock, flags);
+	list_for_each_entry_safe(b, tmp, &q_ctx->rdy_queue, list) {
+		if (b->vb.vb2_buf.index == idx) {
+			list_del(&b->list);
+			q_ctx->num_rdy--;
+			ret = &b->vb;
+			break;
+		}
+	}
+	spin_unlock_irqrestore(&q_ctx->rdy_spinlock, flags);
+
+	return ret;
+}
+EXPORT_SYMBOL_GPL(v4l2_m2m_buf_remove_by_idx);
+
 /*
  * Scheduling handlers
  */
diff --git a/include/media/v4l2-mem2mem.h b/include/media/v4l2-mem2mem.h
index 3ccd01bd245e..e157d5c9b224 100644
--- a/include/media/v4l2-mem2mem.h
+++ b/include/media/v4l2-mem2mem.h
@@ -437,6 +437,47 @@  static inline void *v4l2_m2m_next_dst_buf(struct v4l2_m2m_ctx *m2m_ctx)
 }
 
 /**
+ * v4l2_m2m_for_each_dst_buf() - iterate over a list of destination ready
+ * buffers
+ *
+ * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx
+ * @b: current buffer of type struct v4l2_m2m_buffer
+ */
+#define v4l2_m2m_for_each_dst_buf(m2m_ctx, b)	\
+	list_for_each_entry(b, &m2m_ctx->cap_q_ctx.rdy_queue, list)
+
+/**
+ * v4l2_m2m_for_each_src_buf() - iterate over a list of source ready buffers
+ *
+ * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx
+ * @b: current buffer of type struct v4l2_m2m_buffer
+ */
+#define v4l2_m2m_for_each_src_buf(m2m_ctx, b)	\
+	list_for_each_entry(b, &m2m_ctx->out_q_ctx.rdy_queue, list)
+
+/**
+ * v4l2_m2m_for_each_dst_buf_safe() - iterate over a list of destination ready
+ * buffers safely
+ *
+ * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx
+ * @b: current buffer of type struct v4l2_m2m_buffer
+ * @n: used as temporary storage
+ */
+#define v4l2_m2m_for_each_dst_buf_safe(m2m_ctx, b, n)	\
+	list_for_each_entry_safe(b, n, &m2m_ctx->cap_q_ctx.rdy_queue, list)
+
+/**
+ * v4l2_m2m_for_each_src_buf_safe() - iterate over a list of source ready
+ * buffers safely
+ *
+ * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx
+ * @b: current buffer of type struct v4l2_m2m_buffer
+ * @n: used as temporary storage
+ */
+#define v4l2_m2m_for_each_src_buf_safe(m2m_ctx, b, n)	\
+	list_for_each_entry_safe(b, n, &m2m_ctx->out_q_ctx.rdy_queue, list)
+
+/**
  * v4l2_m2m_get_src_vq() - return vb2_queue for source buffers
  *
  * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx
@@ -488,6 +529,57 @@  static inline void *v4l2_m2m_dst_buf_remove(struct v4l2_m2m_ctx *m2m_ctx)
 	return v4l2_m2m_buf_remove(&m2m_ctx->cap_q_ctx);
 }
 
+/**
+ * v4l2_m2m_buf_remove_by_buf() - take off exact buffer from the list of ready
+ * buffers
+ *
+ * @q_ctx: pointer to struct @v4l2_m2m_queue_ctx
+ * @vbuf: the buffer to be removed
+ */
+void v4l2_m2m_buf_remove_by_buf(struct v4l2_m2m_queue_ctx *q_ctx,
+				struct vb2_v4l2_buffer *vbuf);
+
+/**
+ * v4l2_m2m_src_buf_remove_by_buf() - take off exact source buffer from the list
+ * of ready buffers
+ *
+ * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx
+ * @vbuf: the buffer to be removed
+ */
+static inline void v4l2_m2m_src_buf_remove_by_buf(struct v4l2_m2m_ctx *m2m_ctx,
+						  struct vb2_v4l2_buffer *vbuf)
+{
+	v4l2_m2m_buf_remove_by_buf(&m2m_ctx->out_q_ctx, vbuf);
+}
+
+/**
+ * v4l2_m2m_dst_buf_remove_by_buf() - take off exact destination buffer from the
+ * list of ready buffers
+ *
+ * @m2m_ctx: m2m context assigned to the instance given by struct &v4l2_m2m_ctx
+ * @vbuf: the buffer to be removed
+ */
+static inline void v4l2_m2m_dst_buf_remove_by_buf(struct v4l2_m2m_ctx *m2m_ctx,
+						  struct vb2_v4l2_buffer *vbuf)
+{
+	v4l2_m2m_buf_remove_by_buf(&m2m_ctx->cap_q_ctx, vbuf);
+}
+
+struct vb2_v4l2_buffer *
+v4l2_m2m_buf_remove_by_idx(struct v4l2_m2m_queue_ctx *q_ctx, unsigned int idx);
+
+static inline struct vb2_v4l2_buffer *
+v4l2_m2m_src_buf_remove_by_idx(struct v4l2_m2m_ctx *m2m_ctx, unsigned int idx)
+{
+	return v4l2_m2m_buf_remove_by_idx(&m2m_ctx->out_q_ctx, idx);
+}
+
+static inline struct vb2_v4l2_buffer *
+v4l2_m2m_dst_buf_remove_by_idx(struct v4l2_m2m_ctx *m2m_ctx, unsigned int idx)
+{
+	return v4l2_m2m_buf_remove_by_idx(&m2m_ctx->cap_q_ctx, idx);
+}
+
 /* v4l2 ioctl helpers */
 
 int v4l2_m2m_ioctl_reqbufs(struct file *file, void *priv,