You've already forked FFmpeg
mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-08-10 06:10:52 +02:00
pcmdec: move DVD PCM bits_per_coded_sample check near to the code that sets
the sample size.
This commit is contained in:
@@ -279,10 +279,15 @@ static int pcm_decode_frame(AVCodecContext *avctx,
|
|||||||
sample_size = av_get_bits_per_sample(avctx->codec_id)/8;
|
sample_size = av_get_bits_per_sample(avctx->codec_id)/8;
|
||||||
|
|
||||||
/* av_get_bits_per_sample returns 0 for CODEC_ID_PCM_DVD */
|
/* av_get_bits_per_sample returns 0 for CODEC_ID_PCM_DVD */
|
||||||
if (CODEC_ID_PCM_DVD == avctx->codec_id)
|
if (CODEC_ID_PCM_DVD == avctx->codec_id) {
|
||||||
|
if (avctx->bits_per_coded_sample != 20 &&
|
||||||
|
avctx->bits_per_coded_sample != 24) {
|
||||||
|
av_log(avctx, AV_LOG_ERROR, "PCM DVD unsupported sample depth\n");
|
||||||
|
return AVERROR(EINVAL);
|
||||||
|
}
|
||||||
/* 2 samples are interleaved per block in PCM_DVD */
|
/* 2 samples are interleaved per block in PCM_DVD */
|
||||||
sample_size = avctx->bits_per_coded_sample * 2 / 8;
|
sample_size = avctx->bits_per_coded_sample * 2 / 8;
|
||||||
else if (avctx->codec_id == CODEC_ID_PCM_LXF)
|
} else if (avctx->codec_id == CODEC_ID_PCM_LXF)
|
||||||
/* we process 40-bit blocks per channel for LXF */
|
/* we process 40-bit blocks per channel for LXF */
|
||||||
sample_size = 5;
|
sample_size = 5;
|
||||||
|
|
||||||
@@ -433,9 +438,6 @@ static int pcm_decode_frame(AVCodecContext *avctx,
|
|||||||
src = src8;
|
src = src8;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
|
||||||
av_log(avctx, AV_LOG_ERROR, "PCM DVD unsupported sample depth\n");
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
samples = (uint8_t *) dst_int32_t;
|
samples = (uint8_t *) dst_int32_t;
|
||||||
break;
|
break;
|
||||||
|
Reference in New Issue
Block a user