diff options
author | Anton Khirnov <anton@khirnov.net> | 2013-10-26 22:46:48 +0200 |
---|---|---|
committer | Anton Khirnov <anton@khirnov.net> | 2013-10-28 07:22:18 +0100 |
commit | 23a211cbba0b7c9ee694040031b2e5da1be54a00 (patch) | |
tree | cf496d9ae1c70bd97f985b1ac6b1e3e377802a6a /libavcodec/ac3dec.c | |
parent | f354f30836a3148275ce60d19bbc581310249ad2 (diff) | |
download | ffmpeg-23a211cbba0b7c9ee694040031b2e5da1be54a00.tar.gz |
lavc: change all decoders to behave consistently with AV_EF_CRCCHECK.
Just crccheck prints a warning, crccheck+explode returns an error.
Also document this behavior.
Diffstat (limited to 'libavcodec/ac3dec.c')
-rw-r--r-- | libavcodec/ac3dec.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/libavcodec/ac3dec.c b/libavcodec/ac3dec.c index fd0bf339a7..d664325a29 100644 --- a/libavcodec/ac3dec.c +++ b/libavcodec/ac3dec.c @@ -1330,6 +1330,8 @@ static int ac3_decode_frame(AVCodecContext * avctx, void *data, if (av_crc(av_crc_get_table(AV_CRC_16_ANSI), 0, &buf[2], s->frame_size - 2)) { av_log(avctx, AV_LOG_ERROR, "frame CRC mismatch\n"); + if (avctx->err_recognition & AV_EF_EXPLODE) + return AVERROR_INVALIDDATA; err = AAC_AC3_PARSE_ERROR_CRC; } } |