Commit 89de5157 authored by Tim Walker's avatar Tim Walker Committed by Anton Khirnov

dcadec: implement request_channel_layout.

Signed-off-by: 's avatarAnton Khirnov <anton@khirnov.net>
parent cf7860db
...@@ -1288,7 +1288,8 @@ static int dca_filter_channels(DCAContext *s, int block_index) ...@@ -1288,7 +1288,8 @@ static int dca_filter_channels(DCAContext *s, int block_index)
} }
/* Down mixing */ /* 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); dca_downmix(s->samples_chanptr, s->amode, s->downmix_coef, s->channel_order_tab);
} }
...@@ -1803,8 +1804,14 @@ static int dca_decode_frame(AVCodecContext *avctx, void *data, ...@@ -1803,8 +1804,14 @@ static int dca_decode_frame(AVCodecContext *avctx, void *data,
if (s->amode < 16) { if (s->amode < 16) {
avctx->channel_layout = dca_core_channel_layout[s->amode]; avctx->channel_layout = dca_core_channel_layout[s->amode];
#if FF_API_REQUEST_CHANNELS
FF_DISABLE_DEPRECATION_WARNINGS
if (s->xch_present && (!avctx->request_channels || if (s->xch_present && (!avctx->request_channels ||
avctx->request_channels > num_core_channels + !!s->lfe)) { avctx->request_channels > num_core_channels + !!s->lfe)) {
FF_ENABLE_DEPRECATION_WARNINGS
#else
if (s->xch_present) {
#endif
avctx->channel_layout |= AV_CH_BACK_CENTER; avctx->channel_layout |= AV_CH_BACK_CENTER;
if (s->lfe) { if (s->lfe) {
avctx->channel_layout |= AV_CH_LOW_FREQUENCY; avctx->channel_layout |= AV_CH_LOW_FREQUENCY;
...@@ -1826,7 +1833,8 @@ static int dca_decode_frame(AVCodecContext *avctx, void *data, ...@@ -1826,7 +1833,8 @@ static int dca_decode_frame(AVCodecContext *avctx, void *data,
s->channel_order_tab[channels - 1 - !!s->lfe] < 0) s->channel_order_tab[channels - 1 - !!s->lfe] < 0)
return AVERROR_INVALIDDATA; 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; channels = 2;
s->output = DCA_STEREO; s->output = DCA_STEREO;
avctx->channel_layout = AV_CH_LAYOUT_STEREO; avctx->channel_layout = AV_CH_LAYOUT_STEREO;
...@@ -1922,9 +1930,15 @@ static av_cold int dca_decode_init(AVCodecContext *avctx) ...@@ -1922,9 +1930,15 @@ static av_cold int dca_decode_init(AVCodecContext *avctx)
avctx->sample_fmt = AV_SAMPLE_FMT_FLTP; avctx->sample_fmt = AV_SAMPLE_FMT_FLTP;
/* allow downmixing to stereo */ /* allow downmixing to stereo */
if (avctx->channels > 2 && avctx->request_channels == 2) { #if FF_API_REQUEST_CHANNELS
avctx->channels = avctx->request_channels; FF_DISABLE_DEPRECATION_WARNINGS
} if (avctx->request_channels == 2)
avctx->request_channel_layout = AV_CH_LAYOUT_STEREO;
FF_ENABLE_DEPRECATION_WARNINGS
#endif
if (avctx->channels > 2 &&
avctx->request_channel_layout == AV_CH_LAYOUT_STEREO)
avctx->channels = 2;
return 0; return 0;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment