Simplify error handling by processing header errors separate from CRC and
buffer size vs. frame size errors. Originally committed as revision 21519 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
836fc77785
commit
2c2cdc0bfb
@ -1236,21 +1236,7 @@ static int ac3_decode_frame(AVCodecContext * avctx, void *data, int *data_size,
|
|||||||
*data_size = 0;
|
*data_size = 0;
|
||||||
err = parse_frame_header(s);
|
err = parse_frame_header(s);
|
||||||
|
|
||||||
/* check that reported frame size fits in input buffer */
|
if (err) {
|
||||||
if(!err && s->frame_size > buf_size) {
|
|
||||||
av_log(avctx, AV_LOG_ERROR, "incomplete frame\n");
|
|
||||||
err = AAC_AC3_PARSE_ERROR_FRAME_SIZE;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* check for crc mismatch */
|
|
||||||
if(err != AAC_AC3_PARSE_ERROR_FRAME_SIZE && avctx->error_recognition >= FF_ER_CAREFUL) {
|
|
||||||
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");
|
|
||||||
err = AAC_AC3_PARSE_ERROR_CRC;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(err && err != AAC_AC3_PARSE_ERROR_CRC) {
|
|
||||||
switch(err) {
|
switch(err) {
|
||||||
case AAC_AC3_PARSE_ERROR_SYNC:
|
case AAC_AC3_PARSE_ERROR_SYNC:
|
||||||
av_log(avctx, AV_LOG_ERROR, "frame sync error\n");
|
av_log(avctx, AV_LOG_ERROR, "frame sync error\n");
|
||||||
@ -1278,6 +1264,18 @@ static int ac3_decode_frame(AVCodecContext * avctx, void *data, int *data_size,
|
|||||||
av_log(avctx, AV_LOG_ERROR, "invalid header\n");
|
av_log(avctx, AV_LOG_ERROR, "invalid header\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
/* check that reported frame size fits in input buffer */
|
||||||
|
if (s->frame_size > buf_size) {
|
||||||
|
av_log(avctx, AV_LOG_ERROR, "incomplete frame\n");
|
||||||
|
err = AAC_AC3_PARSE_ERROR_FRAME_SIZE;
|
||||||
|
} else if (avctx->error_recognition >= FF_ER_CAREFUL) {
|
||||||
|
/* check for crc mismatch */
|
||||||
|
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");
|
||||||
|
err = AAC_AC3_PARSE_ERROR_CRC;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* if frame is ok, set audio parameters */
|
/* if frame is ok, set audio parameters */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user