提交 399b210b 编写于 作者: J Jeeja KP 提交者: Mark Brown

ASoC: Intel: Skylake: Add helper routine to handle Algo parameter

Some DSP modules has user configurable parameters, which are
required by some modules at module initialization.

To configure the module algorithm parameter during initialization
we add helpers here
Signed-off-by: NDivya Prakash <divya1.prakash@intel.com>
Signed-off-by: NJeeja KP <jeeja.kp@intel.com>
Signed-off-by: NVinod Koul <vinod.koul@intel.com>
Signed-off-by: NMark Brown <broonie@kernel.org>
上级 9939a9c3
...@@ -387,6 +387,28 @@ static void skl_set_copier_format(struct skl_sst *ctx, ...@@ -387,6 +387,28 @@ static void skl_set_copier_format(struct skl_sst *ctx,
skl_setup_cpr_gateway_cfg(ctx, mconfig, cpr_mconfig); skl_setup_cpr_gateway_cfg(ctx, mconfig, cpr_mconfig);
} }
/*
* Algo module are DSP pre processing modules. Algo module take base module
* configuration and params
*/
static void skl_set_algo_format(struct skl_sst *ctx,
struct skl_module_cfg *mconfig,
struct skl_algo_cfg *algo_mcfg)
{
struct skl_base_cfg *base_cfg = (struct skl_base_cfg *)algo_mcfg;
skl_set_base_module_format(ctx, mconfig, base_cfg);
if (mconfig->formats_config.caps_size == 0)
return;
memcpy(algo_mcfg->params,
mconfig->formats_config.caps,
mconfig->formats_config.caps_size);
}
static u16 skl_get_module_param_size(struct skl_sst *ctx, static u16 skl_get_module_param_size(struct skl_sst *ctx,
struct skl_module_cfg *mconfig) struct skl_module_cfg *mconfig)
{ {
...@@ -404,6 +426,11 @@ static u16 skl_get_module_param_size(struct skl_sst *ctx, ...@@ -404,6 +426,11 @@ static u16 skl_get_module_param_size(struct skl_sst *ctx,
case SKL_MODULE_TYPE_UPDWMIX: case SKL_MODULE_TYPE_UPDWMIX:
return sizeof(struct skl_up_down_mixer_cfg); return sizeof(struct skl_up_down_mixer_cfg);
case SKL_MODULE_TYPE_ALGO:
param_size = sizeof(struct skl_base_cfg);
param_size += mconfig->formats_config.caps_size;
return param_size;
default: default:
/* /*
* return only base cfg when no specific module type is * return only base cfg when no specific module type is
...@@ -450,6 +477,10 @@ static int skl_set_module_format(struct skl_sst *ctx, ...@@ -450,6 +477,10 @@ static int skl_set_module_format(struct skl_sst *ctx,
skl_set_updown_mixer_format(ctx, module_config, *param_data); skl_set_updown_mixer_format(ctx, module_config, *param_data);
break; break;
case SKL_MODULE_TYPE_ALGO:
skl_set_algo_format(ctx, module_config, *param_data);
break;
default: default:
skl_set_base_module_format(ctx, module_config, *param_data); skl_set_base_module_format(ctx, module_config, *param_data);
break; break;
......
...@@ -140,6 +140,11 @@ struct skl_up_down_mixer_cfg { ...@@ -140,6 +140,11 @@ struct skl_up_down_mixer_cfg {
s32 coeff[UP_DOWN_MIXER_MAX_COEFF]; s32 coeff[UP_DOWN_MIXER_MAX_COEFF];
} __packed; } __packed;
struct skl_algo_cfg {
struct skl_base_cfg base_cfg;
char params[0];
} __packed;
enum skl_dma_type { enum skl_dma_type {
SKL_DMA_HDA_HOST_OUTPUT_CLASS = 0, SKL_DMA_HDA_HOST_OUTPUT_CLASS = 0,
SKL_DMA_HDA_HOST_INPUT_CLASS = 1, SKL_DMA_HDA_HOST_INPUT_CLASS = 1,
......
...@@ -81,7 +81,8 @@ enum skl_module_type { ...@@ -81,7 +81,8 @@ enum skl_module_type {
SKL_MODULE_TYPE_MIXER = 0, SKL_MODULE_TYPE_MIXER = 0,
SKL_MODULE_TYPE_COPIER, SKL_MODULE_TYPE_COPIER,
SKL_MODULE_TYPE_UPDWMIX, SKL_MODULE_TYPE_UPDWMIX,
SKL_MODULE_TYPE_SRCINT SKL_MODULE_TYPE_SRCINT,
SKL_MODULE_TYPE_ALGO
}; };
enum skl_core_affinity { enum skl_core_affinity {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册