Mercurial > libavformat.hg
changeset 1285:b5226e679a31 libavformat
fix b pyramid in mp4 muxing if no dts are provided to the muxer
author | michael |
---|---|
date | Wed, 30 Aug 2006 21:18:17 +0000 |
parents | 5abdc17dc283 |
children | 8b423c6ae233 |
files | avformat.h utils.c |
diffstat | 2 files changed, 18 insertions(+), 16 deletions(-) [+] |
line wrap: on
line diff
--- a/avformat.h Tue Aug 29 12:03:07 2006 +0000 +++ b/avformat.h Wed Aug 30 21:18:17 2006 +0000 @@ -266,6 +266,9 @@ int index_entries_allocated_size; int64_t nb_frames; ///< number of frames in this stream if known or 0 + +#define MAX_REORDER_DELAY 4 + int64_t pts_buffer[MAX_REORDER_DELAY+1]; } AVStream; #define AVFMTCTX_NOHEADER 0x0001 /* signal that no header is present
--- a/utils.c Tue Aug 29 12:03:07 2006 +0000 +++ b/utils.c Wed Aug 30 21:18:17 2006 +0000 @@ -2213,6 +2213,7 @@ AVStream *av_new_stream(AVFormatContext *s, int id) { AVStream *st; + int i; if (s->nb_streams >= MAX_STREAMS) return NULL; @@ -2235,6 +2236,8 @@ /* 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 @@ //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; - -// 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); + 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, delay, pkt->size, pkt->stream_index); /* if(pkt->pts == AV_NOPTS_VALUE && pkt->dts == AV_NOPTS_VALUE) return -1;*/ @@ -2347,7 +2350,7 @@ } //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 @@ //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){