diff mbox series

[FFmpeg-devel] avcodec/mjpegdec: add frame threading for mjpeg decoder

Message ID CAPYw7P7cqQ6ntr-J6L1HbBLNnTsHw3=55fywKzW7Ub4fDpfTfA@mail.gmail.com
State New
Headers show
Series [FFmpeg-devel] avcodec/mjpegdec: add frame threading for mjpeg decoder | expand

Commit Message

Paul B Mahol Sept. 7, 2023, 4:44 p.m. UTC
Attached.

Comments

Andreas Rheinhardt Sept. 7, 2023, 5:07 p.m. UTC | #1
Paul B Mahol:
> Attached.
> 
> 

Haven't you sent a patch exactly like this before, which led to Michael
Niedermayer providing a command line where this changes the output?

- Andreas
Paul B Mahol Sept. 7, 2023, 5:34 p.m. UTC | #2
On Thu, Sep 7, 2023 at 7:21 PM Andreas Rheinhardt <
andreas.rheinhardt@outlook.com> wrote:

> Paul B Mahol:
> > Attached.
> >
> >
>
> Haven't you sent a patch exactly like this before, which led to Michael
> Niedermayer providing a command line where this changes the output?
>

That  was not me.

But I know what thread you are referring to.


> - Andreas
>
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel@ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
> To unsubscribe, visit link above, or email
> ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
>
Paul B Mahol Sept. 7, 2023, 5:48 p.m. UTC | #3
On Thu, Sep 7, 2023 at 7:34 PM Paul B Mahol <onemda@gmail.com> wrote:

>
>
> On Thu, Sep 7, 2023 at 7:21 PM Andreas Rheinhardt <
> andreas.rheinhardt@outlook.com> wrote:
>
>> Paul B Mahol:
>> > Attached.
>> >
>> >
>>
>> Haven't you sent a patch exactly like this before, which led to Michael
>> Niedermayer providing a command line where this changes the output?
>>
>
> That  was not me.
>
> But I know what thread you are referring to.
>

Checked that file, my patch does not fix nor break playing of that .avi
That AVI with mjpeg codec is not decoding with latest FFmpeg master code.

Even if I extract mjpeg losslessly from avi It still decodes just fine
without and with this patch applied.


>
>
>> - Andreas
>>
>> _______________________________________________
>> ffmpeg-devel mailing list
>> ffmpeg-devel@ffmpeg.org
>> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>>
>> To unsubscribe, visit link above, or email
>> ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
>>
>
Michael Niedermayer Sept. 7, 2023, 9:17 p.m. UTC | #4
On Thu, Sep 07, 2023 at 06:44:40PM +0200, Paul B Mahol wrote:
> Attached.

>  mjpegdec.c |    8 ++++----
>  1 file changed, 4 insertions(+), 4 deletions(-)
> f65de11bf58ea36b071c3501d4fa700d242edf21  0001-avcodec-mjpegdec-add-frame-threading-for-mjpeg-decod.patch
> From 2cff86b07b56d2923f60923e7dd21a546c2cc6fa Mon Sep 17 00:00:00 2001
> From: Paul B Mahol <onemda@gmail.com>
> Date: Thu, 7 Sep 2023 18:42:03 +0200
> Subject: [PATCH] avcodec/mjpegdec: add frame threading for mjpeg decoder
> 
> Signed-off-by: Paul B Mahol <onemda@gmail.com>
> ---
>  libavcodec/mjpegdec.c | 8 ++++----
>  1 file changed, 4 insertions(+), 4 deletions(-)

./ffmpeg  -v -1 -i tickets/1915/m_noint.avi -f framecrc -an -t 1 -
Here the timestamps change and the files output does not look healthy
(looks as if one field is behind)

@@ -645,18 +645,22 @@
 #codec_id 0: rawvideo
 #dimensions 0: 640x480
 #sar 0: 0/1
-0,          0,          0,        1,   614400, 0x51734de4
-0,          2,          2,        1,   614400, 0x9dfe6e90
-0,          4,          4,        1,   614400, 0x16d1f0d5
-0,          6,          6,        1,   614400, 0x67cbb0f0
-0,          8,          8,        1,   614400, 0x40f5223e
-0,         10,         10,        1,   614400, 0xef9a9ba8
-0,         12,         12,        1,   614400, 0x415cb69a
-0,         14,         14,        1,   614400, 0xbebf1993
-0,         16,         16,        1,   614400, 0xe4495f0f
-0,         18,         18,        1,   614400, 0x05a06480
-0,         20,         20,        1,   614400, 0x323bb5eb
-0,         22,         22,        1,   614400, 0x941b44ff
+0,          0,          0,        1,   614400, 0xb7f88313
+0,          1,          1,        1,   614400, 0xeda529e0
+0,          2,          2,        1,   614400, 0x29d53819
+0,          3,          3,        1,   614400, 0x95619af7
+0,          4,          4,        1,   614400, 0xfadb0437
+0,          5,          5,        1,   614400, 0xb2efa298
+0,          6,          6,        1,   614400, 0x8f4312c6
+0,          7,          7,        1,   614400, 0x8968e329
+0,          8,          8,        1,   614400, 0x545954c5
+0,          9,          9,        1,   614400, 0x144cd0b3
+0,         10,         10,        1,   614400, 0x5cd10fe0
+0,         11,         11,        1,   614400, 0x81b8473c
+0,         12,         12,        1,   614400, 0x58808c89
+0,         13,         13,        1,   614400, 0x21371f9f
+0,         14,         14,        1,   614400, 0x7533cd2a
+0,         15,         15,        1,   614400, 0xc2e8ec09




[...]
Paul B Mahol Sept. 7, 2023, 9:39 p.m. UTC | #5
Sorry but I do not have such file, file i have only does 1 frame.
Michael Niedermayer Sept. 7, 2023, 9:57 p.m. UTC | #6
On Thu, Sep 07, 2023 at 11:39:41PM +0200, Paul B Mahol wrote:
> Sorry but I do not have such file, file i have only does 1 frame.

https://samples.ffmpeg.org/ffmpeg-bugs/trac/ticket1915/

thx

[...]
diff mbox series

Patch

From 2cff86b07b56d2923f60923e7dd21a546c2cc6fa Mon Sep 17 00:00:00 2001
From: Paul B Mahol <onemda@gmail.com>
Date: Thu, 7 Sep 2023 18:42:03 +0200
Subject: [PATCH] avcodec/mjpegdec: add frame threading for mjpeg decoder

Signed-off-by: Paul B Mahol <onemda@gmail.com>
---
 libavcodec/mjpegdec.c | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)

diff --git a/libavcodec/mjpegdec.c b/libavcodec/mjpegdec.c
index 29f281231c..cc38b6c4a9 100644
--- a/libavcodec/mjpegdec.c
+++ b/libavcodec/mjpegdec.c
@@ -52,12 +52,12 @@ 
 #include "jpeglsdec.h"
 #include "profiles.h"
 #include "put_bits.h"
+#include "thread.h"
 #include "tiff.h"
 #include "exif.h"
 #include "bytestream.h"
 #include "tiff_common.h"
 
-
 static int init_default_huffman_tables(MJpegDecodeContext *s)
 {
     static const struct {
@@ -753,8 +753,8 @@  int ff_mjpeg_decode_sof(MJpegDecodeContext *s)
         }
 
         av_frame_unref(s->picture_ptr);
-        if (ff_get_buffer(s->avctx, s->picture_ptr, AV_GET_BUFFER_FLAG_REF) < 0)
-            return -1;
+        if ((ret = ff_thread_get_buffer(s->avctx, s->picture_ptr, AV_GET_BUFFER_FLAG_REF)) < 0)
+            return ret;
         s->picture_ptr->pict_type = AV_PICTURE_TYPE_I;
         s->picture_ptr->flags |= AV_FRAME_FLAG_KEY;
         s->got_picture            = 1;
@@ -3006,7 +3006,7 @@  const FFCodec ff_mjpeg_decoder = {
     .close          = ff_mjpeg_decode_end,
     FF_CODEC_DECODE_CB(ff_mjpeg_decode_frame),
     .flush          = decode_flush,
-    .p.capabilities = AV_CODEC_CAP_DR1,
+    .p.capabilities = AV_CODEC_CAP_DR1 | AV_CODEC_CAP_FRAME_THREADS,
     .p.max_lowres   = 3,
     .p.priv_class   = &mjpegdec_class,
     .p.profiles     = NULL_IF_CONFIG_SMALL(ff_mjpeg_profiles),
-- 
2.39.1