[media] s5p-mfc: end-of-stream handling in encoder bug fix
authorKamil Debski <k.debski@samsung.com>
Fri, 11 Jan 2013 14:29:34 +0000 (11:29 -0300)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Wed, 6 Feb 2013 11:41:44 +0000 (09:41 -0200)
In some circumstances after issuing the V4L2_ENC_CMD_STOP the application
could freeze. This patch prevents this behavior.

Signed-off-by: Kamil Debski <k.debski@samsung.com>
Signed-off-by: Kyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: Sylwester Nawrocki <s.nawrocki@samsung.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
drivers/media/platform/s5p-mfc/s5p_mfc_enc.c

index f92f6ddd739fc1f4cbf982ca41e9ab9a7005530d..2356fd52a169abf2680dd22ebb9e17453c4ac52d 100644 (file)
@@ -1534,6 +1534,8 @@ int vidioc_encoder_cmd(struct file *file, void *priv,
                if (list_empty(&ctx->src_queue)) {
                        mfc_debug(2, "EOS: empty src queue, entering finishing state");
                        ctx->state = MFCINST_FINISHING;
+                       if (s5p_mfc_ctx_ready(ctx))
+                               set_work_bit_irqsave(ctx);
                        spin_unlock_irqrestore(&dev->irqlock, flags);
                        s5p_mfc_hw_call(dev->mfc_ops, try_run, dev);
                } else {