Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp1787533ybl; Sat, 25 Jan 2020 08:30:28 -0800 (PST) X-Google-Smtp-Source: APXvYqwXeto5/gedBJFGTF4JeSf3FcH/kXuDMbrlosuX0+6vDD/2lhrsnE/49luZ++kRoA0Yq3VQ X-Received: by 2002:a9d:7852:: with SMTP id c18mr6404772otm.247.1579969828658; Sat, 25 Jan 2020 08:30:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579969828; cv=none; d=google.com; s=arc-20160816; b=SrEXJlSE4xL+IMhGT30sMAAb6fGUQytIHkU8irRGYpWcfWD/oCX8KSmSV+E84Nn6AF 2UHtYPTevtmia3OfvYyO9qZ4Y6ON+gruLRVZhClhN5gDUAF1IR2tZ7V/M16d7MJyrflL X5nZ5JOiglbN9i+ts40S84AeV7XcJ9zBsdrwc+/MLNpBMSdQnFOyTojRj39Tx8/WQKzl Ob6HpZu+fZ8mqlPV7farrnNWRdS0e1GZeZlofjOe4w7P0i9JVsYyMumt2CSbdCE7XTOG h044eYZqybpLa8cd1Y7P6/xLSlftNs7oJ2qL1F4il3qmuYRqX0t3fEx9efvBRtez9lTS APdw== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=fXSQKIL0dD1lYRTOFFY91TxyyI+2c+Y8mAqJiNtHVic=; b=MMgceQsf0ST56X1f5eKZ4fXnHGco9OUAF+jDlIVk1v7e/VT6Ec9TfGlui4Y/HYmMHg ORv/EyEKr0FDKwwfvZlvvf+nZSJoiB1DkM8tM4WrJPoDfR3+4iyy6TMJ6ATy0AHZaUhf urGKP5c/iXAEO7N9VKDcxeZtMnRc++RR3D/Xi8kfGIDCjubG57eI/0ZvIMiVrLs3b9Hb Fc0Yz3LvC+tZ16mcTylX9UNclyppUgNEvD+6YQGxu9odsFEqcnR3NQD9I/eP9/jkdsVK 1ZuvdThh1+oGbt+4Nuw19VW3E4FaLc6/KUxeYB29xtYXitZvSmPRmS2IHPtxH48KDatY e3KQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=JvpSxx+9; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w5si4732240otq.238.2020.01.25.08.30.16; Sat, 25 Jan 2020 08:30:28 -0800 (PST) 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; dkim=pass header.i=@chromium.org header.s=google header.b=JvpSxx+9; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726294AbgAYQ3Z (ORCPT + 99 others); Sat, 25 Jan 2020 11:29:25 -0500 Received: from mail-pj1-f68.google.com ([209.85.216.68]:56024 "EHLO mail-pj1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725710AbgAYQ3Z (ORCPT ); Sat, 25 Jan 2020 11:29:25 -0500 Received: by mail-pj1-f68.google.com with SMTP id d5so1179920pjz.5 for ; Sat, 25 Jan 2020 08:29:25 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=fXSQKIL0dD1lYRTOFFY91TxyyI+2c+Y8mAqJiNtHVic=; b=JvpSxx+9/xqNSJz/0zgTcvMvolZtJ36685E1qTXtSngk3q8URPaOJgMbUK4wc4RefI 42SkhywCIKUxSg74BRA6M+NjdT2S+rX5U/ET8beCzYf1XQ/Qw8057ridYk+PUMH0OsLy a7+NqmjzrpXp0ZjeLSEhXBcyHxBxhmfEsiBQc= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=fXSQKIL0dD1lYRTOFFY91TxyyI+2c+Y8mAqJiNtHVic=; b=DDBSTWiFyGxI+0tbwnLCvbx42tOoVlmpdGsDx2+1JC2DznzwDhWa5Bcq8UPAeDaHx/ aGuu3tSuqd/wVIInyJuKzYRzuzHfZa6JYo9Si4fBeZzJxoM7mGtbAIp36OIteZkGGjIs eE54d12Cv88LXjv3VxaCDquoEu8+PtmhzvejPo+lPrgqQjD22UfKBZs7zv0i6gLHPnGr 4HZPhggbT871Vvsn1QvExKCbdIftMUzran0kNct4B5kmzPrR1zD/lh1ANPs27IMsjEZF fpfl0z02DaUWZoMVLyQ/2xGCXMBlJaxbuOr4uyqDyopXrXyRQeUuIAf1QYNaiGTuMxhN +U1A== X-Gm-Message-State: APjAAAVuXfcFy83d4i0+gDqc6UxJt0GRRh2a615I8v8ZgXSzwANyPg3/ NRd+6N+15iuPqZhslsxrIKutOln3LYE= X-Received: by 2002:a17:902:b107:: with SMTP id q7mr1935912plr.343.1579969764135; Sat, 25 Jan 2020 08:29:24 -0800 (PST) Received: from localhost ([2401:fa00:1:10:845f:e35d:e30c:4b47]) by smtp.gmail.com with ESMTPSA id r20sm10487339pgu.89.2020.01.25.08.29.21 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Sat, 25 Jan 2020 08:29:23 -0800 (PST) From: Yu-Hsuan Hsu To: linux-kernel@vger.kernel.org Cc: Cheng-Yi Chiang , Tzung-Bi Shih , Enric Balletbo i Serra , Guenter Roeck , Liam Girdwood , Mark Brown , Jaroslav Kysela , Takashi Iwai , Benson Leung , Yu-Hsuan Hsu , alsa-devel@alsa-project.org Subject: [PATCH v2] ASoC: cros_ec_codec: Support setting bclk ratio Date: Sun, 26 Jan 2020 00:29:17 +0800 Message-Id: <20200125162917.247485-1-yuhsuan@chromium.org> X-Mailer: git-send-email 2.25.0.341.g760bfbb309-goog 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 Support setting bclk ratio from machine drivers. Signed-off-by: Yu-Hsuan Hsu --- sound/soc/codecs/cros_ec_codec.c | 25 ++++++++++++++++++++++--- 1 file changed, 22 insertions(+), 3 deletions(-) diff --git a/sound/soc/codecs/cros_ec_codec.c b/sound/soc/codecs/cros_ec_codec.c index 6a24f570c5e86f..d3dc42aa682565 100644 --- a/sound/soc/codecs/cros_ec_codec.c +++ b/sound/soc/codecs/cros_ec_codec.c @@ -45,6 +45,9 @@ struct cros_ec_codec_priv { /* DMIC */ atomic_t dmic_probed; + /* I2S_RX */ + uint32_t i2s_rx_bclk_ratio; + /* WoV */ bool wov_enabled; uint8_t *wov_audio_shm_p; @@ -259,6 +262,7 @@ static int i2s_rx_hw_params(struct snd_pcm_substream *substream, snd_soc_component_get_drvdata(component); struct ec_param_ec_codec_i2s_rx p; enum ec_codec_i2s_rx_sample_depth depth; + uint32_t bclk; int ret; if (params_rate(params) != 48000) @@ -284,15 +288,29 @@ static int i2s_rx_hw_params(struct snd_pcm_substream *substream, if (ret < 0) return ret; - dev_dbg(component->dev, "set bclk to %u\n", - snd_soc_params_to_bclk(params)); + if (priv->i2s_rx_bclk_ratio) + bclk = params_rate(params) * priv->i2s_rx_bclk_ratio; + else + bclk = snd_soc_params_to_bclk(params); + + dev_dbg(component->dev, "set bclk to %u\n", bclk); p.cmd = EC_CODEC_I2S_RX_SET_BCLK; - p.set_bclk_param.bclk = snd_soc_params_to_bclk(params); + p.set_bclk_param.bclk = bclk; return send_ec_host_command(priv->ec_device, EC_CMD_EC_CODEC_I2S_RX, (uint8_t *)&p, sizeof(p), NULL, 0); } +static int i2s_rx_set_bclk_ratio(struct snd_soc_dai *dai, unsigned int ratio) +{ + struct snd_soc_component *component = dai->component; + struct cros_ec_codec_priv *priv = + snd_soc_component_get_drvdata(component); + + priv->i2s_rx_bclk_ratio = ratio; + return 0; +} + static int i2s_rx_set_fmt(struct snd_soc_dai *dai, unsigned int fmt) { struct snd_soc_component *component = dai->component; @@ -340,6 +358,7 @@ static int i2s_rx_set_fmt(struct snd_soc_dai *dai, unsigned int fmt) static const struct snd_soc_dai_ops i2s_rx_dai_ops = { .hw_params = i2s_rx_hw_params, .set_fmt = i2s_rx_set_fmt, + .set_bclk_ratio = i2s_rx_set_bclk_ratio, }; static int i2s_rx_event(struct snd_soc_dapm_widget *w, -- 2.25.0.341.g760bfbb309-goog