Received: by 2002:ab2:6a05:0:b0:1f8:1780:a4ed with SMTP id w5csp2513475lqo; Tue, 14 May 2024 00:24:49 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCW4JS00NNDUum0Rnpc8XuKxeHcwVOU3Y10ZlEh5mwTTWiPKA+lTlgrfuZXO4xkiMy5PHyh6apuRhMJf9uCnU0LgXxwcIvtCINAUT/1r7w== X-Google-Smtp-Source: AGHT+IH40eA2UYmwd0PqcxBHxMZC5/XLtncwX3vzz+TDQ6guGSysbcwUYk/T7BV1C2Yvw4+Gvyn6 X-Received: by 2002:ac8:7f51:0:b0:439:dfc7:aca4 with SMTP id d75a77b69052e-43dfdb6a4efmr155413491cf.63.1715671489458; Tue, 14 May 2024 00:24:49 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1715671489; cv=pass; d=google.com; s=arc-20160816; b=LaAXzlyfSfcAWDhjOj7Kweaj4Gis6nJdP9uky1xVHwURj+KibcEyXiLQ9zx2fzXS3v KUG8cVZZLbculeCsLusy4DMF6C6jmcTdE0kIxgwLtdAwDmmu4SkQs0p9ZBCsElz+7BiM I+GVJP6OuT9M60yD9KtVuJ9CsvNmdi+zkbuwZqGF7cK8iyv3I/7yeQUOV5R1FjZGcpAq oI9ncq7HulyRalc3Yx4H5HBTzg+lRB+Wv8XBWWnxk5R6rv8pX6XF9vt/X7zFfT5li6jh AoiiLYYOmEbyZLZa7IhNl+2KHtqp+jC3ck2DFfzIjjEwTsKjRPpSiIjqwOezHIoulbSr U2xw== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=reply-to:cc:to:in-reply-to:references:message-id :content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:subject:date:from:dkim-signature; bh=oazauDuFEMYmj6SYn9xq5ybv/gpTOe2n3C/kiXV808w=; fh=LhdatDguh+IuN1lDyS6rzhx9ubttSYYZpDCGFgekH1E=; b=K2chjO9mNUUnmdsCgzHW9ux8bwifR/H6gG2NxWQ8DktqCLw6Te7Ti31FicrD8HkIwc XG0S7rRZjXAHWVgS7jT7J964gWRONh1h5N3ul8pHvayqXv1hN2mkZ2WSt4hmg9/TMtYM jJdGvk1MjEri2I3U2VBzRlROh7mgZEZ7sSvzwSRYzKLO9ETCGbn5QMm9b75BsLSsjByF mhTB5O/5JCFWh3yNWy6cH4DiamkG1+SlBQtH1RjDmKZYsUW0gBI3KbALybjWyvtzFL0P qnq1oczqCt9HX+1dVT9nF5kELxaqGS2MG2Dff/+zD6K8ak19ETM2b+3T7FMxnemovRzV Vk9w==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=ALJlMiA1; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-178382-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-178382-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id d75a77b69052e-43df54b55e8si112393881cf.218.2024.05.14.00.24.49 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 May 2024 00:24:49 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-178382-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=ALJlMiA1; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-178382-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-178382-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 0151B1C20CAD for ; Tue, 14 May 2024 07:24:49 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 1F7ED374F1; Tue, 14 May 2024 07:23:20 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="ALJlMiA1" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id F2F18210E6; Tue, 14 May 2024 07:23:18 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1715671399; cv=none; b=h/ka+C+xYIIMmtEg5vJNMHnvml5FOcnd5T0lwyfiKO5eTIaWN8q3iAedOGiu8VN+liiTAAK2xqE+EFSOtfbR2SdAXJu1fQrTzhcmDSkzrzFmBUpe7Tv6HdqoSPtDr3hMJRtfyEE79HTCDMkkBN0BbarSQbjhfDiLeRfbXWNnpQ8= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1715671399; c=relaxed/simple; bh=QgIvzdD8Redb/g03BsHqPcR78rBBA7ClGH+HoxeS/Dg=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=JwmCoq12G+fL2GVvHKDOs6Eg3YtDA0HN28yg3lIHaKdFY/tEgmZhIFeZn+MLwqYpZC4VhOkwAACRmWBYeDHbY12OJmGQhOK1bHcCb26sLMQtFe91/evahELPe6luRMUfUG3hemNUaQ0IU49XSRSGkCDi+SH2IT3nuG7jttHgrrs= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=ALJlMiA1; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPS id 6DFD7C4AF0F; Tue, 14 May 2024 07:23:18 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1715671398; bh=QgIvzdD8Redb/g03BsHqPcR78rBBA7ClGH+HoxeS/Dg=; h=From:Date:Subject:References:In-Reply-To:To:Cc:Reply-To:From; b=ALJlMiA1q5oa09QIICSiSO2d1qUqP6TK1a/c46dqFFZjbD9q698w2ON+fqNf2lOrm RRNy7pRwDEMUQEKew2KOFHRf0fklHZ2ji9SIxFcMyHph6gJmss9g4Dwo45iD5IygDE c00qpd1jWtKGPxyAc5bO8mI2VGfKKEB9gKtZjrFgOQyZEFSM6n24Ksg0KQlLzDb6pX tB5r/+6jhyetJzrpxAW5HLq7CBwG6n+q6YGNS9s9f/E3MF9TaLH95Bf0ODKzk3gDuE ahLSNG/LRNyYtNhm3VFy4PPLJ8wd/E/jpes3k6Ujp0pabaZCnr9kW11Ifm2aVSubwE zQviyUN6zwCFQ== Received: from aws-us-west-2-korg-lkml-1.web.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.lore.kernel.org (Postfix) with ESMTP id 56C05C25B75; Tue, 14 May 2024 07:23:18 +0000 (UTC) From: Dumitru Ceclan via B4 Relay Date: Tue, 14 May 2024 10:22:49 +0300 Subject: [PATCH v2 4/9] iio: adc: ad7173: refactor ain and vref selection Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Message-Id: <20240514-ad4111-v2-4-29be6a55efb5@analog.com> References: <20240514-ad4111-v2-0-29be6a55efb5@analog.com> In-Reply-To: <20240514-ad4111-v2-0-29be6a55efb5@analog.com> To: Ceclan Dumitru Cc: Lars-Peter Clausen , Michael Hennerich , Jonathan Cameron , Rob Herring , Krzysztof Kozlowski , Conor Dooley , David Lechner , linux-iio@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Dumitru Ceclan X-Mailer: b4 0.12.4 X-Developer-Signature: v=1; a=ed25519-sha256; t=1715671396; l=3227; i=dumitru.ceclan@analog.com; s=20240313; h=from:subject:message-id; bh=BQKfZH7Fc3eGJEHjq+owi/bXwaFMUL02xOWUE48nKU8=; b=6pEGQM18sxhf9W3j23sX7tZRn6Za14nZzHf/npskDYpEgNGYpCTiRG0STBqIgcNE1xw4kEnrL tUOdWD6/uf3DTJprHneYWtT66e7RSfgFpIdJyeWdfqSIsSExYyfyH4i X-Developer-Key: i=dumitru.ceclan@analog.com; a=ed25519; pk=HdqMlVyrcazwoiai7oN6ghU+Bj1pusGUFRl30jhS7Bo= X-Endpoint-Received: by B4 Relay for dumitru.ceclan@analog.com/20240313 with auth_id=140 X-Original-From: Dumitru Ceclan Reply-To: dumitru.ceclan@analog.com From: Dumitru Ceclan Move validation of analog inputs and reference voltage selection to separate functions to reduce the size of the channel config parsing function and improve readability. Signed-off-by: Dumitru Ceclan --- drivers/iio/adc/ad7173.c | 62 ++++++++++++++++++++++++++++++++++-------------- 1 file changed, 44 insertions(+), 18 deletions(-) diff --git a/drivers/iio/adc/ad7173.c b/drivers/iio/adc/ad7173.c index d5ad3f01dec7..fb33534d63a9 100644 --- a/drivers/iio/adc/ad7173.c +++ b/drivers/iio/adc/ad7173.c @@ -911,6 +911,44 @@ static int ad7173_register_clk_provider(struct iio_dev *indio_dev) &st->int_clk_hw); } +static int ad7173_validate_voltage_ain_inputs(struct ad7173_state *st, + unsigned int ain[2]) +{ + struct device *dev = &st->sd.spi->dev; + + for (int i = 0; i < 2; i++) { + if (ain[i] < st->info->num_inputs) + continue; + + return dev_err_probe(dev, -EINVAL, + "Input pin number out of range for pair (%d %d).\n", + ain[0], ain[1]); + } + + return 0; +} + +static int ad7173_validate_reference(struct ad7173_state *st, int ref_sel) +{ + struct device *dev = &st->sd.spi->dev; + int ret; + + if (ref_sel == AD7173_SETUP_REF_SEL_INT_REF && !st->info->has_int_ref) + return dev_err_probe(dev, -EINVAL, + "Internal reference is not available on current model.\n"); + + if (ref_sel == AD7173_SETUP_REF_SEL_EXT_REF2 && !st->info->has_ref2) + return dev_err_probe(dev, -EINVAL, + "External reference 2 is not available on current model.\n"); + + ret = ad7173_get_ref_voltage_milli(st, ref_sel); + if (ret < 0) + return dev_err_probe(dev, ret, "Cannot use reference %u\n", + ref_sel); + + return 0; +} + static int ad7173_fw_parse_channel_config(struct iio_dev *indio_dev) { struct ad7173_channel *chans_st_arr, *chan_st_priv; @@ -971,11 +1009,9 @@ static int ad7173_fw_parse_channel_config(struct iio_dev *indio_dev) if (ret) return ret; - if (ain[0] >= st->info->num_inputs || - ain[1] >= st->info->num_inputs) - return dev_err_probe(dev, -EINVAL, - "Input pin number out of range for pair (%d %d).\n", - ain[0], ain[1]); + ret = ad7173_validate_voltage_ain_inputs(st, ain); + if (ret) + return ret; ret = fwnode_property_match_property_string(child, "adi,reference-select", @@ -986,19 +1022,9 @@ static int ad7173_fw_parse_channel_config(struct iio_dev *indio_dev) else ref_sel = ret; - if (ref_sel == AD7173_SETUP_REF_SEL_INT_REF && - !st->info->has_int_ref) - return dev_err_probe(dev, -EINVAL, - "Internal reference is not available on current model.\n"); - - if (ref_sel == AD7173_SETUP_REF_SEL_EXT_REF2 && !st->info->has_ref2) - return dev_err_probe(dev, -EINVAL, - "External reference 2 is not available on current model.\n"); - - ret = ad7173_get_ref_voltage_milli(st, ref_sel); - if (ret < 0) - return dev_err_probe(dev, ret, - "Cannot use reference %u\n", ref_sel); + ret = ad7173_validate_reference(st, ref_sel); + if (ret) + return ret; if (ref_sel == AD7173_SETUP_REF_SEL_INT_REF) st->adc_mode |= AD7173_ADC_MODE_REF_EN; -- 2.43.0