Commit 6a8ffa8b authored by Niklas Söderlund's avatar Niklas Söderlund Committed by Mauro Carvalho Chehab

media: rcar-vin: allocate a scratch buffer at stream start

Before starting a capture, allocate a scratch buffer which can be used
by the driver to give to the hardware if no buffers are available from
userspace. The buffer is not used in this patch but prepares for future
refactoring where the scratch buffer can be used to avoid the need to
fallback on single capture mode if userspace can't queue buffers as fast
as the VIN driver consumes them.
Signed-off-by: default avatarNiklas Söderlund <niklas.soderlund+renesas@ragnatech.se>
Reviewed-by: default avatarJacopo Mondi <jacopo+renesas@jmondi.org>
Reviewed-by: default avatarKieran Bingham <kieran.bingham+renesas@ideasonboard.com>
Signed-off-by: default avatarHans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
parent 579260a5
...@@ -1076,6 +1076,17 @@ static int rvin_start_streaming(struct vb2_queue *vq, unsigned int count) ...@@ -1076,6 +1076,17 @@ static int rvin_start_streaming(struct vb2_queue *vq, unsigned int count)
unsigned long flags; unsigned long flags;
int ret; int ret;
/* Allocate scratch buffer. */
vin->scratch = dma_alloc_coherent(vin->dev, vin->format.sizeimage,
&vin->scratch_phys, GFP_KERNEL);
if (!vin->scratch) {
spin_lock_irqsave(&vin->qlock, flags);
return_all_buffers(vin, VB2_BUF_STATE_QUEUED);
spin_unlock_irqrestore(&vin->qlock, flags);
vin_err(vin, "Failed to allocate scratch buffer\n");
return -ENOMEM;
}
sd = vin_to_source(vin); sd = vin_to_source(vin);
v4l2_subdev_call(sd, video, s_stream, 1); v4l2_subdev_call(sd, video, s_stream, 1);
...@@ -1091,6 +1102,10 @@ static int rvin_start_streaming(struct vb2_queue *vq, unsigned int count) ...@@ -1091,6 +1102,10 @@ static int rvin_start_streaming(struct vb2_queue *vq, unsigned int count)
spin_unlock_irqrestore(&vin->qlock, flags); spin_unlock_irqrestore(&vin->qlock, flags);
if (ret)
dma_free_coherent(vin->dev, vin->format.sizeimage, vin->scratch,
vin->scratch_phys);
return ret; return ret;
} }
...@@ -1141,6 +1156,10 @@ static void rvin_stop_streaming(struct vb2_queue *vq) ...@@ -1141,6 +1156,10 @@ static void rvin_stop_streaming(struct vb2_queue *vq)
/* disable interrupts */ /* disable interrupts */
rvin_disable_interrupts(vin); rvin_disable_interrupts(vin);
/* Free scratch buffer. */
dma_free_coherent(vin->dev, vin->format.sizeimage, vin->scratch,
vin->scratch_phys);
} }
static const struct vb2_ops rvin_qops = { static const struct vb2_ops rvin_qops = {
......
...@@ -102,6 +102,8 @@ struct rvin_graph_entity { ...@@ -102,6 +102,8 @@ struct rvin_graph_entity {
* *
* @lock: protects @queue * @lock: protects @queue
* @queue: vb2 buffers queue * @queue: vb2 buffers queue
* @scratch: cpu address for scratch buffer
* @scratch_phys: physical address of the scratch buffer
* *
* @qlock: protects @queue_buf, @buf_list, @continuous, @sequence * @qlock: protects @queue_buf, @buf_list, @continuous, @sequence
* @state * @state
...@@ -130,6 +132,8 @@ struct rvin_dev { ...@@ -130,6 +132,8 @@ struct rvin_dev {
struct mutex lock; struct mutex lock;
struct vb2_queue queue; struct vb2_queue queue;
void *scratch;
dma_addr_t scratch_phys;
spinlock_t qlock; spinlock_t qlock;
struct vb2_v4l2_buffer *queue_buf[HW_BUFFER_NUM]; struct vb2_v4l2_buffer *queue_buf[HW_BUFFER_NUM];
......
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