Introduce sof_of_machine_select

Merge series from Chunxu Li <chunxu.li@mediatek.com>:

In these patches, we introduce function sof_of_machine_select for SOF
This commit is contained in:
Mark Brown 2022-08-23 19:48:39 +01:00
commit 78f0ecf3c3
No known key found for this signature in database
GPG Key ID: 24D68B725D5487D0
5 changed files with 26 additions and 1 deletions

View File

@ -89,6 +89,7 @@ struct snd_sof_pdata {
/* machine */ /* machine */
struct platform_device *pdev_mach; struct platform_device *pdev_mach;
const struct snd_soc_acpi_mach *machine; const struct snd_soc_acpi_mach *machine;
const struct snd_sof_of_mach *of_machine;
void *hw_pdata; void *hw_pdata;
@ -102,6 +103,7 @@ struct snd_sof_pdata {
struct sof_dev_desc { struct sof_dev_desc {
/* list of machines using this configuration */ /* list of machines using this configuration */
struct snd_soc_acpi_mach *machines; struct snd_soc_acpi_mach *machines;
struct snd_sof_of_mach *of_machines;
/* alternate list of machines using this configuration */ /* alternate list of machines using this configuration */
struct snd_soc_acpi_mach *alt_machines; struct snd_soc_acpi_mach *alt_machines;

View File

@ -515,7 +515,16 @@ static struct snd_sof_dsp_ops sof_mt8186_ops = {
SNDRV_PCM_INFO_NO_PERIOD_WAKEUP, SNDRV_PCM_INFO_NO_PERIOD_WAKEUP,
}; };
static struct snd_sof_of_mach sof_mt8186_machs[] = {
{
.compatible = "mediatek,mt8186",
.sof_tplg_filename = "sof-mt8186.tplg",
},
{}
};
static const struct sof_dev_desc sof_of_mt8186_desc = { static const struct sof_dev_desc sof_of_mt8186_desc = {
.of_machines = sof_mt8186_machs,
.ipc_supported_mask = BIT(SOF_IPC), .ipc_supported_mask = BIT(SOF_IPC),
.ipc_default = SOF_IPC, .ipc_default = SOF_IPC,
.default_fw_path = { .default_fw_path = {

View File

@ -13,6 +13,7 @@
#include <linux/pm_runtime.h> #include <linux/pm_runtime.h>
#include <sound/pcm_params.h> #include <sound/pcm_params.h>
#include <sound/sof.h> #include <sound/sof.h>
#include "sof-of-dev.h"
#include "sof-priv.h" #include "sof-priv.h"
#include "sof-audio.h" #include "sof-audio.h"
#include "sof-utils.h" #include "sof-utils.h"
@ -655,7 +656,12 @@ void snd_sof_new_platform_drv(struct snd_sof_dev *sdev)
struct snd_sof_pdata *plat_data = sdev->pdata; struct snd_sof_pdata *plat_data = sdev->pdata;
const char *drv_name; const char *drv_name;
drv_name = plat_data->machine->drv_name; if (plat_data->machine)
drv_name = plat_data->machine->drv_name;
else if (plat_data->of_machine)
drv_name = plat_data->of_machine->drv_name;
else
drv_name = NULL;
pd->name = "sof-audio-component"; pd->name = "sof-audio-component";
pd->probe = sof_pcm_probe; pd->probe = sof_pcm_probe;

View File

@ -10,6 +10,7 @@
#include <linux/bitfield.h> #include <linux/bitfield.h>
#include "sof-audio.h" #include "sof-audio.h"
#include "sof-of-dev.h"
#include "ops.h" #include "ops.h"
static void sof_reset_route_setup_status(struct snd_sof_dev *sdev, struct snd_sof_widget *widget) static void sof_reset_route_setup_status(struct snd_sof_dev *sdev, struct snd_sof_widget *widget)

View File

@ -9,6 +9,13 @@
#ifndef __SOUND_SOC_SOF_OF_H #ifndef __SOUND_SOC_SOF_OF_H
#define __SOUND_SOC_SOF_OF_H #define __SOUND_SOC_SOF_OF_H
struct snd_sof_of_mach {
const char *compatible;
const char *drv_name;
const char *fw_filename;
const char *sof_tplg_filename;
};
extern const struct dev_pm_ops sof_of_pm; extern const struct dev_pm_ops sof_of_pm;
int sof_of_probe(struct platform_device *pdev); int sof_of_probe(struct platform_device *pdev);