ASoC: Intel: cht_bsw_nau8824: platform name fixup support
authorPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Fri, 25 Jan 2019 20:35:04 +0000 (14:35 -0600)
committerMark Brown <broonie@kernel.org>
Mon, 28 Jan 2019 18:08:51 +0000 (18:08 +0000)
Add helper to override dailink platform name, if passed as parameter

Signed-off-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/intel/boards/cht_bsw_nau8824.c

index 30c46977d53c2827a858fc13bda0663093a2b528..02c2fa23933107a5c8a20cc1f2be96d2d2dcf419 100644 (file)
@@ -25,6 +25,7 @@
 #include <sound/pcm.h>
 #include <sound/pcm_params.h>
 #include <sound/soc.h>
+#include <sound/soc-acpi.h>
 #include <sound/jack.h>
 #include <linux/input.h>
 #include "../atom/sst-atom-controls.h"
@@ -246,6 +247,8 @@ static struct snd_soc_card snd_soc_card_cht = {
 static int snd_cht_mc_probe(struct platform_device *pdev)
 {
        struct cht_mc_private *drv;
+       struct snd_soc_acpi_mach *mach;
+       const char *platform_name;
        int ret_val;
 
        drv = devm_kzalloc(&pdev->dev, sizeof(*drv), GFP_KERNEL);
@@ -253,6 +256,15 @@ static int snd_cht_mc_probe(struct platform_device *pdev)
                return -ENOMEM;
        snd_soc_card_set_drvdata(&snd_soc_card_cht, drv);
 
+       /* override plaform name, if required */
+       mach = (&pdev->dev)->platform_data;
+       platform_name = mach->mach_params.platform;
+
+       ret_val = snd_soc_fixup_dai_links_platform_name(&snd_soc_card_cht,
+                                                       platform_name);
+       if (ret_val)
+               return ret_val;
+
        /* register the soc card */
        snd_soc_card_cht.dev = &pdev->dev;
        ret_val = devm_snd_soc_register_card(&pdev->dev, &snd_soc_card_cht);