From patchwork Wed Mar 31 07:44:45 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shengjiu Wang X-Patchwork-Id: 412836 Delivered-To: patch@linaro.org Received: by 2002:a02:8562:0:0:0:0:0 with SMTP id g89csp281933jai; Wed, 31 Mar 2021 00:59:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxSAjq9RmkRIPYVgN9QHAOYwCuDfHnrdRui1fHP4jRuPJlovl82ZMQ45OBF1kMLUyCxz6xG X-Received: by 2002:a05:6402:3550:: with SMTP id f16mr2139172edd.134.1617177588039; Wed, 31 Mar 2021 00:59:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617177588; cv=none; d=google.com; s=arc-20160816; b=ay0LMUOvHezo6c0qzEQp/loBepbICYSMs6hnrosmSjVhgW4SiGYReBgEdZIMCwh8N9 5hmMWB7qhOyJndkCQa8Ckx3ZXwj13fuAJGGX0UbfyYDY1xsvyaK6jWV2K71sL+rr2a7O Uu0kCBK59iaO9GtPEGIrMTIVlCoZdN/hU7iVhUZIzg1myS+FEw7DGXhar9ITMtmVByGP hDrx5AIxQ8+yOo432X14JJv09dsCQTAJ7q6tBNzeyLx+NHvS2DpPnHL6ynzsLkf5+OF7 lQyLa5FNZluRPB6xYE0BZYhOsvyePFQ6eGooKgDYSrrbqt6l1BvKCk+njieEHyMzqg0u 61AA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:to:from; bh=yw0A++uEWOT44M9P3Xeh3jvNos6AOWDjjjjeeiaGLz0=; b=R/Rahx+z8jl2CRUicTXCq92WLRotnvw7ee7UB/+wPeqsxO6goRJSp9rt7K6wo2+6Ve inByXiPY9ZM8mZ4CDrLaZ3DO5qDzd4JL5qN9IcqFlofhNZS9Q352Iax3gC+OJf/VcRZP ch73j88NHEV3ovg45xdLsMllXInKq95pEjrG+OA6vHJkqmJ42mDhmLPl6ypZv9EPfnoq FLmlB4uFewy54jKl6ZZWFntEmvPWV4CDIHNGPRFLi8VnyARMIIsMXKNPesw/hN1k+sVA koZ/z8HAKql/mzH38MY7T++ZjUd+077Bn34ZIe2hOpFi7d3NUEghWqm8bebH9GAAunr+ CthA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of devicetree-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ca25si1202061edb.204.2021.03.31.00.59.47; Wed, 31 Mar 2021 00:59:48 -0700 (PDT) Received-SPF: pass (google.com: domain of devicetree-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of devicetree-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234228AbhCaH7Q (ORCPT + 6 others); Wed, 31 Mar 2021 03:59:16 -0400 Received: from inva021.nxp.com ([92.121.34.21]:59190 "EHLO inva021.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234106AbhCaH6v (ORCPT ); Wed, 31 Mar 2021 03:58:51 -0400 Received: from inva021.nxp.com (localhost [127.0.0.1]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id D14442002AC; Wed, 31 Mar 2021 09:58:49 +0200 (CEST) Received: from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com [165.114.16.14]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id 51CA92002C7; Wed, 31 Mar 2021 09:58:46 +0200 (CEST) Received: from localhost.localdomain (shlinux2.ap.freescale.net [10.192.224.44]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id D5FAF402F1; Wed, 31 Mar 2021 09:58:41 +0200 (CEST) From: Shengjiu Wang To: lgirdwood@gmail.com, broonie@kernel.org, perex@perex.cz, tiwai@suse.com, alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org, robh+dt@kernel.org, devicetree@vger.kernel.org Subject: [PATCH v2 1/2] ASoC: ak5558: Add support for ak5552 Date: Wed, 31 Mar 2021 15:44:45 +0800 Message-Id: <1617176686-25528-1-git-send-email-shengjiu.wang@nxp.com> X-Mailer: git-send-email 2.7.4 X-Virus-Scanned: ClamAV using ClamSMTP Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org From: Viorel Suman AK5552 is a 32-bit 2ch ADC and has the same register map as AK5558. Signed-off-by: Viorel Suman Signed-off-by: Shengjiu Wang --- changes in v2 - refine the control name. sound/soc/codecs/ak5558.c | 97 ++++++++++++++++++++++++++++++++++++--- 1 file changed, 90 insertions(+), 7 deletions(-) -- 2.27.0 diff --git a/sound/soc/codecs/ak5558.c b/sound/soc/codecs/ak5558.c index 85bdd0534180..3ac62a281807 100644 --- a/sound/soc/codecs/ak5558.c +++ b/sound/soc/codecs/ak5558.c @@ -9,6 +9,7 @@ #include #include #include +#include #include #include #include @@ -23,6 +24,11 @@ #include "ak5558.h" +enum ak555x_type { + AK5558, + AK5552, +}; + #define AK5558_NUM_SUPPLIES 2 static const char *ak5558_supply_names[AK5558_NUM_SUPPLIES] = { "DVDD", @@ -59,6 +65,15 @@ static const struct soc_enum ak5558_mono_enum[] = { ARRAY_SIZE(mono_texts), mono_texts), }; +static const char * const mono_5552_texts[] = { + "2 Slot", "1 Slot (Fixed)", "2 Slot", "1 Slot (Optimal)", +}; + +static const struct soc_enum ak5552_mono_enum[] = { + SOC_ENUM_SINGLE(AK5558_01_POWER_MANAGEMENT2, 1, + ARRAY_SIZE(mono_5552_texts), mono_5552_texts), +}; + static const char * const digfil_texts[] = { "Sharp Roll-Off", "Show Roll-Off", "Short Delay Sharp Roll-Off", "Short Delay Show Roll-Off", @@ -70,8 +85,13 @@ static const struct soc_enum ak5558_adcset_enum[] = { }; static const struct snd_kcontrol_new ak5558_snd_controls[] = { - SOC_ENUM("AK5558 Monaural Mode", ak5558_mono_enum[0]), - SOC_ENUM("AK5558 Digital Filter", ak5558_adcset_enum[0]), + SOC_ENUM("Monaural Mode", ak5558_mono_enum[0]), + SOC_ENUM("Digital Filter", ak5558_adcset_enum[0]), +}; + +static const struct snd_kcontrol_new ak5552_snd_controls[] = { + SOC_ENUM("Monaural Mode", ak5552_mono_enum[0]), + SOC_ENUM("Digital Filter", ak5558_adcset_enum[0]), }; static const struct snd_soc_dapm_widget ak5558_dapm_widgets[] = { @@ -97,6 +117,17 @@ static const struct snd_soc_dapm_widget ak5558_dapm_widgets[] = { SND_SOC_DAPM_AIF_OUT("SDTO", "Capture", 0, SND_SOC_NOPM, 0, 0), }; +static const struct snd_soc_dapm_widget ak5552_dapm_widgets[] = { + /* Analog Input */ + SND_SOC_DAPM_INPUT("AIN1"), + SND_SOC_DAPM_INPUT("AIN2"), + + SND_SOC_DAPM_ADC("ADC Ch1", NULL, AK5558_00_POWER_MANAGEMENT1, 0, 0), + SND_SOC_DAPM_ADC("ADC Ch2", NULL, AK5558_00_POWER_MANAGEMENT1, 1, 0), + + SND_SOC_DAPM_AIF_OUT("SDTO", "Capture", 0, SND_SOC_NOPM, 0, 0), +}; + static const struct snd_soc_dapm_route ak5558_intercon[] = { {"ADC Ch1", NULL, "AIN1"}, {"SDTO", NULL, "ADC Ch1"}, @@ -123,6 +154,14 @@ static const struct snd_soc_dapm_route ak5558_intercon[] = { {"SDTO", NULL, "ADC Ch8"}, }; +static const struct snd_soc_dapm_route ak5552_intercon[] = { + {"ADC Ch1", NULL, "AIN1"}, + {"SDTO", NULL, "ADC Ch1"}, + + {"ADC Ch2", NULL, "AIN2"}, + {"SDTO", NULL, "ADC Ch2"}, +}; + static int ak5558_set_mcki(struct snd_soc_component *component) { return snd_soc_component_update_bits(component, AK5558_02_CONTROL1, AK5558_CKS, @@ -267,6 +306,18 @@ static struct snd_soc_dai_driver ak5558_dai = { .ops = &ak5558_dai_ops, }; +static struct snd_soc_dai_driver ak5552_dai = { + .name = "ak5558-aif", + .capture = { + .stream_name = "Capture", + .channels_min = 1, + .channels_max = 2, + .rates = SNDRV_PCM_RATE_KNOT, + .formats = AK5558_FORMATS, + }, + .ops = &ak5558_dai_ops, +}; + static void ak5558_power_off(struct ak5558_priv *ak5558) { if (!ak5558->reset_gpiod) @@ -354,6 +405,21 @@ static const struct snd_soc_component_driver soc_codec_dev_ak5558 = { .non_legacy_dai_naming = 1, }; +static const struct snd_soc_component_driver soc_codec_dev_ak5552 = { + .probe = ak5558_probe, + .remove = ak5558_remove, + .controls = ak5552_snd_controls, + .num_controls = ARRAY_SIZE(ak5552_snd_controls), + .dapm_widgets = ak5552_dapm_widgets, + .num_dapm_widgets = ARRAY_SIZE(ak5552_dapm_widgets), + .dapm_routes = ak5552_intercon, + .num_dapm_routes = ARRAY_SIZE(ak5552_intercon), + .idle_bias_on = 1, + .use_pmdown_time = 1, + .endianness = 1, + .non_legacy_dai_naming = 1, +}; + static const struct regmap_config ak5558_regmap = { .reg_bits = 8, .val_bits = 8, @@ -368,6 +434,7 @@ static int ak5558_i2c_probe(struct i2c_client *i2c) { struct ak5558_priv *ak5558; int ret = 0; + int dev_id; int i; ak5558 = devm_kzalloc(&i2c->dev, sizeof(*ak5558), GFP_KERNEL); @@ -396,11 +463,26 @@ static int ak5558_i2c_probe(struct i2c_client *i2c) return ret; } - ret = devm_snd_soc_register_component(&i2c->dev, - &soc_codec_dev_ak5558, - &ak5558_dai, 1); - if (ret) + dev_id = (uintptr_t)of_device_get_match_data(&i2c->dev); + switch (dev_id) { + case AK5552: + ret = devm_snd_soc_register_component(&i2c->dev, + &soc_codec_dev_ak5552, + &ak5552_dai, 1); + break; + case AK5558: + ret = devm_snd_soc_register_component(&i2c->dev, + &soc_codec_dev_ak5558, + &ak5558_dai, 1); + break; + default: + dev_err(&i2c->dev, "unexpected device type\n"); + return -EINVAL; + } + if (ret < 0) { + dev_err(&i2c->dev, "failed to register component: %d\n", ret); return ret; + } pm_runtime_enable(&i2c->dev); regcache_cache_only(ak5558->regmap, true); @@ -416,7 +498,8 @@ static int ak5558_i2c_remove(struct i2c_client *i2c) } static const struct of_device_id ak5558_i2c_dt_ids[] __maybe_unused = { - { .compatible = "asahi-kasei,ak5558"}, + { .compatible = "asahi-kasei,ak5558", .data = (void *) AK5558 }, + { .compatible = "asahi-kasei,ak5552", .data = (void *) AK5552 }, { } }; MODULE_DEVICE_TABLE(of, ak5558_i2c_dt_ids); From patchwork Wed Mar 31 07:44:46 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shengjiu Wang X-Patchwork-Id: 412837 Delivered-To: patch@linaro.org Received: by 2002:a02:8562:0:0:0:0:0 with SMTP id g89csp281982jai; Wed, 31 Mar 2021 00:59:52 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx9YrOxV+YXqZx4j1bt6I6YSr14XmdjZHbM9BFFgGtLMO6z+Ly5pUevyU6brDpu5gNJDXUP X-Received: by 2002:a17:907:3353:: with SMTP id yr19mr2230279ejb.8.1617177592046; Wed, 31 Mar 2021 00:59:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617177592; cv=none; d=google.com; s=arc-20160816; b=jOVHGEt+Pmq1VNDjX4ehn8DsfOtgPaJ2dlULXyEEGliSZiyAScIWhKdzze+OJiEtxV zId7ppthuPti3EER74qf1i413QWqHwEThuxllqVo6bSu5PIsbNWAJ+6I9qyr/c+atR1S 94eOfbKyYKtxQiXw/0YAdBQ6/ubZ86stfjpnJ69Js9TILjgZ9o2aT33++cCfy+8jUwA+ iKmYEqgUqth8VPvhVIFr2PRitggZ1vaKRulYEph3MIV6/oFzts2Af4UfsTEHztvI/dPq sp0Jay06Sa0UoywlclgXnVPDUjLr25D6xGeipSswgnddHad7BDZxQID33rMPoMDanW/f 4law== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :to:from; bh=5Y90GTa6WjDqSTnUGiwGDNiRJ5F/ttO1bivdq6eb5AI=; b=AiQUgnGnXdc1Eks8Dw7cczAqCbgkv8AxQha5RXK7/wvmGLZFggKp3qvOegLSjMZiaT rDOOrb6TG05UM2+nMUQ1HY2gwL6HiAKi2S2hmJqFvwj1AjdtIli5YMjHZxW57s6O6Xco q06/oKmObPYdrYgje+BgMd/uGDLMN0Oujs1j5OOf57igCZHVR5bvYwKOZlGSKxGRqDra 25Dde9Jcp3TDUWi5Q0EhhmWN4NkcrmmAbUNTjy0DOPNNlP+dqtEhup/QcVrjy19qgunI q0ZcbBzIEy9jgTcErRgs2ktgMHeJR7BkJPjYAYGtuFMG/bJH/SfSmITZph6r6YYHEJ7t go/Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of devicetree-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ca25si1202061edb.204.2021.03.31.00.59.51; Wed, 31 Mar 2021 00:59:52 -0700 (PDT) Received-SPF: pass (google.com: domain of devicetree-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of devicetree-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234086AbhCaH7Q (ORCPT + 6 others); Wed, 31 Mar 2021 03:59:16 -0400 Received: from inva020.nxp.com ([92.121.34.13]:48422 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234114AbhCaH6v (ORCPT ); Wed, 31 Mar 2021 03:58:51 -0400 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 905C91A01AD; Wed, 31 Mar 2021 09:58:50 +0200 (CEST) Received: from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com [165.114.16.14]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 3A3751A1543; Wed, 31 Mar 2021 09:58:47 +0200 (CEST) Received: from localhost.localdomain (shlinux2.ap.freescale.net [10.192.224.44]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id B4D3640319; Wed, 31 Mar 2021 09:58:42 +0200 (CEST) From: Shengjiu Wang To: lgirdwood@gmail.com, broonie@kernel.org, perex@perex.cz, tiwai@suse.com, alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org, robh+dt@kernel.org, devicetree@vger.kernel.org Subject: [PATCH v2 2/2] ASoC: dt-bindings: ak5558: Add compatible string for ak5552 Date: Wed, 31 Mar 2021 15:44:46 +0800 Message-Id: <1617176686-25528-2-git-send-email-shengjiu.wang@nxp.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1617176686-25528-1-git-send-email-shengjiu.wang@nxp.com> References: <1617176686-25528-1-git-send-email-shengjiu.wang@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org Add compatible string "asahi-kasei,ak5552" for ak5552 Signed-off-by: Shengjiu Wang Acked-by: Rob Herring --- Documentation/devicetree/bindings/sound/ak5558.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) -- 2.27.0 diff --git a/Documentation/devicetree/bindings/sound/ak5558.txt b/Documentation/devicetree/bindings/sound/ak5558.txt index 36934098170c..e28708db6686 100644 --- a/Documentation/devicetree/bindings/sound/ak5558.txt +++ b/Documentation/devicetree/bindings/sound/ak5558.txt @@ -4,7 +4,7 @@ This device supports I2C mode only. Required properties: -- compatible : "asahi-kasei,ak5558" +- compatible : "asahi-kasei,ak5558" or "asahi-kasei,ak5552". - reg : The I2C address of the device. Optional properties: