[FFmpeg-cvslog] avcodec/mlp_parser: mark sync frames as key frames

James Almer git at videolan.org
Thu Dec 12 17:38:14 EET 2019


ffmpeg | branch: master | James Almer <jamrial at gmail.com> | Thu Dec 12 09:32:07 2019 -0300| [aedffc0b220bd47d2a4f5bd3ca751e4e51c500c7] | committer: James Almer

avcodec/mlp_parser: mark sync frames as key frames

Signed-off-by: James Almer <jamrial at gmail.com>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=aedffc0b220bd47d2a4f5bd3ca751e4e51c500c7
---

 libavcodec/mlp_parser.c | 6 ++++++
 1 file changed, 6 insertions(+)

diff --git a/libavcodec/mlp_parser.c b/libavcodec/mlp_parser.c
index b5d3ff7226..5d2ddc5a70 100644
--- a/libavcodec/mlp_parser.c
+++ b/libavcodec/mlp_parser.c
@@ -61,6 +61,8 @@ static int mlp_parse(AVCodecParserContext *s,
     int ret;
     int i, p = 0;
 
+    s->key_frame = 0;
+
     *poutbuf_size = 0;
     if (buf_size == 0)
         return 0;
@@ -136,6 +138,8 @@ static int mlp_parse(AVCodecParserContext *s,
          * access unit header and all the 2- or 4-byte substream headers. */
         // Only check when this isn't a sync frame - syncs have a checksum.
 
+        s->key_frame = 0;
+
         parity_bits = 0;
         for (i = -1; i < mp->num_substreams; i++) {
             parity_bits ^= buf[p++];
@@ -159,6 +163,8 @@ static int mlp_parse(AVCodecParserContext *s,
         if (ff_mlp_read_major_sync(avctx, &mh, &gb) < 0)
             goto lost_sync;
 
+        s->key_frame = 1;
+
         avctx->bits_per_raw_sample = mh.group1_bits;
         if (avctx->bits_per_raw_sample > 16)
             avctx->sample_fmt = AV_SAMPLE_FMT_S32;



More information about the ffmpeg-cvslog mailing list