Commit 85169a75 authored by Marton Balint's avatar Marton Balint

avformat/segment: remove last_cut check when detecting a new segment

Not starting a new segment if the elapsed microsecs since the start of the day
equals the the elapsed microsecs since the start of the day at the time of the
last cut seems plain wrong to me, Deti do you remember the original reason
behind this check?
Signed-off-by: 's avatarMarton Balint <cus@passwd.hu>
parent af621b6d
...@@ -87,7 +87,6 @@ typedef struct SegmentContext { ...@@ -87,7 +87,6 @@ typedef struct SegmentContext {
int64_t clocktime_offset; //< clock offset for cutting the segments at regular clock time int64_t clocktime_offset; //< clock offset for cutting the segments at regular clock time
int64_t clocktime_wrap_duration; //< wrapping duration considered for starting a new segment int64_t clocktime_wrap_duration; //< wrapping duration considered for starting a new segment
int64_t last_val; ///< remember last time for wrap around detection int64_t last_val; ///< remember last time for wrap around detection
int64_t last_cut; ///< remember last cut
int cut_pending; int cut_pending;
int header_written; ///< whether we've already called avformat_write_header int header_written; ///< whether we've already called avformat_write_header
...@@ -870,10 +869,8 @@ calc_times: ...@@ -870,10 +869,8 @@ calc_times:
localtime_r(&sec, &ti); localtime_r(&sec, &ti);
usecs = (int64_t)(ti.tm_hour * 3600 + ti.tm_min * 60 + ti.tm_sec) * 1000000 + (avgt % 1000000); usecs = (int64_t)(ti.tm_hour * 3600 + ti.tm_min * 60 + ti.tm_sec) * 1000000 + (avgt % 1000000);
wrapped_val = (usecs + seg->clocktime_offset) % seg->time; wrapped_val = (usecs + seg->clocktime_offset) % seg->time;
if (seg->last_cut != usecs && wrapped_val < seg->last_val && wrapped_val < seg->clocktime_wrap_duration) { if (wrapped_val < seg->last_val && wrapped_val < seg->clocktime_wrap_duration)
seg->cut_pending = 1; seg->cut_pending = 1;
seg->last_cut = usecs;
}
seg->last_val = wrapped_val; seg->last_val = wrapped_val;
} else { } else {
end_pts = seg->time * (seg->segment_count + 1); end_pts = seg->time * (seg->segment_count + 1);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment