X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=libavformat%2Felectronicarts.c;h=2ee5e1b6fad58d24cec9fda59ba0bafa07f34751;hb=f93bd302821e08df5ee037e67c4b85bec5d4d475;hp=bfd3fed3a2a537a1f8e585d65f83baa7d5938fed;hpb=0ff76ca86e0ea4dcf2b392c45f5fac8e5576bb0d;p=ffmpeg diff --git a/libavformat/electronicarts.c b/libavformat/electronicarts.c index bfd3fed3a2a..2ee5e1b6fad 100644 --- a/libavformat/electronicarts.c +++ b/libavformat/electronicarts.c @@ -458,7 +458,7 @@ static int process_ea_header(AVFormatContext *s) return 1; } -static int ea_probe(AVProbeData *p) +static int ea_probe(const AVProbeData *p) { unsigned big_endian, size; @@ -574,11 +574,12 @@ static int ea_read_packet(AVFormatContext *s, AVPacket *pkt) EaDemuxContext *ea = s->priv_data; AVIOContext *pb = s->pb; int partial_packet = 0; + int hit_end = 0; unsigned int chunk_type, chunk_size; int ret = 0, packet_read = 0, key = 0; int av_uninit(num_samples); - while (!packet_read || partial_packet) { + while ((!packet_read && !hit_end) || partial_packet) { chunk_type = avio_rl32(pb); chunk_size = ea->big_endian ? avio_rb32(pb) : avio_rl32(pb); if (chunk_size < 8) @@ -632,7 +633,6 @@ static int ea_read_packet(AVFormatContext *s, AVPacket *pkt) case AV_CODEC_ID_ADPCM_EA_R3: if (pkt->size < 4) { av_log(s, AV_LOG_ERROR, "Packet is too short\n"); - av_packet_unref(pkt); return AVERROR_INVALIDDATA; } if (ea->audio_codec == AV_CODEC_ID_ADPCM_EA_R3) @@ -676,7 +676,7 @@ static int ea_read_packet(AVFormatContext *s, AVPacket *pkt) } if (avio_feof(pb)) ret = AVERROR_EOF; - packet_read = 1; + hit_end = 1; break; case MVIh_TAG: @@ -735,8 +735,9 @@ get_video_packet: } } - if (ret < 0 && partial_packet) - av_packet_unref(pkt); + if (ret >= 0 && hit_end && !packet_read) + return AVERROR(EAGAIN); + return ret; }