[FFmpeg-cvslog] r10020 - in trunk/libavformat: Makefile nut.c nut.h nutdec.c
michael
subversion
Thu Aug 9 18:29:30 CEST 2007
Author: michael
Date: Thu Aug 9 18:29:30 2007
New Revision: 10020
Log:
move syncpoint timestamp reseting code to a common file
Added:
trunk/libavformat/nut.c
Modified:
trunk/libavformat/Makefile
trunk/libavformat/nut.h
trunk/libavformat/nutdec.c
Modified: trunk/libavformat/Makefile
==============================================================================
--- trunk/libavformat/Makefile (original)
+++ trunk/libavformat/Makefile Thu Aug 9 18:29:30 2007
@@ -101,7 +101,7 @@ OBJS-$(CONFIG_MTV_DEMUXER)
OBJS-$(CONFIG_MXF_DEMUXER) += mxf.o
OBJS-$(CONFIG_NSV_DEMUXER) += nsvdec.o
OBJS-$(CONFIG_NULL_MUXER) += raw.o
-OBJS-$(CONFIG_NUT_DEMUXER) += nutdec.o riff.o
+OBJS-$(CONFIG_NUT_DEMUXER) += nutdec.o nut.o riff.o
OBJS-$(CONFIG_NUV_DEMUXER) += nuv.o riff.o
OBJS-$(CONFIG_OGG_DEMUXER) += ogg2.o \
oggparsevorbis.o \
Added: trunk/libavformat/nut.c
==============================================================================
--- (empty file)
+++ trunk/libavformat/nut.c Thu Aug 9 18:29:30 2007
@@ -0,0 +1,33 @@
+/*
+ * nut
+ * Copyright (c) 2004-2007 Michael Niedermayer
+ *
+ * This file is part of FFmpeg.
+ *
+ * FFmpeg is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * FFmpeg is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with FFmpeg; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#include "nut.h"
+
+void ff_nut_reset_ts(NUTContext *nut, AVRational time_base, int64_t val){
+ int i;
+ for(i=0; i<nut->avf->nb_streams; i++){
+ nut->stream[i].last_pts= av_rescale_rnd(
+ val / nut->time_base_count,
+ time_base.num * (int64_t)nut->stream[i].time_base->den,
+ time_base.den * (int64_t)nut->stream[i].time_base->num,
+ AV_ROUND_DOWN);
+ }
+}
Modified: trunk/libavformat/nut.h
==============================================================================
--- trunk/libavformat/nut.h (original)
+++ trunk/libavformat/nut.h Thu Aug 9 18:29:30 2007
@@ -98,4 +98,6 @@ static unsigned long av_crc04C11DB7_upda
return av_crc(av_crc04C11DB7, checksum, buf, len);
}
+void ff_nut_reset_ts(NUTContext *nut, AVRational time_base, int64_t val);
+
#endif /* AVFORMAT_NUT_H */
Modified: trunk/libavformat/nutdec.c
==============================================================================
--- trunk/libavformat/nutdec.c (original)
+++ trunk/libavformat/nutdec.c Thu Aug 9 18:29:30 2007
@@ -447,7 +447,6 @@ static int decode_syncpoint(NUTContext *
AVFormatContext *s= nut->avf;
ByteIOContext *bc = &s->pb;
int64_t end, tmp;
- int i;
AVRational time_base;
nut->last_syncpoint_pos= url_ftell(bc)-8;
@@ -460,16 +459,7 @@ static int decode_syncpoint(NUTContext *
if(*back_ptr < 0)
return -1;
- time_base= nut->time_base[tmp % nut->time_base_count];
- for(i=0; i<s->nb_streams; i++){
- nut->stream[i].last_pts= av_rescale_rnd(
- tmp / nut->time_base_count,
- time_base.num * (int64_t)nut->stream[i].time_base->den,
- time_base.den * (int64_t)nut->stream[i].time_base->num,
- AV_ROUND_DOWN);
- //last_key_frame ?
- }
- //FIXME put this in a reset func maybe
+ ff_nut_reset_ts(nut, nut->time_base[tmp % nut->time_base_count], tmp);
if(skip_reserved(bc, end) || get_checksum(bc)){
av_log(s, AV_LOG_ERROR, "sync point checksum mismatch\n");
More information about the ffmpeg-cvslog
mailing list