Commit 7ed1f83b authored by Peter Ujfalusi's avatar Peter Ujfalusi Committed by Mark Brown

ASoC: SOF: Compile and runtime IPC version selection

The new IPC4 version is only supported by Intel platforms, iMX, AMD and
MediaTek only uses the standard SOF IPC.
There is no need for these platforms to build kernel support for IPC4 as
it is just dead code for them.

SND_SOC_SOF_IPC3 and SND_SOC_SOF_INTEL_IPC4 is introduced to allow compile
time selection and exclusion of IPC implementations.

To avoid randconfig failures add also support for runtime selection of
the IPC ops in ipc.c based on sdev->pdata->ipc_type
Signed-off-by: default avatarPeter Ujfalusi <peter.ujfalusi@linux.intel.com>
Reviewed-by: default avatarBard Liao <yung-chuan.liao@linux.intel.com>
Reviewed-by: default avatarRanjani Sridharan <ranjani.sridharan@linux.intel.com>
Link: https://lore.kernel.org/r/20220614075618.28605-1-peter.ujfalusi@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 689614ce
...@@ -252,6 +252,13 @@ config SND_SOC_SOF_PROBE_WORK_QUEUE ...@@ -252,6 +252,13 @@ config SND_SOC_SOF_PROBE_WORK_QUEUE
When selected, the probe is handled in two steps, for example to When selected, the probe is handled in two steps, for example to
avoid lockdeps if request_module is used in the probe. avoid lockdeps if request_module is used in the probe.
# Supported IPC versions
config SND_SOC_SOF_IPC3
bool
config SND_SOC_SOF_INTEL_IPC4
bool
source "sound/soc/sof/amd/Kconfig" source "sound/soc/sof/amd/Kconfig"
source "sound/soc/sof/imx/Kconfig" source "sound/soc/sof/imx/Kconfig"
source "sound/soc/sof/intel/Kconfig" source "sound/soc/sof/intel/Kconfig"
......
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause) # SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause)
snd-sof-objs := core.o ops.o loader.o ipc.o pcm.o pm.o debug.o topology.o\ snd-sof-objs := core.o ops.o loader.o ipc.o pcm.o pm.o debug.o topology.o\
control.o trace.o iomem-utils.o sof-audio.o stream-ipc.o\ control.o trace.o iomem-utils.o sof-audio.o stream-ipc.o
ipc3-topology.o ipc3-control.o ipc3.o ipc3-pcm.o ipc3-loader.o\
ipc3-dtrace.o\ # IPC implementations
ipc4.o ipc4-loader.o ipc4-topology.o ipc4-control.o ipc4-pcm.o ifneq ($(CONFIG_SND_SOC_SOF_IPC3),)
snd-sof-objs += ipc3.o ipc3-loader.o ipc3-topology.o ipc3-control.o ipc3-pcm.o\
ipc3-dtrace.o
endif
ifneq ($(CONFIG_SND_SOC_SOF_INTEL_IPC4),)
snd-sof-objs += ipc4.o ipc4-loader.o ipc4-topology.o ipc4-control.o ipc4-pcm.o
endif
# SOF client support
ifneq ($(CONFIG_SND_SOC_SOF_CLIENT),) ifneq ($(CONFIG_SND_SOC_SOF_CLIENT),)
snd-sof-objs += sof-client.o snd-sof-objs += sof-client.o
endif endif
......
...@@ -17,6 +17,7 @@ if SND_SOC_SOF_AMD_TOPLEVEL ...@@ -17,6 +17,7 @@ if SND_SOC_SOF_AMD_TOPLEVEL
config SND_SOC_SOF_AMD_COMMON config SND_SOC_SOF_AMD_COMMON
tristate tristate
select SND_SOC_SOF select SND_SOC_SOF
select SND_SOC_SOF_IPC3
select SND_SOC_SOF_PCI_DEV select SND_SOC_SOF_PCI_DEV
select SND_AMD_ACP_CONFIG select SND_AMD_ACP_CONFIG
select SND_SOC_ACPI if ACPI select SND_SOC_ACPI if ACPI
......
...@@ -15,6 +15,7 @@ config SND_SOC_SOF_IMX_COMMON ...@@ -15,6 +15,7 @@ config SND_SOC_SOF_IMX_COMMON
tristate tristate
select SND_SOC_SOF_OF_DEV select SND_SOC_SOF_OF_DEV
select SND_SOC_SOF select SND_SOC_SOF
select SND_SOC_SOF_IPC3
select SND_SOC_SOF_XTENSA select SND_SOC_SOF_XTENSA
select SND_SOC_SOF_COMPRESS select SND_SOC_SOF_COMPRESS
help help
......
...@@ -40,6 +40,7 @@ if SND_SOC_SOF_ACPI ...@@ -40,6 +40,7 @@ if SND_SOC_SOF_ACPI
config SND_SOC_SOF_BAYTRAIL config SND_SOC_SOF_BAYTRAIL
tristate "SOF support for Baytrail, Braswell and Cherrytrail" tristate "SOF support for Baytrail, Braswell and Cherrytrail"
default SND_SOC_SOF_ACPI default SND_SOC_SOF_ACPI
select SND_SOC_SOF_IPC3
select SND_SOC_SOF_INTEL_COMMON select SND_SOC_SOF_INTEL_COMMON
select SND_SOC_SOF_INTEL_ATOM_HIFI_EP select SND_SOC_SOF_INTEL_ATOM_HIFI_EP
select SND_SOC_SOF_ACPI_DEV select SND_SOC_SOF_ACPI_DEV
...@@ -60,6 +61,7 @@ config SND_SOC_SOF_BAYTRAIL ...@@ -60,6 +61,7 @@ config SND_SOC_SOF_BAYTRAIL
config SND_SOC_SOF_BROADWELL config SND_SOC_SOF_BROADWELL
tristate "SOF support for Broadwell" tristate "SOF support for Broadwell"
default SND_SOC_SOF_ACPI default SND_SOC_SOF_ACPI
select SND_SOC_SOF_IPC3
select SND_SOC_SOF_INTEL_COMMON select SND_SOC_SOF_INTEL_COMMON
select SND_SOC_SOF_INTEL_HIFI_EP_IPC select SND_SOC_SOF_INTEL_HIFI_EP_IPC
select SND_SOC_SOF_ACPI_DEV select SND_SOC_SOF_ACPI_DEV
...@@ -85,6 +87,7 @@ config SND_SOC_SOF_MERRIFIELD ...@@ -85,6 +87,7 @@ config SND_SOC_SOF_MERRIFIELD
tristate "SOF support for Tangier/Merrifield" tristate "SOF support for Tangier/Merrifield"
default SND_SOC_SOF_PCI default SND_SOC_SOF_PCI
select SND_SOC_SOF_PCI_DEV select SND_SOC_SOF_PCI_DEV
select SND_SOC_SOF_IPC3
select SND_SOC_SOF_INTEL_ATOM_HIFI_EP select SND_SOC_SOF_INTEL_ATOM_HIFI_EP
help help
This adds support for Sound Open Firmware for Intel(R) platforms This adds support for Sound Open Firmware for Intel(R) platforms
...@@ -95,6 +98,8 @@ config SND_SOC_SOF_MERRIFIELD ...@@ -95,6 +98,8 @@ config SND_SOC_SOF_MERRIFIELD
config SND_SOC_SOF_INTEL_APL config SND_SOC_SOF_INTEL_APL
tristate tristate
select SND_SOC_SOF_HDA_COMMON select SND_SOC_SOF_HDA_COMMON
select SND_SOC_SOF_IPC3
select SND_SOC_SOF_INTEL_IPC4
config SND_SOC_SOF_APOLLOLAKE config SND_SOC_SOF_APOLLOLAKE
tristate "SOF support for Apollolake" tristate "SOF support for Apollolake"
...@@ -120,6 +125,8 @@ config SND_SOC_SOF_INTEL_CNL ...@@ -120,6 +125,8 @@ config SND_SOC_SOF_INTEL_CNL
tristate tristate
select SND_SOC_SOF_HDA_COMMON select SND_SOC_SOF_HDA_COMMON
select SND_SOC_SOF_INTEL_SOUNDWIRE_LINK_BASELINE select SND_SOC_SOF_INTEL_SOUNDWIRE_LINK_BASELINE
select SND_SOC_SOF_IPC3
select SND_SOC_SOF_INTEL_IPC4
config SND_SOC_SOF_CANNONLAKE config SND_SOC_SOF_CANNONLAKE
tristate "SOF support for Cannonlake" tristate "SOF support for Cannonlake"
...@@ -154,6 +161,8 @@ config SND_SOC_SOF_INTEL_ICL ...@@ -154,6 +161,8 @@ config SND_SOC_SOF_INTEL_ICL
tristate tristate
select SND_SOC_SOF_HDA_COMMON select SND_SOC_SOF_HDA_COMMON
select SND_SOC_SOF_INTEL_SOUNDWIRE_LINK_BASELINE select SND_SOC_SOF_INTEL_SOUNDWIRE_LINK_BASELINE
select SND_SOC_SOF_IPC3
select SND_SOC_SOF_INTEL_IPC4
config SND_SOC_SOF_ICELAKE config SND_SOC_SOF_ICELAKE
tristate "SOF support for Icelake" tristate "SOF support for Icelake"
...@@ -179,6 +188,8 @@ config SND_SOC_SOF_INTEL_TGL ...@@ -179,6 +188,8 @@ config SND_SOC_SOF_INTEL_TGL
tristate tristate
select SND_SOC_SOF_HDA_COMMON select SND_SOC_SOF_HDA_COMMON
select SND_SOC_SOF_INTEL_SOUNDWIRE_LINK_BASELINE select SND_SOC_SOF_INTEL_SOUNDWIRE_LINK_BASELINE
select SND_SOC_SOF_IPC3
select SND_SOC_SOF_INTEL_IPC4
config SND_SOC_SOF_TIGERLAKE config SND_SOC_SOF_TIGERLAKE
tristate "SOF support for Tigerlake" tristate "SOF support for Tigerlake"
......
...@@ -155,12 +155,22 @@ struct snd_sof_ipc *snd_sof_ipc_init(struct snd_sof_dev *sdev) ...@@ -155,12 +155,22 @@ struct snd_sof_ipc *snd_sof_ipc_init(struct snd_sof_dev *sdev)
init_waitqueue_head(&msg->waitq); init_waitqueue_head(&msg->waitq);
/* switch (sdev->pdata->ipc_type) {
* Use IPC3 ops as it is the only available version now. With the addition of new IPC #if defined(CONFIG_SND_SOC_SOF_IPC3)
* versions, this will need to be modified to use the selected version at runtime. case SOF_IPC:
*/ ops = &ipc3_ops;
ipc->ops = &ipc3_ops; break;
ops = ipc->ops; #endif
#if defined(CONFIG_SND_SOC_SOF_INTEL_IPC4)
case SOF_INTEL_IPC4:
ops = &ipc4_ops;
break;
#endif
default:
dev_err(sdev->dev, "Not supported IPC version: %d\n",
sdev->pdata->ipc_type);
return NULL;
}
/* check for mandatory ops */ /* check for mandatory ops */
if (!ops->tx_msg || !ops->rx_msg || !ops->set_get_data || !ops->get_reply) { if (!ops->tx_msg || !ops->rx_msg || !ops->set_get_data || !ops->get_reply) {
...@@ -190,6 +200,8 @@ struct snd_sof_ipc *snd_sof_ipc_init(struct snd_sof_dev *sdev) ...@@ -190,6 +200,8 @@ struct snd_sof_ipc *snd_sof_ipc_init(struct snd_sof_dev *sdev)
return NULL; return NULL;
} }
ipc->ops = ops;
return ipc; return ipc;
} }
EXPORT_SYMBOL(snd_sof_ipc_init); EXPORT_SYMBOL(snd_sof_ipc_init);
......
...@@ -15,6 +15,7 @@ config SND_SOC_SOF_MTK_COMMON ...@@ -15,6 +15,7 @@ config SND_SOC_SOF_MTK_COMMON
tristate tristate
select SND_SOC_SOF_OF_DEV select SND_SOC_SOF_OF_DEV
select SND_SOC_SOF select SND_SOC_SOF
select SND_SOC_SOF_IPC3
select SND_SOC_SOF_XTENSA select SND_SOC_SOF_XTENSA
select SND_SOC_SOF_COMPRESS select SND_SOC_SOF_COMPRESS
help help
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment