diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2006-08-30 21:18:17 +0000 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2006-08-30 21:18:17 +0000 |
commit | 504ee036ee7f8bb2fc7e8d8278362f6250899d46 (patch) | |
tree | dc4d442c025c60fd353390d6e5b082e49f41acf9 /libavformat/utils.c | |
parent | 56d2d2d01a96ed801517f826285f4c9877f46db3 (diff) | |
download | ffmpeg-504ee036ee7f8bb2fc7e8d8278362f6250899d46.tar.gz |
fix b pyramid in mp4 muxing if no dts are provided to the muxer
Originally committed as revision 6133 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/utils.c')
-rw-r--r-- | libavformat/utils.c | 29 |
1 files changed, 14 insertions, 15 deletions
diff --git a/libavformat/utils.c b/libavformat/utils.c index 862cf8b707..e6de92c58e 100644 --- a/libavformat/utils.c +++ b/libavformat/utils.c @@ -2213,6 +2213,7 @@ void av_close_input_file(AVFormatContext *s) AVStream *av_new_stream(AVFormatContext *s, int id) { AVStream *st; + int i; if (s->nb_streams >= MAX_STREAMS) return NULL; @@ -2235,6 +2236,8 @@ AVStream *av_new_stream(AVFormatContext *s, int id) /* default pts settings is MPEG like */ av_set_pts_info(st, 33, 1, 90000); st->last_IP_pts = AV_NOPTS_VALUE; + for(i=0; i<MAX_REORDER_DELAY+1; i++) + st->pts_buffer[i]= AV_NOPTS_VALUE; s->streams[s->nb_streams++] = st; return st; @@ -2330,10 +2333,10 @@ int av_write_header(AVFormatContext *s) //FIXME merge with compute_pkt_fields static int compute_pkt_fields2(AVStream *st, AVPacket *pkt){ - int b_frames = FFMAX(st->codec->has_b_frames, st->codec->max_b_frames); - int num, den, frame_size; + int delay = FFMAX(st->codec->has_b_frames, !!st->codec->max_b_frames); + int num, den, frame_size, i; -// av_log(NULL, AV_LOG_DEBUG, "av_write_frame: pts:%lld dts:%lld cur_dts:%lld b:%d size:%d st:%d\n", pkt->pts, pkt->dts, st->cur_dts, b_frames, pkt->size, pkt->stream_index); +// av_log(NULL, AV_LOG_DEBUG, "av_write_frame: pts:%lld dts:%lld cur_dts:%lld b:%d size:%d st:%d\n", pkt->pts, pkt->dts, st->cur_dts, delay, pkt->size, pkt->stream_index); /* if(pkt->pts == AV_NOPTS_VALUE && pkt->dts == AV_NOPTS_VALUE) return -1;*/ @@ -2347,7 +2350,7 @@ static int compute_pkt_fields2(AVStream *st, AVPacket *pkt){ } //XXX/FIXME this is a temporary hack until all encoders output pts - if((pkt->pts == 0 || pkt->pts == AV_NOPTS_VALUE) && pkt->dts == AV_NOPTS_VALUE && !b_frames){ + if((pkt->pts == 0 || pkt->pts == AV_NOPTS_VALUE) && pkt->dts == AV_NOPTS_VALUE && !delay){ pkt->dts= // pkt->pts= st->cur_dts; pkt->pts= st->pts.val; @@ -2355,17 +2358,13 @@ static int compute_pkt_fields2(AVStream *st, AVPacket *pkt){ //calculate dts from pts if(pkt->pts != AV_NOPTS_VALUE && pkt->dts == AV_NOPTS_VALUE){ - if(b_frames){ - if(st->last_IP_pts == AV_NOPTS_VALUE){ - st->last_IP_pts= -pkt->duration; - } - if(st->last_IP_pts < pkt->pts){ - pkt->dts= st->last_IP_pts; - st->last_IP_pts= pkt->pts; - }else - pkt->dts= pkt->pts; - }else - pkt->dts= pkt->pts; + st->pts_buffer[0]= pkt->pts; + for(i=1; i<delay+1 && st->pts_buffer[i] == AV_NOPTS_VALUE; i++) + st->pts_buffer[i]= (i-delay-1) * pkt->duration; + for(i=0; i<delay && st->pts_buffer[i] > st->pts_buffer[i+1]; i++) + SWAP(int64_t, st->pts_buffer[i], st->pts_buffer[i+1]); + + pkt->dts= st->pts_buffer[0]; } if(st->cur_dts && st->cur_dts != AV_NOPTS_VALUE && st->cur_dts >= pkt->dts){ |