Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp171838pxk; Wed, 16 Sep 2020 01:01:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyIljeyNFZldtKBDKaXKZAT3JeeTsX/Tqc3JGSOcKYosHacP2GWLp/Ul11G8JLPMy60V2rY X-Received: by 2002:a17:906:a4e:: with SMTP id x14mr23784446ejf.112.1600243273408; Wed, 16 Sep 2020 01:01:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600243273; cv=none; d=google.com; s=arc-20160816; b=flPc7sI+Vliv92c2bVIQLirHScpWADVyS/+iAfVqXgdqLx4kuIB4KVJXQL8duurSNH sD10hS0TrawmUwCCUYYtdHlFHeOBfgTcXMZlao0px76EPqLRGX6jfcBJ0dluTOZSlSmL e22kYl8LUP9qBDAPmAbk4uKPaeUpH9gtKvgJW4IrZZf8Lgh+8RIz7H2Rbz43ULMlumMr WCCpgErOcHpa5Rm5SdXWsA7UpbAnDrhL+4eb7u4ZRNNe1dKc2y2gAUGc32cIP4awEdpA Ln5hf1FhlcjX36k87IxDUpk780lk34Rfeuo1KNMQOmOtpIrFK9JsMurL8J0jEM1EAKxT VwYw== 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 :ironport-sdr:dkim-signature; bh=+Bee2oDYV5ypb/Wdn/uiK1X779bbbI4wm+9E+eFG2P4=; b=chQ9cGfjiBDbUBB0Pqw6y5ECUwJBRXDpYBdMkCZmN0EGlGaH9A8qh2ceeNzc+nMOJK VPvy2XALOfZZX71h4sgdaX5iHfW3xGKpBZtxgZTIUmG1ttex3a7OwrkKnrMjw0Va4fDJ wQbDdI0jSsQr4ofSBNMS8rboTiI3vYlNXwUKk2msRcqAjkpC+x0o1WT56uqWTI4/WJEp NOGdhFCfIXtZKj2H/x69Ljgvpq6owb1G36gYV3n8F7p1CKFkjbxfP4XC0rosrGl4meME aNAKJFrX1xLkAePdYxL4cx8/CzD3QvVCvVfwla3QOB+3nB2+xP8cCk3LZKili7CzlJYp btFA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@axis.com header.s=axis-central1 header.b=XQF7lgxI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=axis.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i12si10770390ejk.740.2020.09.16.01.00.50; Wed, 16 Sep 2020 01:01:13 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@axis.com header.s=axis-central1 header.b=XQF7lgxI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=axis.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726541AbgIPIAD (ORCPT + 99 others); Wed, 16 Sep 2020 04:00:03 -0400 Received: from smtp1.axis.com ([195.60.68.17]:44530 "EHLO smtp1.axis.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726369AbgIPH75 (ORCPT ); Wed, 16 Sep 2020 03:59:57 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=axis.com; l=2719; q=dns/txt; s=axis-central1; t=1600243197; x=1631779197; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=+Bee2oDYV5ypb/Wdn/uiK1X779bbbI4wm+9E+eFG2P4=; b=XQF7lgxI9TZSKhzBooFkQVtnbzReFFK+suC24sUxID740fqtANbYlxeN zuYJYBiDIoFAyGar/YsvuNwXAZY4Oc66DfIxFG0zYKvw/5PG27mU/Yh1q 7gGcBZS6vTTACnMHN19xasO9YQTj49cysqS51bQmUyhcw/tVj7Wz9YtMI KEiqOVnjEgIgRHXFvS+WbSgn4WkSEnEBnX/cVQJ0It7n6yBCjDDLIaQNP yI+4Gcd4w8UXzvwDpAu0Uz12YZPng0SiIR4I0Y4rkruYtx6dqy3IuKbcF 5yQ3REmWyOyHFznm2QYDotsiNx+/QzpgnuLYiKg0Gp0jFGmeZyv7qHRNH g==; IronPort-SDR: G4MZK7x65pmT/cNZCF+JKxe8wY0W522UpF9odulQr4TM0Y70oo98Jc/eVjPJS9NiG0buT9juFx kkYGXIvYdGmxyPdw9G7dHxCVA97/PQTZzvzDnzSeofNxNmz8BWDHdNyIVSJVuKkHiNlaTBvFuY wbamjoRakn2lJuIE1vutaI3DBdtChFLIEqhtR9FeqF73F7nuiSPycrrwHCLGOsGOlZvhLw9Dih grVSYZBTqn62PuplOE/E+jiJqdPx3p7DJ6UXXnb4MLJjHkRyRz6Mct6Ncp6GPKMNJUvYSoBgFj Vg4= X-IronPort-AV: E=Sophos;i="5.76,432,1592863200"; d="scan'208";a="12999945" From: Camel Guo To: , , , , , CC: , , , Camel Guo Subject: [PATCH v3 2/2] ASoC: tlv320adcx140: Add support for configuring GPIO pin Date: Wed, 16 Sep 2020 09:59:49 +0200 Message-ID: <20200916075949.28479-2-camel.guo@axis.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200916075949.28479-1-camel.guo@axis.com> References: <20200916075949.28479-1-camel.guo@axis.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Camel Guo Add support to configure the GPIO pin to the specific configuration. The GPIO pin can be configured as GPO, IRQ, SDOUT2, PDMCLK, MICBASE_EN, GPI, MCLK, SDIN, PDMDIN1, PDMDIN2, PDMDIN3 or PDMDIN4 and the output drive can be configured with various configuration. Signed-off-by: Camel Guo --- v3: - Add ADCX140_NUM_GPIO_CFGS avoiding using magic number - Remove unneeded check on ret in adcx140_configure_gpio sound/soc/codecs/tlv320adcx140.c | 40 ++++++++++++++++++++++++++++++++ sound/soc/codecs/tlv320adcx140.h | 5 ++++ 2 files changed, 45 insertions(+) diff --git a/sound/soc/codecs/tlv320adcx140.c b/sound/soc/codecs/tlv320adcx140.c index f33ee604ee78..fe6fc6df66cc 100644 --- a/sound/soc/codecs/tlv320adcx140.c +++ b/sound/soc/codecs/tlv320adcx140.c @@ -837,6 +837,42 @@ static int adcx140_configure_gpo(struct adcx140_priv *adcx140) } +static int adcx140_configure_gpio(struct adcx140_priv *adcx140) +{ + int gpio_count = 0; + u32 gpio_outputs[ADCX140_NUM_GPIO_CFGS]; + u32 gpio_output_val = 0; + int ret; + + gpio_count = device_property_count_u32(adcx140->dev, + "ti,gpio-config"); + if (gpio_count == 0) + return 0; + + if (gpio_count != ADCX140_NUM_GPIO_CFGS) + return -EINVAL; + + ret = device_property_read_u32_array(adcx140->dev, "ti,gpio-config", + gpio_outputs, gpio_count); + if (ret) + return ret; + + if (gpio_outputs[0] > ADCX140_GPIO_CFG_MAX) { + dev_err(adcx140->dev, "GPIO config out of range\n"); + return -EINVAL; + } + + if (gpio_outputs[1] > ADCX140_GPIO_DRV_MAX) { + dev_err(adcx140->dev, "GPIO drive out of range\n"); + return -EINVAL; + } + + gpio_output_val = gpio_outputs[0] << ADCX140_GPIO_SHIFT + | gpio_outputs[1]; + + return regmap_write(adcx140->regmap, ADCX140_GPIO_CFG0, gpio_output_val); +} + static int adcx140_codec_probe(struct snd_soc_component *component) { struct adcx140_priv *adcx140 = snd_soc_component_get_drvdata(component); @@ -934,6 +970,10 @@ static int adcx140_codec_probe(struct snd_soc_component *component) return ret; } + ret = adcx140_configure_gpio(adcx140); + if (ret) + return ret; + ret = adcx140_configure_gpo(adcx140); if (ret) goto out; diff --git a/sound/soc/codecs/tlv320adcx140.h b/sound/soc/codecs/tlv320adcx140.h index eedbc1d7221f..9d04dec374d1 100644 --- a/sound/soc/codecs/tlv320adcx140.h +++ b/sound/soc/codecs/tlv320adcx140.h @@ -145,4 +145,9 @@ #define ADCX140_GPO_CFG_MAX 4 #define ADCX140_GPO_DRV_MAX 5 +#define ADCX140_NUM_GPIO_CFGS 2 +#define ADCX140_GPIO_SHIFT 4 +#define ADCX140_GPIO_CFG_MAX 15 +#define ADCX140_GPIO_DRV_MAX 5 + #endif /* _TLV320ADCX140_ */ -- 2.20.1