ASoC: Intel: Skylake: Support modules with generic extension
authorSzymon Mielczarek <szymonx.mielczarek@intel.com>
Wed, 18 Aug 2021 07:57:40 +0000 (09:57 +0200)
committerMark Brown <broonie@kernel.org>
Mon, 23 Aug 2021 15:40:03 +0000 (16:40 +0100)
Some DSP modules require, besides the module base configuration, a
generic extension containing audio format for all module's pins that are
in use.

Signed-off-by: Gustaw Lewandowski <gustaw.lewandowski@linux.intel.com>
Signed-off-by: Szymon Mielczarek <szymonx.mielczarek@intel.com>
Signed-off-by: Cezary Rojewski <cezary.rojewski@intel.com>
Tested-by: Lukasz Majczak <lma@semihalf.com>
Link: https://lore.kernel.org/r/20210818075742.1515155-10-cezary.rojewski@intel.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/intel/skylake/skl-messages.c
sound/soc/intel/skylake/skl-topology.h

index 7257acf0b6ee9c971b744427d1da5ac77e6fdb9b..8886f984ae261bd3dd987e4a43878ddcc054f82a 100644 (file)
@@ -472,6 +472,75 @@ static void skl_set_base_module_format(struct skl_dev *skl,
        base_cfg->is_pages = res->is_pages;
 }
 
+static void fill_pin_params(struct skl_audio_data_format *pin_fmt,
+                           struct skl_module_fmt *format)
+{
+       pin_fmt->number_of_channels = format->channels;
+       pin_fmt->s_freq = format->s_freq;
+       pin_fmt->bit_depth = format->bit_depth;
+       pin_fmt->valid_bit_depth = format->valid_bit_depth;
+       pin_fmt->ch_cfg = format->ch_cfg;
+       pin_fmt->sample_type = format->sample_type;
+       pin_fmt->channel_map = format->ch_map;
+       pin_fmt->interleaving = format->interleaving_style;
+}
+
+/*
+ * Any module configuration begins with a base module configuration but
+ * can be followed by a generic extension containing audio format for all
+ * module's pins that are in use.
+ */
+static void skl_set_base_ext_module_format(struct skl_dev *skl,
+                                          struct skl_module_cfg *mconfig,
+                                          struct skl_base_cfg_ext *base_cfg_ext)
+{
+       struct skl_module *module = mconfig->module;
+       struct skl_module_pin_resources *pin_res;
+       struct skl_module_iface *fmt = &module->formats[mconfig->fmt_idx];
+       struct skl_module_res *res = &module->resources[mconfig->res_idx];
+       struct skl_module_fmt *format;
+       struct skl_pin_format *pin_fmt;
+       char *params;
+       int i;
+
+       base_cfg_ext->nr_input_pins = res->nr_input_pins;
+       base_cfg_ext->nr_output_pins = res->nr_output_pins;
+       base_cfg_ext->priv_param_length =
+               mconfig->formats_config[SKL_PARAM_INIT].caps_size;
+
+       for (i = 0; i < res->nr_input_pins; i++) {
+               pin_res = &res->input[i];
+               pin_fmt = &base_cfg_ext->pins_fmt[i];
+
+               pin_fmt->pin_idx = pin_res->pin_index;
+               pin_fmt->buf_size = pin_res->buf_size;
+
+               format = &fmt->inputs[pin_res->pin_index].fmt;
+               fill_pin_params(&pin_fmt->audio_fmt, format);
+       }
+
+       for (i = 0; i < res->nr_output_pins; i++) {
+               pin_res = &res->output[i];
+               pin_fmt = &base_cfg_ext->pins_fmt[res->nr_input_pins + i];
+
+               pin_fmt->pin_idx = pin_res->pin_index;
+               pin_fmt->buf_size = pin_res->buf_size;
+
+               format = &fmt->outputs[pin_res->pin_index].fmt;
+               fill_pin_params(&pin_fmt->audio_fmt, format);
+       }
+
+       if (!base_cfg_ext->priv_param_length)
+               return;
+
+       params = (char *)base_cfg_ext + sizeof(struct skl_base_cfg_ext);
+       params += (base_cfg_ext->nr_input_pins + base_cfg_ext->nr_output_pins) *
+                 sizeof(struct skl_pin_format);
+
+       memcpy(params, mconfig->formats_config[SKL_PARAM_INIT].caps,
+              mconfig->formats_config[SKL_PARAM_INIT].caps_size);
+}
+
 /*
  * Copies copier capabilities into copier module and updates copier module
  * config size.
@@ -1091,19 +1160,6 @@ int skl_unbind_modules(struct skl_dev *skl,
        return ret;
 }
 
-static void fill_pin_params(struct skl_audio_data_format *pin_fmt,
-                               struct skl_module_fmt *format)
-{
-       pin_fmt->number_of_channels = format->channels;
-       pin_fmt->s_freq = format->s_freq;
-       pin_fmt->bit_depth = format->bit_depth;
-       pin_fmt->valid_bit_depth = format->valid_bit_depth;
-       pin_fmt->ch_cfg = format->ch_cfg;
-       pin_fmt->sample_type = format->sample_type;
-       pin_fmt->channel_map = format->ch_map;
-       pin_fmt->interleaving = format->interleaving_style;
-}
-
 #define CPR_SINK_FMT_PARAM_ID 2
 
 /*
index ef332c83d5c046382d7e182e278c9d36e0ff2597..f0695b2ac5dd2cf27acda2ec3fd9f9f805b65133 100644 (file)
@@ -152,6 +152,21 @@ struct skl_up_down_mixer_cfg {
        u32 ch_map;
 } __packed;
 
+struct skl_pin_format {
+       u32 pin_idx;
+       u32 buf_size;
+       struct skl_audio_data_format audio_fmt;
+} __packed;
+
+struct skl_base_cfg_ext {
+       u16 nr_input_pins;
+       u16 nr_output_pins;
+       u8 reserved[8];
+       u32 priv_param_length;
+       /* Input pin formats followed by output ones. */
+       struct skl_pin_format pins_fmt[0];
+} __packed;
+
 struct skl_algo_cfg {
        struct skl_base_cfg  base_cfg;
        char params[];