asfenc: return error on negative timestamp
According to the specification the timestamp is represented by a 32bit unsigned. CC: libav-stable@libav.org
This commit is contained in:
parent
6552808014
commit
d1bec33b46
@ -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…
Reference in New Issue
Block a user