ASoC: SOF: Intel: mtl: setup primary core info on MeteorLake platform
authorRander Wang <rander.wang@intel.com>
Fri, 16 Jun 2023 10:00:39 +0000 (12:00 +0200)
committerMark Brown <broonie@kernel.org>
Fri, 16 Jun 2023 11:53:54 +0000 (12:53 +0100)
Set primary core mask and refcount.

Reviewed-by: Ranjani Sridharan <ranjani.sridharan@linux.intel.com>
Reviewed-by: Péter Ujfalusi <peter.ujfalusi@linux.intel.com>
Signed-off-by: Rander Wang <rander.wang@intel.com>
Signed-off-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Link: https://lore.kernel.org/r/20230616100039.378150-9-pierre-louis.bossart@linux.intel.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/sof/intel/mtl.c

index 8ae331f..30fe77f 100644 (file)
@@ -361,11 +361,17 @@ static int mtl_dsp_core_power_up(struct snd_sof_dev *sdev, int core)
        ret = snd_sof_dsp_read_poll_timeout(sdev, HDA_DSP_BAR, MTL_DSP2CXCTL_PRIMARY_CORE, dspcxctl,
                                            (dspcxctl & cpa) == cpa, HDA_DSP_REG_POLL_INTERVAL_US,
                                            HDA_DSP_RESET_TIMEOUT_US);
-       if (ret < 0)
+       if (ret < 0) {
                dev_err(sdev->dev, "%s: timeout on MTL_DSP2CXCTL_PRIMARY_CORE read\n",
                        __func__);
+               return ret;
+       }
 
-       return ret;
+       /* set primary core mask and refcount to 1 */
+       sdev->enabled_cores_mask = BIT(SOF_DSP_PRIMARY_CORE);
+       sdev->dsp_core_ref_count[SOF_DSP_PRIMARY_CORE] = 1;
+
+       return 0;
 }
 
 static int mtl_dsp_core_power_down(struct snd_sof_dev *sdev, int core)
@@ -388,10 +394,15 @@ static int mtl_dsp_core_power_down(struct snd_sof_dev *sdev, int core)
                                            !(dspcxctl & MTL_DSP2CXCTL_PRIMARY_CORE_CPA_MASK),
                                            HDA_DSP_REG_POLL_INTERVAL_US,
                                            HDA_DSP_PD_TIMEOUT * USEC_PER_MSEC);
-       if (ret < 0)
+       if (ret < 0) {
                dev_err(sdev->dev, "failed to power down primary core\n");
+               return ret;
+       }
 
-       return ret;
+       sdev->enabled_cores_mask = 0;
+       sdev->dsp_core_ref_count[SOF_DSP_PRIMARY_CORE] = 0;
+
+       return 0;
 }
 
 int mtl_power_down_dsp(struct snd_sof_dev *sdev)