[FFmpeg-devel] [PATCH 5/6] avformat/mov: Notify new sequence at the start of editlist
Zhao Zhili
quinkblack at foxmail.com
Tue Mar 18 14:58:51 EET 2025
From: Zhao Zhili <zhilizhao at tencent.com>
---
libavformat/avformat.h | 2 ++
libavformat/mov.c | 19 +++++++++++++------
2 files changed, 15 insertions(+), 6 deletions(-)
diff --git a/libavformat/avformat.h b/libavformat/avformat.h
index 498c557a3c..f83151a73f 100644
--- a/libavformat/avformat.h
+++ b/libavformat/avformat.h
@@ -611,6 +611,8 @@ typedef struct AVIndexEntry {
#define AVINDEX_DISCARD_FRAME 0x0002 /**
* Flag is used to indicate which frame should be discarded after decoding.
*/
+#define AVINDEX_NEW_SEQUENCE 0x0004 /* Mark the start of a new sequence */
+
int flags:2;
int size:30; //Yeah, trying to keep the size of this small to reduce memory requirements (it is 24 vs. 32 bytes due to possible 8-byte alignment).
int min_distance; /**< Minimum distance between this and the previous keyframe, used to avoid unneeded searching. */
diff --git a/libavformat/mov.c b/libavformat/mov.c
index bf526db67a..787a2b87e6 100644
--- a/libavformat/mov.c
+++ b/libavformat/mov.c
@@ -4394,20 +4394,23 @@ static void mov_fix_index(MOVContext *mov, AVStream *st)
}
}
- if (add_index_entry(st, current->pos, edit_list_dts_counter, current->size,
- current->min_distance, flags) == -1) {
- av_log(mov->fc, AV_LOG_ERROR, "Cannot add index entry\n");
- break;
- }
// Update the index ranges array
if (!current_index_range || index != current_index_range->end) {
current_index_range = current_index_range ? current_index_range + 1
: msc->index_ranges;
current_index_range->start = index;
+ if ((flags & AVINDEX_KEYFRAME) && st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO)
+ flags |= AVINDEX_NEW_SEQUENCE;
}
current_index_range->end = index + 1;
+ if (add_index_entry(st, current->pos, edit_list_dts_counter, current->size,
+ current->min_distance, flags) == -1) {
+ av_log(mov->fc, AV_LOG_ERROR, "Cannot add index entry\n");
+ break;
+ }
+
// Only start incrementing DTS in frame_duration amounts, when we encounter a frame in edit list.
if (edit_list_start_encountered > 0) {
edit_list_dts_counter = edit_list_dts_counter + frame_duration;
@@ -10889,7 +10892,11 @@ static int mov_finalize_packet(AVFormatContext *s, AVStream *st, AVIndexEntry *s
uint8_t sample_is_depended_on = (sample_flags >> 2) & 0x3;
pkt->flags |= sample_is_depended_on == MOV_SAMPLE_DEPENDENCY_NO ? AV_PKT_FLAG_DISPOSABLE : 0;
}
- pkt->flags |= sample->flags & AVINDEX_KEYFRAME ? AV_PKT_FLAG_KEY : 0;
+ if (sample->flags & AVINDEX_KEYFRAME) {
+ pkt->flags |= AV_PKT_FLAG_KEY;
+ if (sample->flags & AVINDEX_NEW_SEQUENCE)
+ pkt->flags |= AV_PKT_FLAG_NEW_SEQUENCE;
+ }
pkt->pos = sample->pos;
/* Multiple stsd handling. */
--
2.46.0
More information about the ffmpeg-devel
mailing list