diff --git a/src/audio/module_adapter/module/waves.c b/src/audio/module_adapter/module/waves.c index 8002174e1a5f..b772ac14e525 100644 --- a/src/audio/module_adapter/module/waves.c +++ b/src/audio/module_adapter/module/waves.c @@ -43,7 +43,8 @@ struct waves_codec_data { uint32_t response_max_bytes; uint32_t request_max_bytes; void *response; - struct module_config setup_cfg; + uint32_t config_blob_size; + void *config_blob; }; enum waves_codec_params { @@ -209,9 +210,10 @@ static int waves_effect_allocate(struct processing_module *mod) return -ENOMEM; } - comp_dbg(dev, "waves_effect_allocate() allocated %d bytes for effect", + comp_info(dev, "waves_effect_allocate() allocated %d bytes for effect", waves_codec->effect_size); + comp_dbg(dev, "waves_effect_allocate() done"); return 0; } @@ -399,8 +401,8 @@ static int waves_effect_buffers(struct processing_module *mod) codec->mpd.out_buff = waves_codec->o_buffer; codec->mpd.out_buff_size = waves_codec->buffer_bytes; - comp_dbg(dev, "waves_effect_buffers() in_buff_size %d, out_buff_size %d", - codec->mpd.in_buff_size, codec->mpd.out_buff_size); + comp_info(dev, "waves_effect_buffers() size i_buffer %d, o_buffer %d", + waves_codec->buffer_bytes, waves_codec->buffer_bytes); comp_dbg(dev, "waves_effect_buffers() done"); return 0; @@ -462,6 +464,51 @@ static int waves_effect_revision(struct processing_module *mod) return 0; } +/* cache config blob*/ +static int waves_effect_save_config_blob_to_cache(struct processing_module *mod, + void *data, uint32_t size) +{ + struct comp_dev *dev = mod->dev; + struct module_data *codec = &mod->priv; + struct waves_codec_data *waves_codec = codec->private; + + comp_info(dev, "waves_effect_save_config_blob_to_cache() start"); + + /* release old cached config blob*/ + if (waves_codec->config_blob && size != waves_codec->config_blob_size) { + comp_info(dev, "waves_effect_save_config_blob_to_cache() release blob"); + module_free_memory(mod, waves_codec->config_blob); + waves_codec->config_blob = NULL; + waves_codec->config_blob_size = 0; + } + + if (!waves_codec->config_blob) { + waves_codec->config_blob = module_allocate_memory(mod, size, 16); + if (!waves_codec->config_blob) { + comp_err(dev, + "waves_effect_save_config_blob_to_cache() failed to allocate %d bytes for config blob", + size); + return -ENOMEM; + } + waves_codec->config_blob_size = size; + } + + int ret = memcpy_s(waves_codec->config_blob, waves_codec->config_blob_size, + data, size); + if (ret) { + comp_err(dev, + "waves_effect_save_config_blob_to_cache(): failed to copy config blob %d", + ret); + module_free_memory(mod, waves_codec->config_blob); + waves_codec->config_blob = NULL; + waves_codec->config_blob_size = 0; + return ret; + } + + comp_dbg(dev, "waves_effect_save_config_blob_to_cache() done"); + return 0; +} + /* apply MaxxEffect message */ static int waves_effect_message(struct processing_module *mod, void *data, uint32_t size) { @@ -498,37 +545,62 @@ static int waves_effect_message(struct processing_module *mod, void *data, uint3 return 0; } -/* apply codec config */ -static int waves_effect_config(struct processing_module *mod) +/* apply config blob */ +static int waves_effect_apply_config_blob_from_cache(struct processing_module *mod) { struct comp_dev *dev = mod->dev; struct module_data *codec = &mod->priv; struct waves_codec_data *waves_codec = codec->private; + + comp_info(dev, "waves_effect_apply_config_blob_from_cache()"); + + if (waves_codec->config_blob) { + return waves_effect_message(mod, waves_codec->config_blob, + waves_codec->config_blob_size); + } + return 0; +} + +static int waves_effect_handle_param_message(struct processing_module *mod, + void *data, uint32_t size) +{ + int ret = waves_effect_save_config_blob_to_cache(mod, data, size); + + if (!ret) + ret = waves_effect_apply_config_blob_from_cache(mod); + + return ret; +} + +/* apply codec config */ +static int waves_effect_apply_config(struct processing_module *mod) +{ + struct comp_dev *dev = mod->dev; + struct module_data *codec = &mod->priv; struct module_param *param; struct module_config *cfg; uint32_t index; uint32_t param_number = 0; int ret = 0; - comp_info(dev, "waves_codec_configure() start"); + comp_dbg(dev, "waves_effect_apply_config() start"); cfg = &codec->cfg; - /* use setup config if no runtime config available */ - if (!cfg->avail) - cfg = &waves_codec->setup_cfg; - - comp_info(dev, "waves_codec_configure() config %p, size %d, avail %d", + comp_info(dev, "waves_effect_apply_config() config %p, size %d, avail %d", cfg->data, cfg->size, cfg->avail); - if (!cfg->avail || !cfg->size) { - comp_err(dev, "waves_codec_configure() no config, avail %d, size %d", - cfg->avail, cfg->size); - return -EINVAL; + if (!cfg->data) { + ret = waves_effect_apply_config_blob_from_cache(mod); + if (ret) { + comp_err(dev, "waves_effect_apply_config() error %x: apply cache fail", + ret); + return ret; + } } if (cfg->size > MAX_CONFIG_SIZE_BYTES) { - comp_err(dev, "waves_codec_configure() provided config is too big, size %d", + comp_err(dev, "waves_effect_apply_config() provided config is too big, size %d", cfg->size); return -EINVAL; } @@ -542,15 +614,15 @@ static int waves_effect_config(struct processing_module *mod) param = (struct module_param *)((char *)cfg->data + index); param_data_size = param->size - sizeof(param->size) - sizeof(param->id); - comp_info(dev, "waves_codec_configure() param num %d id %d size %d", + comp_info(dev, "waves_effect_apply_config() param num %d id %d size %d", param_number, param->id, param->size); switch (param->id) { case PARAM_NOP: - comp_info(dev, "waves_codec_configure() NOP"); + comp_info(dev, "waves_effect_apply_config() NOP"); break; case PARAM_MESSAGE: - ret = waves_effect_message(mod, param->data, param_data_size); + ret = waves_effect_handle_param_message(mod, param->data, param_data_size); break; case PARAM_REVISION: ret = waves_effect_revision(mod); @@ -563,28 +635,12 @@ static int waves_effect_config(struct processing_module *mod) index += param->size; } - if (ret) - comp_err(dev, "waves_codec_configure() failed %d", ret); - - comp_dbg(dev, "waves_codec_configure() done"); - return ret; -} - -/* apply setup config */ -static int waves_effect_setup_config(struct processing_module *mod) -{ - struct comp_dev *dev = mod->dev; - int ret; - - comp_dbg(dev, "waves_effect_setup_config() start"); - - ret = waves_effect_config(mod); - if (ret < 0) { - comp_err(dev, "waves_effect_setup_config(): fail to apply config"); + if (ret) { + comp_err(dev, "waves_effect_apply_config() failed %d", ret); return ret; } - comp_dbg(dev, "waves_effect_setup_config() done"); + comp_dbg(dev, "waves_effect_apply_config() done"); return 0; } @@ -603,64 +659,44 @@ static int waves_codec_init(struct processing_module *mod) comp_err(dev, "waves_codec_init() failed to allocate %d bytes for waves_codec_data", sizeof(struct waves_codec_data)); ret = -ENOMEM; + goto err3; } else { - memset(waves_codec, 0, sizeof(struct waves_codec_data)); codec->private = waves_codec; - ret = waves_effect_allocate(mod); if (ret) { - module_free_memory(mod, waves_codec); - codec->private = NULL; + goto err2; } } - if (ret) { - comp_err(dev, "waves_codec_init() failed %d", ret); - return ret; - } - waves_codec->setup_cfg.avail = false; - - /* copy the setup config only for the first init */ - if (codec->state == MODULE_DISABLED && codec->cfg.avail) { - struct module_config *setup_cfg = &waves_codec->setup_cfg; - - /* allocate memory for set up config */ - setup_cfg->data = rballoc(0, SOF_MEM_CAPS_RAM, codec->cfg.size); - if (!setup_cfg->data) { - comp_err(dev, "waves_codec_init(): failed to alloc setup config"); - module_free_memory(mod, waves_codec); - return -ENOMEM; - } - - /* copy the setup config */ - setup_cfg->size = codec->cfg.size; - ret = memcpy_s(setup_cfg->data, setup_cfg->size, codec->cfg.data, setup_cfg->size); - if (ret) { - comp_err(dev, "waves_codec_init(): failed to copy setup config %d", ret); - module_free_memory(mod, waves_codec); - return ret; - } - setup_cfg->avail = true; - } - ret = MaxxEffect_GetMessageMaxSize(waves_codec->effect, &waves_codec->request_max_bytes, &waves_codec->response_max_bytes); if (ret) { comp_err(dev, "waves_codec_init() MaxxEffect_GetMessageMaxSize returned %d", ret); - return -EINVAL; + ret = -EINVAL; + goto err1; } response = module_allocate_memory(mod, waves_codec->response_max_bytes, 16); if (!response) { comp_err(dev, "waves_codec_init() failed to allocate %d bytes for response", waves_codec->response_max_bytes); - return -ENOMEM; + ret = -ENOMEM; + goto err1; } waves_codec->response = response; comp_dbg(dev, "waves_codec_init() done"); return ret; + +err1: + module_free_memory(mod, waves_codec->effect); +err2: + module_free_memory(mod, waves_codec); + codec->private = NULL; +err3: + comp_err(dev, "waves_codec_init() failed %d", ret); + return ret; } static int waves_codec_prepare(struct processing_module *mod) @@ -671,20 +707,26 @@ static int waves_codec_prepare(struct processing_module *mod) comp_dbg(dev, "waves_codec_prepare() start"); ret = waves_effect_check(dev); + if (ret) + goto error; - if (!ret) - ret = waves_effect_init(mod); - - if (!ret) - ret = waves_effect_buffers(mod); + ret = waves_effect_init(mod); + if (ret) + goto error; - if (!ret) - ret = waves_effect_setup_config(mod); + ret = waves_effect_buffers(mod); + if (ret) + goto error; + ret = waves_effect_apply_config(mod); if (ret) - comp_err(dev, "waves_codec_prepare() failed %d", ret); + goto error; comp_dbg(dev, "waves_codec_prepare() done"); + return 0; + +error: + comp_err(dev, "waves_codec_prepare() failed %d", ret); return ret; } @@ -776,20 +818,6 @@ waves_codec_process(struct processing_module *mod, return ret; } -static int waves_codec_apply_config(struct processing_module *mod) -{ - int ret; - struct comp_dev *dev = mod->dev; - - comp_dbg(dev, "waves_codec_apply_config() start"); - ret = waves_effect_config(mod); - if (ret) - comp_err(dev, "waves_codec_apply_config() failed %d", ret); - - comp_dbg(dev, "waves_codec_apply_config() done"); - return ret; -} - static int waves_codec_reset(struct processing_module *mod) { MaxxStatus_t status; @@ -822,7 +850,7 @@ static int waves_codec_reset(struct processing_module *mod) static int waves_codec_free(struct processing_module *mod) { module_free_all_memory(mod); - comp_dbg(mod->dev, "waves_codec_free()"); + comp_info(mod->dev, "waves_codec_free()"); return 0; } @@ -847,14 +875,14 @@ waves_codec_set_configuration(struct processing_module *mod, uint32_t config_id, return 0; /* whole configuration received, apply it now */ - ret = waves_codec_apply_config(mod); + ret = waves_effect_apply_config(mod); if (ret) { comp_err(dev, "waves_codec_set_configuration(): error %x: runtime config apply failed", ret); return ret; } - comp_dbg(dev, "waves_codec_set_configuration(): config applied"); + comp_info(dev, "waves_codec_set_configuration(): config applied"); return 0; }