Commit 9d2dd3ae authored by reimar's avatar reimar

Check for av_new_stream failure, fixes CID76 RUN2


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@13533 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 15a2a87e
......@@ -82,6 +82,8 @@ static int get_sindex(AVFormatContext *s, int id, int format) {
return i;
}
st = av_new_stream(s, id);
if (!st)
return AVERROR(ENOMEM);
switch (format) {
case 3:
case 4:
......@@ -415,6 +417,7 @@ static int gxf_packet(AVFormatContext *s, AVPacket *pkt) {
while (!url_feof(pb)) {
int track_type, track_id, ret;
int field_nr;
int stream_index;
if (!parse_packet_header(pb, &pkt_type, &pkt_len)) {
if (!url_feof(pb))
av_log(s, AV_LOG_ERROR, "GXF: sync lost\n");
......@@ -435,6 +438,9 @@ static int gxf_packet(AVFormatContext *s, AVPacket *pkt) {
pkt_len -= 16;
track_type = get_byte(pb);
track_id = get_byte(pb);
stream_index = get_sindex(s, track_id, track_type);
if (stream_index < 0)
return stream_index;
field_nr = get_be32(pb);
get_be32(pb); // field information
get_be32(pb); // "timeline" field number
......@@ -444,7 +450,7 @@ static int gxf_packet(AVFormatContext *s, AVPacket *pkt) {
// field information, it might be better to take this into account
// as well.
ret = av_get_packet(pb, pkt, pkt_len);
pkt->stream_index = get_sindex(s, track_id, track_type);
pkt->stream_index = stream_index;
pkt->dts = field_nr;
return ret;
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment