The value is a timestamp offset, not a duration.

Signed-off-by: James Almer <jamr...@gmail.com>
---
 libavformat/isom.h   |  2 +-
 libavformat/mov.c    | 29 +++++++++++++++--------------
 libavformat/movenc.c |  8 ++++----
 3 files changed, 20 insertions(+), 19 deletions(-)

diff --git a/libavformat/isom.h b/libavformat/isom.h
index 5aab5bad9b..ff08f2a48d 100644
--- a/libavformat/isom.h
+++ b/libavformat/isom.h
@@ -61,7 +61,7 @@ typedef struct MOVStts {
 
 typedef struct MOVCtts {
     unsigned int count;
-    int duration;
+    int offset;
 } MOVCtts;
 
 typedef struct MOVStsc {
diff --git a/libavformat/mov.c b/libavformat/mov.c
index 954ff657a9..3e94a21418 100644
--- a/libavformat/mov.c
+++ b/libavformat/mov.c
@@ -3977,7 +3977,7 @@ static int find_prev_closest_index(AVStream *st,
             // Find a "key frame" with PTS <= timestamp_pts (So that we can 
decode B-frames correctly).
             // No need to add dts_shift to the timestamp here becase 
timestamp_pts has already been
             // compensated by dts_shift above.
-            if ((e_old[*index].timestamp + ctts_data[*ctts_index].duration) <= 
timestamp_pts &&
+            if ((e_old[*index].timestamp + ctts_data[*ctts_index].offset) <= 
timestamp_pts &&
                 (e_old[*index].flags & AVINDEX_KEYFRAME)) {
                 break;
             }
@@ -4068,7 +4068,7 @@ static void fix_index_entry_timestamps(AVStream* st, int 
end_index, int64_t end_
  * Returns the new ctts_count if successful, else returns -1.
  */
 static int64_t add_ctts_entry(MOVCtts** ctts_data, unsigned int* ctts_count, 
unsigned int* allocated_size,
-                              int count, int duration)
+                              int count, int offset)
 {
     MOVCtts *ctts_buf_new;
     const size_t min_size_needed = (*ctts_count + 1) * sizeof(MOVCtts);
@@ -4088,7 +4088,7 @@ static int64_t add_ctts_entry(MOVCtts** ctts_data, 
unsigned int* ctts_count, uns
     *ctts_data = ctts_buf_new;
 
     ctts_buf_new[*ctts_count].count = count;
-    ctts_buf_new[*ctts_count].duration = duration;
+    ctts_buf_new[*ctts_count].offset = offset;
 
     *ctts_count = (*ctts_count) + 1;
     return *ctts_count;
@@ -4118,7 +4118,7 @@ static void mov_estimate_video_delay(MOVContext *c, 
AVStream* st)
             if (buf_start == MAX_REORDER_DELAY + 1)
                 buf_start = 0;
 
-            pts_buf[j] = sti->index_entries[ind].timestamp + 
msc->ctts_data[ctts_ind].duration;
+            pts_buf[j] = sti->index_entries[ind].timestamp + 
msc->ctts_data[ctts_ind].offset;
 
             // The timestamps that are already in the sorted buffer, and are 
greater than the
             // current pts, are exactly the timestamps that need to be 
buffered to output PTS
@@ -4347,7 +4347,7 @@ static void mov_fix_index(MOVContext *mov, AVStream *st)
             curr_ctts = 0;
 
             if (ctts_data_old && ctts_index_old < ctts_count_old) {
-                curr_ctts = ctts_data_old[ctts_index_old].duration;
+                curr_ctts = ctts_data_old[ctts_index_old].offset;
                 av_log(mov->fc, AV_LOG_TRACE, "stts: %"PRId64" ctts: 
%"PRId64", ctts_index: %"PRId64", ctts_count: %"PRId64"\n",
                        curr_cts, curr_ctts, ctts_index_old, ctts_count_old);
                 curr_cts += curr_ctts;
@@ -4356,11 +4356,11 @@ static void mov_fix_index(MOVContext *mov, AVStream *st)
                     if (add_ctts_entry(&msc->ctts_data, &msc->ctts_count,
                                        &msc->ctts_allocated_size,
                                        ctts_data_old[ctts_index_old].count - 
edit_list_start_ctts_sample,
-                                       ctts_data_old[ctts_index_old].duration) 
== -1) {
+                                       ctts_data_old[ctts_index_old].offset) 
== -1) {
                         av_log(mov->fc, AV_LOG_ERROR, "Cannot add CTTS entry 
%"PRId64" - {%"PRId64", %d}\n",
                                ctts_index_old,
                                ctts_data_old[ctts_index_old].count - 
edit_list_start_ctts_sample,
-                               ctts_data_old[ctts_index_old].duration);
+                               ctts_data_old[ctts_index_old].offset);
                         break;
                     }
                     ctts_index_old++;
@@ -4463,10 +4463,10 @@ static void mov_fix_index(MOVContext *mov, AVStream *st)
                         if (add_ctts_entry(&msc->ctts_data, &msc->ctts_count,
                                            &msc->ctts_allocated_size,
                                            ctts_sample_old - 
edit_list_start_ctts_sample,
-                                           
ctts_data_old[ctts_index_old].duration) == -1) {
+                                           
ctts_data_old[ctts_index_old].offset) == -1) {
                             av_log(mov->fc, AV_LOG_ERROR, "Cannot add CTTS 
entry %"PRId64" - {%"PRId64", %d}\n",
                                    ctts_index_old, ctts_sample_old - 
edit_list_start_ctts_sample,
-                                   ctts_data_old[ctts_index_old].duration);
+                                   ctts_data_old[ctts_index_old].offset);
                             break;
                         }
                     }
@@ -4540,7 +4540,7 @@ static int build_open_gop_key_points(AVStream *st)
     k = 0;
     for (uint32_t i = 0; i < sc->ctts_count; i++)
         for (int j = 0; j < sc->ctts_data[i].count; j++)
-             sc->sample_offsets[k++] = sc->ctts_data[i].duration;
+             sc->sample_offsets[k++] = sc->ctts_data[i].offset;
 
     /* The following HEVC NAL type reveal the use of open GOP sync points
      * (TODO: BLA types may also be concerned) */
@@ -4693,7 +4693,7 @@ static void mov_build_index(MOVContext *mov, AVStream *st)
                             sc->ctts_count < sc->sample_count; j++)
                     add_ctts_entry(&sc->ctts_data, &sc->ctts_count,
                                    &sc->ctts_allocated_size, 1,
-                                   ctts_data_old[i].duration);
+                                   ctts_data_old[i].offset);
             av_free(ctts_data_old);
         }
 
@@ -4900,7 +4900,7 @@ static void mov_build_index(MOVContext *mov, AVStream *st)
     if (st->start_time == AV_NOPTS_VALUE && st->codecpar->codec_type == 
AVMEDIA_TYPE_VIDEO && sti->nb_index_entries > 0) {
         st->start_time = sti->index_entries[0].timestamp + sc->dts_shift;
         if (sc->ctts_data) {
-            st->start_time += sc->ctts_data[0].duration;
+            st->start_time += sc->ctts_data[0].offset;
         }
     }
 
@@ -5910,7 +5910,7 @@ static int mov_read_trun(MOVContext *c, AVIOContext *pb, 
MOVAtom atom)
         sti->index_entries[index_entry_pos].flags = index_entry_flags;
 
         sc->ctts_data[index_entry_pos].count = 1;
-        sc->ctts_data[index_entry_pos].duration = ctts_duration;
+        sc->ctts_data[index_entry_pos].offset = ctts_duration;
         index_entry_pos++;
 
         av_log(c->fc, AV_LOG_TRACE, "AVIndex stream %d, sample %d, offset 
%"PRIx64", dts %"PRId64", "
@@ -10721,7 +10721,8 @@ static int mov_finalize_packet(AVFormatContext *s, 
AVStream *st, AVIndexEntry *s
         pkt->flags |= AV_PKT_FLAG_DISCARD;
     }
     if (sc->ctts_data && sc->ctts_index < sc->ctts_count) {
-        pkt->pts = av_sat_add64(pkt->dts, av_sat_add64(sc->dts_shift, 
sc->ctts_data[sc->ctts_index].duration));
+        pkt->pts = av_sat_add64(pkt->dts, av_sat_add64(sc->dts_shift, 
sc->ctts_data[sc->ctts_index].offset));
+
         /* update ctts context */
         sc->ctts_sample++;
         if (sc->ctts_index < sc->ctts_count &&
diff --git a/libavformat/movenc.c b/libavformat/movenc.c
index 0544eace6d..94f068ebe1 100644
--- a/libavformat/movenc.c
+++ b/libavformat/movenc.c
@@ -3004,13 +3004,13 @@ static int mov_write_ctts_tag(AVFormatContext *s, 
AVIOContext *pb, MOVTrack *tra
     if (!ctts_entries)
         return AVERROR(ENOMEM);
     ctts_entries[0].count = 1;
-    ctts_entries[0].duration = track->cluster[0].cts;
+    ctts_entries[0].offset = track->cluster[0].cts;
     for (i = 1; i < track->entry; i++) {
-        if (track->cluster[i].cts == ctts_entries[entries].duration) {
+        if (track->cluster[i].cts == ctts_entries[entries].offset) {
             ctts_entries[entries].count++; /* compress */
         } else {
             entries++;
-            ctts_entries[entries].duration = track->cluster[i].cts;
+            ctts_entries[entries].offset = track->cluster[i].cts;
             ctts_entries[entries].count = 1;
         }
     }
@@ -3026,7 +3026,7 @@ static int mov_write_ctts_tag(AVFormatContext *s, 
AVIOContext *pb, MOVTrack *tra
     avio_wb32(pb, entries); /* entry count */
     for (i = 0; i < entries; i++) {
         avio_wb32(pb, ctts_entries[i].count);
-        avio_wb32(pb, ctts_entries[i].duration);
+        avio_wb32(pb, ctts_entries[i].offset);
     }
     av_free(ctts_entries);
     return atom_size;
-- 
2.47.0

_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

To unsubscribe, visit link above, or email
ffmpeg-devel-requ...@ffmpeg.org with subject "unsubscribe".

Reply via email to