X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=libavformat%2Fidroqdec.c;h=519f31d61a09547c12d70e091ff787f51bc00529;hb=a04ad248a05e7b613abe09b3bb067f555108d794;hp=8fd67a6818b37c0c0742bb57e3603100948b41a0;hpb=022fa7a24ea8f5000e7b6a50e57cc752f417da47;p=ffmpeg diff --git a/libavformat/idroqdec.c b/libavformat/idroqdec.c index 8fd67a6818b..519f31d61a0 100644 --- a/libavformat/idroqdec.c +++ b/libavformat/idroqdec.c @@ -59,7 +59,7 @@ typedef struct RoqDemuxContext { } RoqDemuxContext; -static int roq_probe(AVProbeData *p) +static int roq_probe(const AVProbeData *p) { if ((AV_RL16(&p->buf[0]) != RoQ_MAGIC_NUMBER) || (AV_RL32(&p->buf[2]) != 0xFFFFFFFF)) @@ -205,8 +205,9 @@ static int roq_read_packet(AVFormatContext *s, } /* load up the packet */ - if (av_new_packet(pkt, chunk_size + RoQ_CHUNK_PREAMBLE_SIZE)) - return AVERROR(EIO); + ret = av_new_packet(pkt, chunk_size + RoQ_CHUNK_PREAMBLE_SIZE); + if (ret < 0) + return ret; /* copy over preamble */ memcpy(pkt->data, preamble, RoQ_CHUNK_PREAMBLE_SIZE); @@ -223,8 +224,7 @@ static int roq_read_packet(AVFormatContext *s, ret = avio_read(pb, pkt->data + RoQ_CHUNK_PREAMBLE_SIZE, chunk_size); if (ret != chunk_size) { - av_packet_unref(pkt); - ret = AVERROR(EIO); + return AVERROR(EIO); } packet_read = 1;