[FFmpeg-cvslog] r18781 - trunk/libavformat/mpegtsenc.c
bcoudurier
subversion
Sun May 10 03:57:21 CEST 2009
Author: bcoudurier
Date: Sun May 10 03:57:21 2009
New Revision: 18781
Log:
ensure first pts is set, according to specs
Modified:
trunk/libavformat/mpegtsenc.c
Modified: trunk/libavformat/mpegtsenc.c
==============================================================================
--- trunk/libavformat/mpegtsenc.c Sun May 10 03:41:35 2009 (r18780)
+++ trunk/libavformat/mpegtsenc.c Sun May 10 03:57:21 2009 (r18781)
@@ -173,6 +173,7 @@ typedef struct MpegTSWriteStream {
int pid; /* stream associated pid */
int cc;
int payload_index;
+ int first_pts_check; ///< first pts check needed
int64_t payload_pts;
int64_t payload_dts;
uint8_t payload[DEFAULT_PES_PAYLOAD_SIZE];
@@ -419,6 +420,7 @@ static int mpegts_write_header(AVFormatC
ts_st->pid = DEFAULT_START_PID + i;
ts_st->payload_pts = AV_NOPTS_VALUE;
ts_st->payload_dts = AV_NOPTS_VALUE;
+ ts_st->first_pts_check = 1;
/* update PCR pid by using the first video stream */
if (st->codec->codec_type == CODEC_TYPE_VIDEO &&
service->pcr_pid == 0x1fff)
@@ -701,6 +703,12 @@ static int mpegts_write_packet(AVFormatC
if (pkt->dts != AV_NOPTS_VALUE)
dts = pkt->dts + delay;
+ if (ts_st->first_pts_check && pts == AV_NOPTS_VALUE) {
+ av_log(s, AV_LOG_ERROR, "first pts value must set\n");
+ return -1;
+ }
+ ts_st->first_pts_check = 0;
+
if (st->codec->codec_type == CODEC_TYPE_SUBTITLE) {
/* for subtitle, a single PES packet must be generated */
mpegts_write_pes(s, st, buf, size, pts, AV_NOPTS_VALUE);
More information about the ffmpeg-cvslog
mailing list