[FFmpeg-devel] [PATCH] avformat/segafilm - fix keyframe detection and set packet, flags

Gyan Doshi gyandoshi at gmail.com
Thu Mar 22 06:49:15 EET 2018



On 3/22/2018 2:02 AM, Carl Eugen Hoyos wrote:

> Can you comment on why this 15-year old code was wrong?

It inverts the correct assignment of keyframe status. On the sample file 
uploaded to trac, the existing code marks the first frame as non-KF and 
all remaining frames as KF.

Changed to AVINDEX_KEYFRAME.

Regards,
Gyan
-------------- next part --------------
From 443de6adc84c2cd5f11bb5e35f2e3bccb09d3b70 Mon Sep 17 00:00:00 2001
From: Gyan Doshi <gyandoshi at gmail.com>
Date: Wed, 21 Mar 2018 18:59:33 +0530
Subject: [PATCH] avformat/segafilm - fix keyframe detection and set packet
 flags

Streams from a Segafilm cpk file can't be streamcopied because
keyframe flag isn't correctly set in stream index and
said flag is never conveyed to the packet

Fixes #7091
---
 libavformat/segafilm.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/libavformat/segafilm.c b/libavformat/segafilm.c
index 1fdef50cc7..383ec4d216 100644
--- a/libavformat/segafilm.c
+++ b/libavformat/segafilm.c
@@ -239,7 +239,7 @@ static int film_read_header(AVFormatContext *s)
         } else {
             film->sample_table[i].stream = film->video_stream_index;
             film->sample_table[i].pts = AV_RB32(&scratch[8]) & 0x7FFFFFFF;
-            film->sample_table[i].keyframe = (scratch[8] & 0x80) ? 0 : 1;
+            film->sample_table[i].keyframe = (scratch[8] & 0x80) ? AVINDEX_KEYFRAME : 0;
             video_frame_counter++;
             if (film->video_type)
                 av_add_index_entry(s->streams[film->video_stream_index],
@@ -286,6 +286,7 @@ static int film_read_packet(AVFormatContext *s,
 
     pkt->stream_index = sample->stream;
     pkt->pts = sample->pts;
+    pkt->flags |= sample->keyframe;
 
     film->current_sample++;
 
-- 
2.12.2.windows.2


More information about the ffmpeg-devel mailing list