xref: /linux/sound/soc/intel/avs/boards/dmic.c (revision 33e02dc69afbd8f1b85a51d74d72f139ba4ca623)
16575e5caSCezary Rojewski // SPDX-License-Identifier: GPL-2.0-only
26575e5caSCezary Rojewski //
3*94001147SPierre-Louis Bossart // Copyright(c) 2021-2022 Intel Corporation
46575e5caSCezary Rojewski //
56575e5caSCezary Rojewski // Authors: Cezary Rojewski <cezary.rojewski@intel.com>
66575e5caSCezary Rojewski //          Amadeusz Slawinski <amadeuszx.slawinski@linux.intel.com>
76575e5caSCezary Rojewski //
86575e5caSCezary Rojewski 
96575e5caSCezary Rojewski #include <linux/device.h>
106575e5caSCezary Rojewski #include <linux/module.h>
116575e5caSCezary Rojewski #include <sound/soc.h>
126575e5caSCezary Rojewski #include <sound/soc-acpi.h>
136575e5caSCezary Rojewski 
146575e5caSCezary Rojewski SND_SOC_DAILINK_DEF(dmic_pin, DAILINK_COMP_ARRAY(COMP_CPU("DMIC Pin")));
156575e5caSCezary Rojewski SND_SOC_DAILINK_DEF(dmic_wov_pin, DAILINK_COMP_ARRAY(COMP_CPU("DMIC WoV Pin")));
166575e5caSCezary Rojewski SND_SOC_DAILINK_DEF(dmic_codec, DAILINK_COMP_ARRAY(COMP_CODEC("dmic-codec", "dmic-hifi")));
176575e5caSCezary Rojewski /* Name overridden on probe */
186575e5caSCezary Rojewski SND_SOC_DAILINK_DEF(platform, DAILINK_COMP_ARRAY(COMP_PLATFORM("")));
196575e5caSCezary Rojewski 
206575e5caSCezary Rojewski static struct snd_soc_dai_link card_dai_links[] = {
216575e5caSCezary Rojewski 	/* Back ends */
226575e5caSCezary Rojewski 	{
236575e5caSCezary Rojewski 		.name = "DMIC",
246575e5caSCezary Rojewski 		.id = 0,
256575e5caSCezary Rojewski 		.dpcm_capture = 1,
266575e5caSCezary Rojewski 		.nonatomic = 1,
276575e5caSCezary Rojewski 		.no_pcm = 1,
286575e5caSCezary Rojewski 		SND_SOC_DAILINK_REG(dmic_pin, dmic_codec, platform),
296575e5caSCezary Rojewski 	},
306575e5caSCezary Rojewski 	{
316575e5caSCezary Rojewski 		.name = "DMIC WoV",
326575e5caSCezary Rojewski 		.id = 1,
336575e5caSCezary Rojewski 		.dpcm_capture = 1,
346575e5caSCezary Rojewski 		.nonatomic = 1,
356575e5caSCezary Rojewski 		.no_pcm = 1,
366575e5caSCezary Rojewski 		.ignore_suspend = 1,
376575e5caSCezary Rojewski 		SND_SOC_DAILINK_REG(dmic_wov_pin, dmic_codec, platform),
386575e5caSCezary Rojewski 	},
396575e5caSCezary Rojewski };
406575e5caSCezary Rojewski 
416575e5caSCezary Rojewski static const struct snd_soc_dapm_widget card_widgets[] = {
426575e5caSCezary Rojewski 	SND_SOC_DAPM_MIC("SoC DMIC", NULL),
436575e5caSCezary Rojewski };
446575e5caSCezary Rojewski 
456575e5caSCezary Rojewski static const struct snd_soc_dapm_route card_routes[] = {
466575e5caSCezary Rojewski 	{"DMic", NULL, "SoC DMIC"},
476575e5caSCezary Rojewski };
486575e5caSCezary Rojewski 
avs_dmic_probe(struct platform_device * pdev)496575e5caSCezary Rojewski static int avs_dmic_probe(struct platform_device *pdev)
506575e5caSCezary Rojewski {
516575e5caSCezary Rojewski 	struct snd_soc_acpi_mach *mach;
526575e5caSCezary Rojewski 	struct snd_soc_card *card;
536575e5caSCezary Rojewski 	struct device *dev = &pdev->dev;
546575e5caSCezary Rojewski 	int ret;
556575e5caSCezary Rojewski 
566575e5caSCezary Rojewski 	mach = dev_get_platdata(dev);
576575e5caSCezary Rojewski 
586575e5caSCezary Rojewski 	card = devm_kzalloc(dev, sizeof(*card), GFP_KERNEL);
596575e5caSCezary Rojewski 	if (!card)
606575e5caSCezary Rojewski 		return -ENOMEM;
616575e5caSCezary Rojewski 
626575e5caSCezary Rojewski 	card->name = "avs_dmic";
636575e5caSCezary Rojewski 	card->dev = dev;
646575e5caSCezary Rojewski 	card->owner = THIS_MODULE;
656575e5caSCezary Rojewski 	card->dai_link = card_dai_links;
666575e5caSCezary Rojewski 	card->num_links = ARRAY_SIZE(card_dai_links);
676575e5caSCezary Rojewski 	card->dapm_widgets = card_widgets;
686575e5caSCezary Rojewski 	card->num_dapm_widgets = ARRAY_SIZE(card_widgets);
696575e5caSCezary Rojewski 	card->dapm_routes = card_routes;
706575e5caSCezary Rojewski 	card->num_dapm_routes = ARRAY_SIZE(card_routes);
716575e5caSCezary Rojewski 	card->fully_routed = true;
726575e5caSCezary Rojewski 
736575e5caSCezary Rojewski 	ret = snd_soc_fixup_dai_links_platform_name(card, mach->mach_params.platform);
746575e5caSCezary Rojewski 	if (ret)
756575e5caSCezary Rojewski 		return ret;
766575e5caSCezary Rojewski 
776575e5caSCezary Rojewski 	return devm_snd_soc_register_card(dev, card);
786575e5caSCezary Rojewski }
796575e5caSCezary Rojewski 
80deb8dcadSAmadeusz Sławiński static const struct platform_device_id avs_dmic_driver_ids[] = {
81deb8dcadSAmadeusz Sławiński 	{
82deb8dcadSAmadeusz Sławiński 		.name = "avs_dmic",
83deb8dcadSAmadeusz Sławiński 	},
84deb8dcadSAmadeusz Sławiński 	{},
85deb8dcadSAmadeusz Sławiński };
86deb8dcadSAmadeusz Sławiński MODULE_DEVICE_TABLE(platform, avs_dmic_driver_ids);
87deb8dcadSAmadeusz Sławiński 
886575e5caSCezary Rojewski static struct platform_driver avs_dmic_driver = {
896575e5caSCezary Rojewski 	.probe = avs_dmic_probe,
906575e5caSCezary Rojewski 	.driver = {
916575e5caSCezary Rojewski 		.name = "avs_dmic",
926575e5caSCezary Rojewski 		.pm = &snd_soc_pm_ops,
936575e5caSCezary Rojewski 	},
94deb8dcadSAmadeusz Sławiński 	.id_table = avs_dmic_driver_ids,
956575e5caSCezary Rojewski };
966575e5caSCezary Rojewski 
976575e5caSCezary Rojewski module_platform_driver(avs_dmic_driver);
986575e5caSCezary Rojewski 
99d619b0b7SAmadeusz Sławiński MODULE_DESCRIPTION("Intel DMIC machine driver");
1006575e5caSCezary Rojewski MODULE_LICENSE("GPL");
101