[FFmpeg-devel] [PATCH 4/4] avformat/img2dec: support nanosecond file times

Michael Niedermayer michaelni at gmx.at
Sat Apr 12 05:05:21 CEST 2014


On Mon, May 27, 2013 at 11:24:02PM +0200, Clément Bœsch wrote:
> On Sat, May 25, 2013 at 03:58:04PM +0200, Michael Niedermayer wrote:
> > Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> > ---
> >  libavformat/img2dec.c |   15 +++++++++++++--
> >  1 file changed, 13 insertions(+), 2 deletions(-)
> > 
> > diff --git a/libavformat/img2dec.c b/libavformat/img2dec.c
> > index b847d6c..ea4ee0f 100644
> > --- a/libavformat/img2dec.c
> > +++ b/libavformat/img2dec.c
> > @@ -20,6 +20,7 @@
> >   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
> >   */
> >  
> > +#define _BSD_SOURCE
> >  #include <sys/stat.h>
> >  #include "libavutil/avstring.h"
> >  #include "libavutil/log.h"
> > @@ -225,7 +226,13 @@ static int img_read_header(AVFormatContext *s1)
> >          st->need_parsing = AVSTREAM_PARSE_FULL;
> >      }
> >  
> > -    if (s->ts_from_file)
> > +    if (s->ts_from_file == 2) {
> > +#if !HAVE_STRUCT_STAT_ST_MTIM_TV_NSEC
> > +        av_log(s1, AV_LOG_ERROR, "POSIX.1-2008 not supported, nanosecond file timestamps unavailable\n");
> > +        return AVERROR(ENOSYS);
> > +#endif
> > +        avpriv_set_pts_info(st, 64, 1, 1000000000);
> > +    } else if (s->ts_from_file)
> >          avpriv_set_pts_info(st, 64, 1, 1);
> >      else
> >          avpriv_set_pts_info(st, 64, s->framerate.den, s->framerate.num);
> > @@ -393,6 +400,10 @@ static int img_read_packet(AVFormatContext *s1, AVPacket *pkt)
> >          if (stat(filename, &img_stat))
> >              return AVERROR(EIO);
> >          pkt->pts = (int64_t)img_stat.st_mtime;
> > +#if HAVE_STRUCT_STAT_ST_MTIM_TV_NSEC
> > +        if (s->ts_from_file == 2)
> > +            pkt->pts = 1000000000*pkt->pts + img_stat.st_mtim.tv_nsec;
> > +#endif
> >          av_add_index_entry(s1->streams[0], s->img_number, pkt->pts, 0, 0, AVINDEX_KEYFRAME);
> >      } else if (!s->is_pipe) {
> >          pkt->pts      = s->pts;
> > @@ -467,7 +478,7 @@ static const AVOption options[] = {
> >      { "start_number_range", "set range for looking at the first sequence number", OFFSET(start_number_range), AV_OPT_TYPE_INT, {.i64 = 5}, 1, INT_MAX, DEC },
> >      { "video_size",   "set video size",                      OFFSET(width),        AV_OPT_TYPE_IMAGE_SIZE, {.str = NULL}, 0, 0,   DEC },
> >      { "frame_size",   "force frame size in bytes",           OFFSET(frame_size),   AV_OPT_TYPE_INT,    {.i64 = 0   }, 0, INT_MAX, DEC },
> > -    { "ts_from_file", "set frame timestamp from file's one", OFFSET(ts_from_file), AV_OPT_TYPE_INT,    {.i64 = 0   }, 0, 1,       DEC },
> > +    { "ts_from_file", "set frame timestamp from file's one", OFFSET(ts_from_file), AV_OPT_TYPE_INT,    {.i64 = 0   }, 0, 2,       DEC },
> >      { NULL },
> 
> 0, 1 and 2 are not intuitive, especially without a documentation update.
> Could you add some const?

added and applied


> 
> Use case examples would be welcome. How does this behave when you mix this
> with -vsync cfr/vfr?

it should behave the same as any other input with timestamps
in nanosecond precission

[...]

-- 
Michael     GnuPG fingerprint: 9FF2128B147EF6730BADF133611EC787040B0FAB

Its not that you shouldnt use gotos but rather that you should write
readable code and code with gotos often but not always is less readable
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 198 bytes
Desc: Digital signature
URL: <http://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20140412/d395a9a4/attachment.asc>


More information about the ffmpeg-devel mailing list