Browse Source

asfenc: return error on negative timestamp

According to the specification the timestamp is represented by a 32bit
unsigned.

CC: libav-stable@libav.org
tags/n2.0
Luca Barbato 13 years ago
parent
commit
d1bec33b46
1 changed files with 8 additions and 0 deletions
  1. +8
    -0
      libavformat/asfenc.c

+ 8
- 0
libavformat/asfenc.c View File

@@ -774,6 +774,14 @@ static int asf_write_packet(AVFormatContext *s, AVPacket *pkt)
flags &= ~AV_PKT_FLAG_KEY;

pts = (pkt->pts != AV_NOPTS_VALUE) ? pkt->pts : pkt->dts;

if (pts < 0) {
av_log(s, AV_LOG_ERROR,
"Negative dts not supported stream %d, dts %"PRId64"\n",
pkt->stream_index, pts);
return AVERROR(ENOSYS);
}

assert(pts != AV_NOPTS_VALUE);
duration = pts * 10000;
asf->duration = FFMAX(asf->duration, duration + pkt->duration * 10000);


Loading…
Cancel
Save