return tplg_filename;
 }
 
-static int dmic_topology_fixup(struct snd_sof_dev *sdev,
-                              const char **tplg_filename,
-                              const char *idisp_str,
-                              int *dmic_found)
+static int dmic_detect_topology_fixup(struct snd_sof_dev *sdev,
+                                     const char **tplg_filename,
+                                     const char *idisp_str,
+                                     int *dmic_found,
+                                     bool tplg_fixup)
 {
-       const char *default_tplg_filename = *tplg_filename;
-       const char *fixed_tplg_filename;
        const char *dmic_str;
        int dmic_num;
 
                break;
        }
 
-       fixed_tplg_filename = fixup_tplg_name(sdev, default_tplg_filename,
-                                             idisp_str, dmic_str);
-       if (!fixed_tplg_filename)
-               return -ENOMEM;
+       if (tplg_fixup) {
+               const char *default_tplg_filename = *tplg_filename;
+               const char *fixed_tplg_filename;
+
+               fixed_tplg_filename = fixup_tplg_name(sdev, default_tplg_filename,
+                                                     idisp_str, dmic_str);
+               if (!fixed_tplg_filename)
+                       return -ENOMEM;
+               *tplg_filename = fixed_tplg_filename;
+       }
 
        dev_info(sdev->dev, "DMICs detected in NHLT tables: %d\n", dmic_num);
        *dmic_found = dmic_num;
-       *tplg_filename = fixed_tplg_filename;
 
        return 0;
 }
                 *  - one external HDAudio codec
                 */
                if (!*mach && codec_num <= 2) {
+                       bool tplg_fixup;
+
                        hda_mach = snd_soc_acpi_intel_hda_machines;
 
                        dev_info(bus->dev, "using HDA machine driver %s now\n",
                                idisp_str = "";
 
                        /* topology: use the info from hda_machines */
-                       tplg_filename = hda_mach->sof_tplg_filename;
-                       ret = dmic_topology_fixup(sdev, &tplg_filename, idisp_str, &dmic_num);
+                       if (pdata->tplg_filename) {
+                               tplg_fixup = false;
+                               tplg_filename = pdata->tplg_filename;
+                       } else {
+                               tplg_fixup = true;
+                               tplg_filename = hda_mach->sof_tplg_filename;
+                       }
+                       ret = dmic_detect_topology_fixup(sdev, &tplg_filename, idisp_str, &dmic_num,
+                                                        tplg_fixup);
                        if (ret < 0)
                                return;
 
                }
                if (mach && mach->link_mask) {
                        int dmic_num = 0;
+                       bool tplg_fixup;
+                       const char *tplg_filename;
 
                        mach->mach_params.links = mach->links;
                        mach->mach_params.link_mask = mach->link_mask;
                        mach->mach_params.platform = dev_name(sdev->dev);
-                       pdata->tplg_filename = mach->sof_tplg_filename;
+
+                       if (pdata->tplg_filename) {
+                               tplg_fixup = false;
+                       } else {
+                               tplg_fixup = true;
+                               tplg_filename = mach->sof_tplg_filename;
+                       }
 
                        /*
                         * DMICs use up to 4 pins and are typically pin-muxed with SoundWire
                         * b) the NHLT table reports the presence of microphones
                         */
                        if (hweight_long(mach->link_mask) <= 2) {
-                               const char *tplg_filename = mach->sof_tplg_filename;
                                int ret;
 
-                               ret = dmic_topology_fixup(sdev, &tplg_filename, "", &dmic_num);
+                               ret = dmic_detect_topology_fixup(sdev, &tplg_filename, "",
+                                                                &dmic_num, tplg_fixup);
                                if (ret < 0)
                                        return NULL;
-
-                               pdata->tplg_filename = tplg_filename;
                        }
+                       if (tplg_fixup)
+                               pdata->tplg_filename = tplg_filename;
                        mach->mach_params.dmic_num = dmic_num;
 
                        dev_dbg(sdev->dev,
        mach = snd_soc_acpi_find_machine(desc->machines);
        if (mach) {
                bool add_extension = false;
+               bool tplg_fixup = false;
 
                /*
                 * If tplg file name is overridden, use it instead of
                 * the one set in mach table
                 */
-               if (!sof_pdata->tplg_filename)
+               if (!sof_pdata->tplg_filename) {
                        sof_pdata->tplg_filename = mach->sof_tplg_filename;
+                       tplg_fixup = true;
+               }
 
                /* report to machine driver if any DMICs are found */
                mach->mach_params.dmic_num = check_dmic_num(sdev);
 
-               if (mach->tplg_quirk_mask & SND_SOC_ACPI_TPLG_INTEL_DMIC_NUMBER &&
+               if (tplg_fixup &&
+                   mach->tplg_quirk_mask & SND_SOC_ACPI_TPLG_INTEL_DMIC_NUMBER &&
                    mach->mach_params.dmic_num) {
                        tplg_filename = devm_kasprintf(sdev->dev, GFP_KERNEL,
                                                       "%s%s%d%s",
                /* report SSP link mask to machine driver */
                mach->mach_params.i2s_link_mask = check_nhlt_ssp_mask(sdev);
 
-               if (mach->tplg_quirk_mask & SND_SOC_ACPI_TPLG_INTEL_SSP_NUMBER &&
+               if (tplg_fixup &&
+                   mach->tplg_quirk_mask & SND_SOC_ACPI_TPLG_INTEL_SSP_NUMBER &&
                    mach->mach_params.i2s_link_mask) {
                        int ssp_num;
 
                        add_extension = true;
                }
 
-               if (add_extension) {
+               if (tplg_fixup && add_extension) {
                        tplg_filename = devm_kasprintf(sdev->dev, GFP_KERNEL,
                                                       "%s%s",
                                                       sof_pdata->tplg_filename,