From fafc1ca007b7399f36090f511909ec694360ff6e Mon Sep 17 00:00:00 2001 From: Johny Lin Date: Fri, 8 Mar 2024 09:50:04 +0000 Subject: [PATCH] multiband_drc: instantaneous enabled state switch on processing In present multiband_drc design, the enabled state is determined by the switch control while multiband_drc starts to process. If the switch control toggles while processing, it will take effects on the next time multiband_drc starts to process. This commit makes change to let the enabled state update instantaneously by the switch control toggle when multiband_drc is processing. Signed-off-by: Pin-chih Lin (cherry picked from commit 8e8ff75a7669c5bb1abb281c98557e42ab1aef67) --- src/audio/multiband_drc/multiband_drc.c | 45 +++++++++---------- .../multiband_drc/multiband_drc_generic.c | 8 ++-- .../sof/audio/multiband_drc/multiband_drc.h | 5 +++ 3 files changed, 30 insertions(+), 28 deletions(-) diff --git a/src/audio/multiband_drc/multiband_drc.c b/src/audio/multiband_drc/multiband_drc.c index a9238d0cb9fa..bcb33908c61a 100644 --- a/src/audio/multiband_drc/multiband_drc.c +++ b/src/audio/multiband_drc/multiband_drc.c @@ -135,6 +135,16 @@ static int multiband_drc_init_coef(struct multiband_drc_comp_data *cd, int16_t n "multiband_drc_init_coef(), initializing %i-way crossover", config->num_bands); + /* Crossover: determine the split function */ + cd->crossover_split = crossover_find_split_func(config->num_bands); + if (!cd->crossover_split) { + comp_cl_err(&comp_multiband_drc, + "multiband_drc_init_coef(), No crossover_split for band num %i", + config->num_bands); + ret = -EINVAL; + goto err; + } + /* Crossover: collect the coef array and assign it to every channel */ crossover = config->crossover_coef; for (ch = 0; ch < nch; ch++) { @@ -456,7 +466,10 @@ static void multiband_drc_process(struct comp_dev *dev, struct comp_buffer *sour buffer_stream_invalidate(source, source_bytes); - cd->multiband_drc_func(dev, &source->stream, &sink->stream, frames); + if (cd->process_enabled) + cd->multiband_drc_func(dev, &source->stream, &sink->stream, frames); + else + multiband_drc_default_pass(dev, &source->stream, &sink->stream, frames); buffer_stream_writeback(sink, sink_bytes); @@ -530,35 +543,19 @@ static int multiband_drc_prepare(struct comp_dev *dev) comp_dbg(dev, "multiband_drc_prepare(), source_format=%d, sink_format=%d", cd->source_format, cd->source_format); cd->config = comp_get_data_blob(cd->model_handler, NULL, NULL); - if (cd->config && cd->process_enabled) { + if (cd->config) { ret = multiband_drc_setup(cd, sourceb->stream.channels, sourceb->stream.rate); if (ret < 0) { comp_err(dev, "multiband_drc_prepare() error: multiband_drc_setup failed."); goto err; } + } - cd->multiband_drc_func = multiband_drc_find_proc_func(cd->source_format); - if (!cd->multiband_drc_func) { - comp_err(dev, "multiband_drc_prepare(), No proc func"); - ret = -EINVAL; - goto err; - } - - cd->crossover_split = crossover_find_split_func(cd->config->num_bands); - if (!cd->crossover_split) { - comp_err(dev, "multiband_drc_prepare(), No crossover_split for band num %i", - cd->config->num_bands); - ret = -EINVAL; - goto err; - } - } else { - comp_info(dev, "multiband_drc_prepare(), DRC is in passthrough mode"); - cd->multiband_drc_func = multiband_drc_find_proc_func_pass(cd->source_format); - if (!cd->multiband_drc_func) { - comp_err(dev, "multiband_drc_prepare(), No proc func passthrough"); - ret = -EINVAL; - goto err; - } + cd->multiband_drc_func = multiband_drc_find_proc_func(cd->source_format); + if (!cd->multiband_drc_func) { + comp_err(dev, "multiband_drc_prepare(), No proc func"); + ret = -EINVAL; + goto err; } /* validate sink data format and period bytes */ diff --git a/src/audio/multiband_drc/multiband_drc_generic.c b/src/audio/multiband_drc/multiband_drc_generic.c index 57689a09d633..2aef2e2b2771 100644 --- a/src/audio/multiband_drc/multiband_drc_generic.c +++ b/src/audio/multiband_drc/multiband_drc_generic.c @@ -10,10 +10,10 @@ #include #include -static void multiband_drc_default_pass(const struct comp_dev *dev, - const struct audio_stream *source, - struct audio_stream *sink, - uint32_t frames) +void multiband_drc_default_pass(const struct comp_dev *dev, + const struct audio_stream *source, + struct audio_stream *sink, + uint32_t frames) { audio_stream_copy(source, 0, sink, 0, source->channels * frames); } diff --git a/src/include/sof/audio/multiband_drc/multiband_drc.h b/src/include/sof/audio/multiband_drc/multiband_drc.h index ae98aa785b14..b08a18b54f26 100644 --- a/src/include/sof/audio/multiband_drc/multiband_drc.h +++ b/src/include/sof/audio/multiband_drc/multiband_drc.h @@ -52,6 +52,11 @@ extern const struct multiband_drc_proc_fnmap multiband_drc_proc_fnmap[]; extern const struct multiband_drc_proc_fnmap multiband_drc_proc_fnmap_pass[]; extern const size_t multiband_drc_proc_fncount; +void multiband_drc_default_pass(const struct comp_dev *dev, + const struct audio_stream *source, + struct audio_stream *sink, + uint32_t frames); + /** * \brief Returns Multiband DRC processing function. */