Skip to content

Commit

Permalink
ASoC: Intel: Skylake: Fix passing loadable flag for module
Browse files Browse the repository at this point in the history
[ Upstream commit c5ed9c5 ]

skl_get_module_info() tries to set mconfig->module->loadable before
mconfig->module has been assigned thus flag was always set to false
and driver did not try to load module binaries.

Signed-off-by: Gustaw Lewandowski <gustaw.lewandowski@linux.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-7-cezary.rojewski@intel.com
Signed-off-by: Mark Brown <broonie@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
  • Loading branch information
gustaw authored and gregkh committed Sep 18, 2021
1 parent 16a5850 commit 43e8f17
Showing 1 changed file with 9 additions and 16 deletions.
25 changes: 9 additions & 16 deletions sound/soc/intel/skylake/skl-pcm.c
Expand Up @@ -1317,21 +1317,6 @@ static int skl_get_module_info(struct skl_dev *skl,
return -EIO;
}

list_for_each_entry(module, &skl->uuid_list, list) {
if (guid_equal(uuid_mod, &module->uuid)) {
mconfig->id.module_id = module->id;
if (mconfig->module)
mconfig->module->loadable = module->is_loadable;
ret = 0;
break;
}
}

if (ret)
return ret;

uuid_mod = &module->uuid;
ret = -EIO;
for (i = 0; i < skl->nr_modules; i++) {
skl_module = skl->modules[i];
uuid_tplg = &skl_module->uuid;
Expand All @@ -1341,10 +1326,18 @@ static int skl_get_module_info(struct skl_dev *skl,
break;
}
}

if (skl->nr_modules && ret)
return ret;

ret = -EIO;
list_for_each_entry(module, &skl->uuid_list, list) {
if (guid_equal(uuid_mod, &module->uuid)) {
mconfig->id.module_id = module->id;
mconfig->module->loadable = module->is_loadable;
ret = 0;
}

for (i = 0; i < MAX_IN_QUEUE; i++) {
pin_id = &mconfig->m_in_pin[i].id;
if (guid_equal(&pin_id->mod_uuid, &module->uuid))
Expand All @@ -1358,7 +1351,7 @@ static int skl_get_module_info(struct skl_dev *skl,
}
}

return 0;
return ret;
}

static int skl_populate_modules(struct skl_dev *skl)
Expand Down

0 comments on commit 43e8f17

Please sign in to comment.