Skip to content

Commit

Permalink
ASoC: SOF: debug: show firmware/topology prefix/names
Browse files Browse the repository at this point in the history
The SOF driver has multiple profiles to select firmware/topology
prefix/names depending on the platform and ipc_type, and each of those
fields can be overridden with kernel parameters. This results in some
cases in confusion on what configuration is actually used in a given
test.

We currently log the firmware and topology names in the kernel logs,
but there's been an ask to add the information in debugfs to simplify
test scripts used by developers and CI.

This isn't meant to be a stable ABI used by apps, changes will be
allowed as needed.

Closes: thesofproject#3867
Signed-off-by: Pierre-Louis Bossart <[email protected]>
  • Loading branch information
plbossart committed Apr 4, 2024
1 parent 98c2a40 commit c82788b
Showing 1 changed file with 12 additions and 0 deletions.
12 changes: 12 additions & 0 deletions sound/soc/sof/debug.c
Original file line number Diff line number Diff line change
Expand Up @@ -330,14 +330,26 @@ EXPORT_SYMBOL_GPL(snd_sof_dbg_memory_info_init);

int snd_sof_dbg_init(struct snd_sof_dev *sdev)
{
struct snd_sof_pdata *plat_data = sdev->pdata;
struct snd_sof_dsp_ops *ops = sof_ops(sdev);
const struct snd_sof_debugfs_map *map;
struct dentry *fw_profile;
int i;
int err;

/* use "sof" as top level debugFS dir */
sdev->debugfs_root = debugfs_create_dir("sof", NULL);

/* expose firmware/topology prefix/names for test purposes */
fw_profile = debugfs_create_dir("fw_profile", sdev->debugfs_root);

debugfs_create_str("fw_path", 0444, fw_profile, (char **)&plat_data->fw_filename_prefix);
debugfs_create_str("fw_lib_path", 0444, fw_profile, (char **)&plat_data->fw_lib_prefix);
debugfs_create_str("tplg_path", 0444, fw_profile, (char **)&plat_data->tplg_filename_prefix);
debugfs_create_str("fw_name", 0444, fw_profile, (char **)&plat_data->fw_filename);
debugfs_create_str("tplg_name", 0444, fw_profile, (char **)&plat_data->tplg_filename);
debugfs_create_u32("ipc_type", 0444, fw_profile, (u32 *)&plat_data->ipc_type);

/* init dfsentry list */
INIT_LIST_HEAD(&sdev->dfsentry_list);

Expand Down

0 comments on commit c82788b

Please sign in to comment.