[FFmpeg-devel] [PATCH] mxfdec: set audio packet pts

Matthieu Bouron matthieu.bouron at gmail.com
Thu Sep 13 11:28:07 CEST 2012


On Thu, Sep 13, 2012 at 11:25 AM, Tomas Härdin <tomas.hardin at codemill.se>wrote:

> On Wed, 2012-09-12 at 13:06 +0200, Michael Niedermayer wrote:
> > @@ -2045,12 +2046,14 @@ static int mxf_read_packet_old(AVFormatContext
> *s, AVPacket *pkt)
> >              pkt->stream_index = index;
> >              pkt->pos = klv.offset;
> >
> > -            if (s->streams[index]->codec->codec_type ==
> AVMEDIA_TYPE_VIDEO && next_ofs >= 0) {
> > +            codec_type = s->streams[index]->codec->codec_type;
> > +            if ((codec_type == AVMEDIA_TYPE_AUDIO || codec_type ==
> AVMEDIA_TYPE_VIDEO) && next_ofs >= 0) {
> >                  /* mxf->current_edit_unit good - see if we have an
> index table to derive timestamps from */
> >                  MXFIndexTable *t = &mxf->index_tables[0];
> >
> >                  if (mxf->nb_index_tables >= 1 && mxf->current_edit_unit
> < t->nb_ptses) {
> > -                    pkt->dts = mxf->current_edit_unit + t->first_dts;
> > +                    if (codec_type == AVMEDIA_TYPE_VIDEO)
> > +                        pkt->dts = mxf->current_edit_unit +
> t->first_dts;
> >                      pkt->pts = t->ptses[mxf->current_edit_unit];
>
> Setting audio PTSes to the reordered values is simply wrong. We had a
> discussion about fixing NTSC stuff "properly" (within the limits of
> MXF). The TL;DR of it is that st->time_base should be the samplerate and
> that audio timestamps need to be extrapolated. I don't have time to work
> on this at the moment though.
>

A new patch is on the way and should be ready in a few days.

Matthieu


More information about the ffmpeg-devel mailing list