On Mon, 18 Nov 2013 12:41:44 +0100, Tim Walker <[email protected]> wrote:
> ---
> libavcodec/dcadec.c | 21 ++++++++++++++-------
> 1 file changed, 14 insertions(+), 7 deletions(-)
>
> diff --git a/libavcodec/dcadec.c b/libavcodec/dcadec.c
> index 7af5e5c..8835133 100644
> --- a/libavcodec/dcadec.c
> +++ b/libavcodec/dcadec.c
> @@ -1288,7 +1288,8 @@ static int dca_filter_channels(DCAContext *s, int
> block_index)
> }
>
> /* Down mixing */
> - if (s->avctx->request_channels == 2 && s->prim_channels > 2) {
> + if (s->prim_channels > 2 &&
> + s->avctx->request_channel_layout == AV_CH_LAYOUT_STEREO) {
> dca_downmix(s->samples_chanptr, s->amode, s->downmix_coef,
> s->channel_order_tab);
> }
>
> @@ -1803,8 +1804,11 @@ static int dca_decode_frame(AVCodecContext *avctx,
> void *data,
> if (s->amode < 16) {
> avctx->channel_layout = dca_core_channel_layout[s->amode];
>
> - if (s->xch_present && (!avctx->request_channels ||
> - avctx->request_channels > num_core_channels +
> !!s->lfe)) {
> + if (s->xch_present &&
> + (!avctx->request_channels ||
> + avctx->request_channels > num_core_channels + !!s->lfe) &&
> + (!avctx->request_channel_layout ||
> + avctx->request_channel_layout & AV_CH_BACK_CENTER)) {
I'm a bit confused by this part.
If we're only handling request_channel_layout == stereo
(and temporarily request_channels == 2, which is converted to
request_channel_layout in init), why are you checking request_channels here?
> avctx->channel_layout |= AV_CH_BACK_CENTER;
> if (s->lfe) {
> avctx->channel_layout |= AV_CH_LOW_FREQUENCY;
> @@ -1826,7 +1830,8 @@ static int dca_decode_frame(AVCodecContext *avctx, void
> *data,
> s->channel_order_tab[channels - 1 - !!s->lfe] < 0)
> return AVERROR_INVALIDDATA;
>
> - if (avctx->request_channels == 2 && s->prim_channels > 2) {
> + if (s->prim_channels > 2 &&
> + avctx->request_channel_layout == AV_CH_LAYOUT_STEREO) {
> channels = 2;
> s->output = DCA_STEREO;
> avctx->channel_layout = AV_CH_LAYOUT_STEREO;
> @@ -1922,9 +1927,11 @@ static av_cold int dca_decode_init(AVCodecContext
> *avctx)
> avctx->sample_fmt = AV_SAMPLE_FMT_FLTP;
>
> /* allow downmixing to stereo */
> - if (avctx->channels > 2 && avctx->request_channels == 2) {
> - avctx->channels = avctx->request_channels;
> - }
> + if (avctx->request_channels == 2)
> + avctx->request_channel_layout = AV_CH_LAYOUT_STEREO;
> + if (avctx->channels > 2 &&
> + avctx->request_channel_layout == AV_CH_LAYOUT_STEREO)
> + avctx->channels = 2;
wrap it in #if FF_API_REQUEST_CHANNELS and FF_DISABLE_DEPRECATION_WARNINGS /
FF_ENABLE_DEPRECATION_WARNINGS
--
Anton Khirnov
_______________________________________________
libav-devel mailing list
[email protected]
https://lists.libav.org/mailman/listinfo/libav-devel