X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=libavformat%2Fboadec.c;h=69d17763ef774633501b9b46561919d5403f1979;hb=f4df5039a791a56de85c64e6b9e4448a221b5c40;hp=730e9573d5a30c8af64b6d3c19f55c1df6198556;hpb=f32d2939555706365ad1d39aadd5ee7ce1d9fa4f;p=ffmpeg diff --git a/libavformat/boadec.c b/libavformat/boadec.c index 730e9573d5a..69d17763ef7 100644 --- a/libavformat/boadec.c +++ b/libavformat/boadec.c @@ -24,7 +24,7 @@ #include "avformat.h" #include "internal.h" -static int probe(AVProbeData *p) +static int probe(const AVProbeData *p) { if (p->buf_size < 2096) return 0; @@ -54,12 +54,12 @@ static int read_header(AVFormatContext *s) avio_rl32(s->pb); st->codecpar->sample_rate = avio_rl32(s->pb); st->codecpar->channels = avio_rl32(s->pb); - if (st->codecpar->channels > FF_SANE_NB_CHANNELS) + if (st->codecpar->channels > FF_SANE_NB_CHANNELS || st->codecpar->channels <= 0) return AVERROR(ENOSYS); s->internal->data_offset = avio_rl32(s->pb); avio_r8(s->pb); st->codecpar->block_align = avio_rl32(s->pb); - if (st->codecpar->block_align > INT_MAX / FF_SANE_NB_CHANNELS) + if (st->codecpar->block_align > INT_MAX / FF_SANE_NB_CHANNELS || st->codecpar->block_align <= 0) return AVERROR_INVALIDDATA; st->codecpar->block_align *= st->codecpar->channels; @@ -75,7 +75,7 @@ static int read_packet(AVFormatContext *s, AVPacket *pkt) return av_get_packet(s->pb, pkt, st->codecpar->block_align); } -AVInputFormat ff_boa_demuxer = { +const AVInputFormat ff_boa_demuxer = { .name = "boa", .long_name = NULL_IF_CONFIG_SMALL("Black Ops Audio"), .read_probe = probe,