Unverified Commit 0db0c62c authored by Katsuhiro Suzuki's avatar Katsuhiro Suzuki Committed by Mark Brown
Browse files

ASoC: es8316: fix redundant codes of clock



This patch removes redundant null checks for optional MCLK clock.
And fix DT binding document for changing clock property to optional
from required.

Signed-off-by: default avatarKatsuhiro Suzuki <katsuhiro@katsuster.net>
Link: https://lore.kernel.org/r/20190907163653.9382-1-katsuhiro@katsuster.net


Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent f4df4e40
Loading
Loading
Loading
Loading
+3 −0
Original line number Diff line number Diff line
@@ -6,6 +6,9 @@ Required properties:

  - compatible  : should be "everest,es8316"
  - reg : the I2C address of the device for I2C

Optional properties:

  - clocks : a list of phandle, should contain entries for clock-names
  - clock-names : should include as follows:
         "mclk" : master clock (MCLK) of the device
+13 −18
Original line number Diff line number Diff line
@@ -370,11 +370,9 @@ static int es8316_set_dai_sysclk(struct snd_soc_dai *codec_dai,
	if (freq == 0)
		return 0;

	if (es8316->mclk) {
	ret = clk_set_rate(es8316->mclk, freq);
	if (ret)
		return ret;
	}

	/* Limit supported sample rates to ones that can be autodetected
	 * by the codec running in slave mode.
@@ -709,21 +707,19 @@ static int es8316_probe(struct snd_soc_component *component)

	es8316->component = component;

	es8316->mclk = devm_clk_get(component->dev, "mclk");
	if (PTR_ERR(es8316->mclk) == -EPROBE_DEFER)
		return -EPROBE_DEFER;
	es8316->mclk = devm_clk_get_optional(component->dev, "mclk");
	if (IS_ERR(es8316->mclk)) {
		dev_err(component->dev, "clock is invalid, ignored\n");
		es8316->mclk = NULL;
		dev_err(component->dev, "unable to get mclk\n");
		return PTR_ERR(es8316->mclk);
	}
	if (!es8316->mclk)
		dev_warn(component->dev, "assuming static mclk\n");

	if (es8316->mclk) {
	ret = clk_prepare_enable(es8316->mclk);
	if (ret) {
			dev_err(component->dev, "unable to enable clock\n");
		dev_err(component->dev, "unable to enable mclk\n");
		return ret;
	}
	}

	/* Reset codec and enable current state machine */
	snd_soc_component_write(component, ES8316_RESET, 0x3f);
@@ -751,7 +747,6 @@ static void es8316_remove(struct snd_soc_component *component)
{
	struct es8316_priv *es8316 = snd_soc_component_get_drvdata(component);

	if (es8316->mclk)
	clk_disable_unprepare(es8316->mclk);
}