Commit 24912093 authored by Gildas Bazin's avatar Gildas Bazin

* modules/demux/mp4/mp4.c: fixed bug in PTS calculation.

parent 28932b3b
...@@ -77,7 +77,7 @@ typedef struct ...@@ -77,7 +77,7 @@ typedef struct
uint32_t *p_sample_delta_dts; /* dts delta */ uint32_t *p_sample_delta_dts; /* dts delta */
uint32_t *p_sample_count_pts; uint32_t *p_sample_count_pts;
uint32_t *p_sample_offset_pts; /* pts-dts */ int32_t *p_sample_offset_pts; /* pts-dts */
/* TODO if needed add pts /* TODO if needed add pts
but quickly *add* support for edts and seeking */ but quickly *add* support for edts and seeking */
...@@ -228,7 +228,8 @@ static inline int64_t MP4_TrackGetPTSDelta( demux_t *p_demux, mp4_track_t *p_tra ...@@ -228,7 +228,8 @@ static inline int64_t MP4_TrackGetPTSDelta( demux_t *p_demux, mp4_track_t *p_tra
for( i_index = 0;; i_index++ ) for( i_index = 0;; i_index++ )
{ {
if( i_sample < ck->p_sample_count_pts[i_index] ) if( i_sample < ck->p_sample_count_pts[i_index] )
return ck->p_sample_offset_pts[i_index] * I64C(1000000) / p_track->i_timescale; return ck->p_sample_offset_pts[i_index] * I64C(1000000) /
(int64_t)p_track->i_timescale;
i_sample -= ck->p_sample_count_pts[i_index]; i_sample -= ck->p_sample_count_pts[i_index];
} }
...@@ -1145,7 +1146,7 @@ static int TrackCreateSamplesIndex( demux_t *p_demux, ...@@ -1145,7 +1146,7 @@ static int TrackCreateSamplesIndex( demux_t *p_demux,
/* allocate them */ /* allocate them */
ck->p_sample_count_pts = calloc( i_entry, sizeof( uint32_t ) ); ck->p_sample_count_pts = calloc( i_entry, sizeof( uint32_t ) );
ck->p_sample_offset_pts = calloc( i_entry, sizeof( uint32_t ) ); ck->p_sample_offset_pts = calloc( i_entry, sizeof( int32_t ) );
/* now copy */ /* now copy */
i_sample_count = ck->i_sample_count; i_sample_count = ck->i_sample_count;
......
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