|
@@ -502,7 +502,7 @@ static int adau17x1_hw_params(struct snd_pcm_substream *substream,
|
|
|
}
|
|
|
|
|
|
if (adau->sigmadsp) {
|
|
|
- ret = adau17x1_setup_firmware(adau, params_rate(params));
|
|
|
+ ret = adau17x1_setup_firmware(component, params_rate(params));
|
|
|
if (ret < 0)
|
|
|
return ret;
|
|
|
}
|
|
@@ -835,26 +835,40 @@ bool adau17x1_volatile_register(struct device *dev, unsigned int reg)
|
|
|
}
|
|
|
EXPORT_SYMBOL_GPL(adau17x1_volatile_register);
|
|
|
|
|
|
-int adau17x1_setup_firmware(struct adau *adau, unsigned int rate)
|
|
|
+int adau17x1_setup_firmware(struct snd_soc_component *component,
|
|
|
+ unsigned int rate)
|
|
|
{
|
|
|
int ret;
|
|
|
- int dspsr;
|
|
|
+ int dspsr, dsp_run;
|
|
|
+ struct adau *adau = snd_soc_component_get_drvdata(component);
|
|
|
+ struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component);
|
|
|
+
|
|
|
+ snd_soc_dapm_mutex_lock(dapm);
|
|
|
|
|
|
ret = regmap_read(adau->regmap, ADAU17X1_DSP_SAMPLING_RATE, &dspsr);
|
|
|
if (ret)
|
|
|
- return ret;
|
|
|
+ goto err;
|
|
|
+
|
|
|
+ ret = regmap_read(adau->regmap, ADAU17X1_DSP_RUN, &dsp_run);
|
|
|
+ if (ret)
|
|
|
+ goto err;
|
|
|
|
|
|
regmap_write(adau->regmap, ADAU17X1_DSP_ENABLE, 1);
|
|
|
regmap_write(adau->regmap, ADAU17X1_DSP_SAMPLING_RATE, 0xf);
|
|
|
+ regmap_write(adau->regmap, ADAU17X1_DSP_RUN, 0);
|
|
|
|
|
|
ret = sigmadsp_setup(adau->sigmadsp, rate);
|
|
|
if (ret) {
|
|
|
regmap_write(adau->regmap, ADAU17X1_DSP_ENABLE, 0);
|
|
|
- return ret;
|
|
|
+ goto err;
|
|
|
}
|
|
|
regmap_write(adau->regmap, ADAU17X1_DSP_SAMPLING_RATE, dspsr);
|
|
|
+ regmap_write(adau->regmap, ADAU17X1_DSP_RUN, dsp_run);
|
|
|
|
|
|
- return 0;
|
|
|
+err:
|
|
|
+ snd_soc_dapm_mutex_unlock(dapm);
|
|
|
+
|
|
|
+ return ret;
|
|
|
}
|
|
|
EXPORT_SYMBOL_GPL(adau17x1_setup_firmware);
|
|
|
|