diff options
Diffstat (limited to 'sound/soc/meson/t9015.c')
| -rw-r--r-- | sound/soc/meson/t9015.c | 20 | 
1 files changed, 4 insertions, 16 deletions
diff --git a/sound/soc/meson/t9015.c b/sound/soc/meson/t9015.c index 9c6b4dac6893..571f65788c59 100644 --- a/sound/soc/meson/t9015.c +++ b/sound/soc/meson/t9015.c @@ -48,7 +48,6 @@  #define POWER_CFG	0x10  struct t9015 { -	struct clk *pclk;  	struct regulator *avdd;  }; @@ -249,6 +248,7 @@ static int t9015_probe(struct platform_device *pdev)  	struct t9015 *priv;  	void __iomem *regs;  	struct regmap *regmap; +	struct clk *pclk;  	int ret;  	priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL); @@ -256,26 +256,14 @@ static int t9015_probe(struct platform_device *pdev)  		return -ENOMEM;  	platform_set_drvdata(pdev, priv); -	priv->pclk = devm_clk_get(dev, "pclk"); -	if (IS_ERR(priv->pclk)) -		return dev_err_probe(dev, PTR_ERR(priv->pclk), "failed to get core clock\n"); +	pclk = devm_clk_get_enabled(dev, "pclk"); +	if (IS_ERR(pclk)) +		return dev_err_probe(dev, PTR_ERR(pclk), "failed to get core clock\n");  	priv->avdd = devm_regulator_get(dev, "AVDD");  	if (IS_ERR(priv->avdd))  		return dev_err_probe(dev, PTR_ERR(priv->avdd), "failed to AVDD\n"); -	ret = clk_prepare_enable(priv->pclk); -	if (ret) { -		dev_err(dev, "core clock enable failed\n"); -		return ret; -	} - -	ret = devm_add_action_or_reset(dev, -			(void(*)(void *))clk_disable_unprepare, -			priv->pclk); -	if (ret) -		return ret; -  	ret = device_reset(dev);  	if (ret) {  		dev_err(dev, "reset failed\n");  |