X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=libavformat%2Fwav.c;h=ab4b3b42e7241bcdc4e04808dd250f429c182b14;hb=9ba43e50efa2483fb3ca1e3f62a474db7dd3ac8d;hp=b9a8f4038ad6d65f04e7db9b4209ea263832ee1e;hpb=707138593af5c4783035d0b9cc2d7c8cb2137dfa;p=ffmpeg diff --git a/libavformat/wav.c b/libavformat/wav.c index b9a8f4038ad..ab4b3b42e72 100644 --- a/libavformat/wav.c +++ b/libavformat/wav.c @@ -52,6 +52,7 @@ typedef struct { int smv_last_stream; int smv_eof; int audio_eof; + int ignore_length; } WAVContext; #if CONFIG_WAV_MUXER @@ -345,7 +346,7 @@ static int wav_parse_bext_tag(AVFormatContext *s, int64_t size) } else { /* extended UMID */ snprintf(temp, sizeof(temp), "0x%016"PRIX64"%016"PRIX64"%016"PRIX64"%016"PRIX64 - "0x%016"PRIX64"%016"PRIX64"%016"PRIX64"%016"PRIX64, + "%016"PRIX64"%016"PRIX64"%016"PRIX64"%016"PRIX64, umid_parts[0], umid_parts[1], umid_parts[2], umid_parts[3], umid_parts[4], umid_parts[5], umid_parts[6], umid_parts[7]); } @@ -506,8 +507,8 @@ static int wav_read_header(AVFormatContext *s, goto break_loop; case MKTAG('L', 'I', 'S', 'T'): list_type = avio_rl32(pb); - if (size <= 4) { - av_log(s, AV_LOG_ERROR, "too short LIST"); + if (size < 4) { + av_log(s, AV_LOG_ERROR, "too short LIST tag\n"); return AVERROR_INVALIDDATA; } switch (list_type) { @@ -618,6 +619,8 @@ smv_out: st = s->streams[0]; left = wav->data_end - avio_tell(s->pb); + if (wav->ignore_length) + left= INT_MAX; if (left <= 0){ if (CONFIG_W64_DEMUXER && wav->w64) left = find_guid(s->pb, guid_data) - 24; @@ -677,6 +680,19 @@ static int wav_read_seek(AVFormatContext *s, return pcm_read_seek(s, stream_index, timestamp, flags); } +#define OFFSET(x) offsetof(WAVContext, x) +#define DEC AV_OPT_FLAG_DECODING_PARAM +static const AVOption demux_options[] = { + { "ignore_length", "Ignore length", OFFSET(ignore_length), AV_OPT_TYPE_INT, { 0 }, 0, 1, DEC }, + { NULL }, +}; + +static const AVClass wav_demuxer_class = { + .class_name = "WAV demuxer", + .item_name = av_default_item_name, + .option = demux_options, + .version = LIBAVUTIL_VERSION_INT, +}; AVInputFormat ff_wav_demuxer = { .name = "wav", .long_name = NULL_IF_CONFIG_SMALL("WAV format"), @@ -687,6 +703,7 @@ AVInputFormat ff_wav_demuxer = { .read_seek = wav_read_seek, .flags= AVFMT_GENERIC_INDEX, .codec_tag= (const AVCodecTag* const []){ff_codec_wav_tags, 0}, + .priv_class = &wav_demuxer_class, }; #endif /* CONFIG_WAV_DEMUXER */