Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp2177847ybl; Sat, 31 Aug 2019 09:28:39 -0700 (PDT) X-Google-Smtp-Source: APXvYqwQ3QzUplH9+VNOsLE3g4U1s2Vhk/xqumTh+6GWofYtsC0HhzhtcDlT3FsGfdfr6Q7wlkch X-Received: by 2002:a17:90a:a47:: with SMTP id o65mr4630707pjo.90.1567268919422; Sat, 31 Aug 2019 09:28:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567268919; cv=none; d=google.com; s=arc-20160816; b=G+ntz2Z+p0FQf9qYrgRIiUZKjn0GOgygw9M8aBB/c7z/bdXgvXYEOXTZvOJQDw6rxP V7wBp96WRjkxvK13+pm0kfW+SJNdvZpNPEs59MAbylEUtBGONA7qxOQT8le3hVsByQ94 Ny58SkNVciAnq33C0EVFulY2opEGXZP6a+gg6ljl4rRJJfj/i5MWPZ1rEuK/yOb5jYUb zgB0uMp65rpDEVU7K9BgmsRmjZ9Yj2I/8SplF25O3uQ1MAmXgmtcPnTqQOh51YAJA2uG 6Be9AwchS+g7gLZMWWiGrrH0gd2/liiqkBfwfyaEDdcwiEx4HLBUELGID1h7zoD3gnbt 2YUQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=fmHkL7gSDP83t3P8hwd0TsC4vbhj+dfCqkFSelguIzg=; b=ItF669LLVKX4LVCppSvLb9+nLfeK5ten7tDJpI2gkR8xvNEKyTQKOk8SDGDzvPLXtH YEQ/LcF41c7PXjLvk90+fM3oq+w+5RZ9AKivQAjxBK4DtWoPZNpnEyvIcfAotG9T21MK L5+9yb6f22ZXi5AkxIJPHwDdNiUFkvIbhg5EspL+X6tep+1zWA+igwD0dS9MEzGAYGY5 lXP6NmN7+tqB9bNdu2B9bzj2W2JSsG+8+kwqlyeFf9ZskRjLsEYb16w4q/vFZ8Xvsw3y jOA5MskbnXjONe+Vx7gI4CxP1CMRH9FzwfQtUjt4sy5LQ+kV2pRduVIdxzkvIPoFSOBs eMDg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t1si7740188plo.8.2019.08.31.09.28.06; Sat, 31 Aug 2019 09:28:39 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728451AbfHaQ1P (ORCPT + 99 others); Sat, 31 Aug 2019 12:27:15 -0400 Received: from www1102.sakura.ne.jp ([219.94.129.142]:37300 "EHLO www1102.sakura.ne.jp" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728244AbfHaQ1O (ORCPT ); Sat, 31 Aug 2019 12:27:14 -0400 Received: from fsav105.sakura.ne.jp (fsav105.sakura.ne.jp [27.133.134.232]) by www1102.sakura.ne.jp (8.15.2/8.15.2) with ESMTP id x7VGQsBM085476; Sun, 1 Sep 2019 01:26:54 +0900 (JST) (envelope-from katsuhiro@katsuster.net) Received: from www1102.sakura.ne.jp (219.94.129.142) by fsav105.sakura.ne.jp (F-Secure/fsigk_smtp/530/fsav105.sakura.ne.jp); Sun, 01 Sep 2019 01:26:54 +0900 (JST) X-Virus-Status: clean(F-Secure/fsigk_smtp/530/fsav105.sakura.ne.jp) Received: from localhost.localdomain (118.153.231.153.ap.dti.ne.jp [153.231.153.118]) (authenticated bits=0) by www1102.sakura.ne.jp (8.15.2/8.15.2) with ESMTPSA id x7VGQoru085462 (version=TLSv1.2 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Sun, 1 Sep 2019 01:26:54 +0900 (JST) (envelope-from katsuhiro@katsuster.net) From: Katsuhiro Suzuki To: Mark Brown , David Yang , Daniel Drake , Hans de Goede Cc: alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org, Katsuhiro Suzuki Subject: [PATCH v2 2/3] ASoC: es8316: Add clock control of MCLK Date: Sun, 1 Sep 2019 01:26:49 +0900 Message-Id: <20190831162650.19822-2-katsuhiro@katsuster.net> X-Mailer: git-send-email 2.23.0.rc1 In-Reply-To: <20190831162650.19822-1-katsuhiro@katsuster.net> References: <20190831162650.19822-1-katsuhiro@katsuster.net> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch introduce clock property for MCLK master freq control. Driver will set rate of MCLK master if set_sysclk is called and changing sysclk by board driver. Signed-off-by: Katsuhiro Suzuki --- Changes from v1: - Output logs if clock error is found - Disable and unprepare mclk when remove this driver --- sound/soc/codecs/es8316.c | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/sound/soc/codecs/es8316.c b/sound/soc/codecs/es8316.c index 229808fa627c..ab41f2c056bd 100644 --- a/sound/soc/codecs/es8316.c +++ b/sound/soc/codecs/es8316.c @@ -9,6 +9,7 @@ #include #include +#include #include #include #include @@ -33,6 +34,7 @@ static const unsigned int supported_mclk_lrck_ratios[] = { struct es8316_priv { struct mutex lock; + struct clk *mclk; struct regmap *regmap; struct snd_soc_component *component; struct snd_soc_jack *jack; @@ -363,12 +365,19 @@ static int es8316_set_dai_sysclk(struct snd_soc_dai *codec_dai, { struct snd_soc_component *component = codec_dai->component; struct es8316_priv *es8316 = snd_soc_component_get_drvdata(component); + int ret; es8316->sysclk = freq; if (freq == 0) return 0; + if (es8316->mclk) { + ret = clk_set_rate(es8316->mclk, freq); + if (ret) + return ret; + } + return 0; } @@ -693,9 +702,26 @@ static int es8316_set_jack(struct snd_soc_component *component, static int es8316_probe(struct snd_soc_component *component) { struct es8316_priv *es8316 = snd_soc_component_get_drvdata(component); + int ret; es8316->component = component; + es8316->mclk = devm_clk_get(component->dev, "mclk"); + if (PTR_ERR(es8316->mclk) == -EPROBE_DEFER) + return -EPROBE_DEFER; + if (IS_ERR(es8316->mclk)) { + dev_err(component->dev, "clock is invalid, ignored\n"); + es8316->mclk = NULL; + } + + if (es8316->mclk) { + ret = clk_prepare_enable(es8316->mclk); + if (ret) { + dev_err(component->dev, "unable to enable clock\n"); + return ret; + } + } + /* Reset codec and enable current state machine */ snd_soc_component_write(component, ES8316_RESET, 0x3f); usleep_range(5000, 5500); @@ -718,8 +744,17 @@ static int es8316_probe(struct snd_soc_component *component) return 0; } +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); +} + static const struct snd_soc_component_driver soc_component_dev_es8316 = { .probe = es8316_probe, + .remove = es8316_remove, .set_jack = es8316_set_jack, .controls = es8316_snd_controls, .num_controls = ARRAY_SIZE(es8316_snd_controls), -- 2.23.0.rc1