[media] v4l: omap3isp: preview: Mark output buffer done first
The sequence number counter is incremented on each output buffer, and that incremented value is used as the sequence number of that buffer. The input buffer sequence numbering is based just on reading the same counter. If the input buffer is marked done first, its sequence number ends up being that of the output buffer - 1. This is how the resizer works as well. Signed-off-by: Sakari Ailus <sakari.ailus@iki.fi> Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
This commit is contained in:
parent
514580f99a
commit
61d5b9d46d
|
@ -1480,13 +1480,6 @@ static void preview_isr_buffer(struct isp_prev_device *prev)
|
|||
struct isp_buffer *buffer;
|
||||
int restart = 0;
|
||||
|
||||
if (prev->input == PREVIEW_INPUT_MEMORY) {
|
||||
buffer = omap3isp_video_buffer_next(&prev->video_in);
|
||||
if (buffer != NULL)
|
||||
preview_set_inaddr(prev, buffer->dma);
|
||||
pipe->state |= ISP_PIPELINE_IDLE_INPUT;
|
||||
}
|
||||
|
||||
if (prev->output & PREVIEW_OUTPUT_MEMORY) {
|
||||
buffer = omap3isp_video_buffer_next(&prev->video_out);
|
||||
if (buffer != NULL) {
|
||||
|
@ -1496,6 +1489,13 @@ static void preview_isr_buffer(struct isp_prev_device *prev)
|
|||
pipe->state |= ISP_PIPELINE_IDLE_OUTPUT;
|
||||
}
|
||||
|
||||
if (prev->input == PREVIEW_INPUT_MEMORY) {
|
||||
buffer = omap3isp_video_buffer_next(&prev->video_in);
|
||||
if (buffer != NULL)
|
||||
preview_set_inaddr(prev, buffer->dma);
|
||||
pipe->state |= ISP_PIPELINE_IDLE_INPUT;
|
||||
}
|
||||
|
||||
switch (prev->state) {
|
||||
case ISP_PIPELINE_STREAM_SINGLESHOT:
|
||||
if (isp_pipeline_ready(pipe))
|
||||
|
|
Loading…
Reference in New Issue