Received: by 2002:a05:7412:2a8c:b0:e2:908c:2ebd with SMTP id u12csp773828rdh; Sun, 24 Sep 2023 11:05:42 -0700 (PDT) X-Google-Smtp-Source: AGHT+IH88g6EXGE396ZEwSlLPLGSHTdDfi3SmSLUnT6jWb4+yRWTnFREQoPTJQ4qo8Ov8q71CF89 X-Received: by 2002:aa7:8885:0:b0:68c:5cec:30d4 with SMTP id z5-20020aa78885000000b0068c5cec30d4mr3635806pfe.27.1695578742022; Sun, 24 Sep 2023 11:05:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695578742; cv=none; d=google.com; s=arc-20160816; b=yIw4ssoYkNo0I7l8nMIwh97S12UhKgOx3vqTHGMa7DwXBjyjE2TD+YkK5BTZUTACCd I6iudvopTMMxuGhqpTKVdpdOQP3kWVZLfwyExghsbddP6NyKtrD2VLaaeM4HtKGDjdJ9 31lEhU1RHT14NRmwMuNBRBZPB6fOQumNYG7LNlenhKrTXhMwAgdoCllZQ1hGRwXd7wg4 fi2yW85fxcW1N9KX/jSRH2DdZNWw831GW1FPnSUzW2ovhIDjYtP/Z7a9cMoDb5fPiK9d jVSlW9AXRjEOOLGuAY2NHLWkVNKBBxNe8VMCYolow6qZJLuYRFjpFBhqHrSUXWC90s8K Fqfg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :dkim-signature; bh=gCqLVruT8Q3cJkiAcN1/lVEcFi+GC/Qg4MM1U4ADQ/0=; fh=J/aQ3VQ1usFn2OiUKgsoebtsI6yr0VQFLqFjqmvpq44=; b=0WcSxxzT7sxvvYWG+xKBGF9FGfRwszbDr26f6DUYSSwKEdYeAA7ehDHOYTPGHsIvCF O/CxEa5Ifcsm7iZdkqfZgHQTQhLzTu0+pBsTI6KquCA3eQFJ2dPwvcQ1eDrSH8Cl5OAJ hy5AM0FXzhZoCIlRtmBbHwRO6BlE8E2M6vxmwzOM6gqu2xfJ1BaoVKCPbRs7d1/J4Tgy wXT2lPQgPmXD2rvgQPB1IvQ6LfGrvihTiNAn9qUIOtaN+IE2HP3bgUbb/EJBan85JxOj Q0tHdlsZmPlMVUzPrWDqlHWI4mtG28zNo7Ss/WMnOz+pdmxn5LLpalQMf7kAM9dF4afb 3RWg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=t6SeVMYY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from howler.vger.email (howler.vger.email. [23.128.96.34]) by mx.google.com with ESMTPS id g24-20020a633758000000b00574057d7c19si8679166pgn.220.2023.09.24.11.05.41 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 24 Sep 2023 11:05:41 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) client-ip=23.128.96.34; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=t6SeVMYY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by howler.vger.email (Postfix) with ESMTP id A3B11827AF90; Sun, 24 Sep 2023 11:05:40 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230147AbjIXSFo (ORCPT + 99 others); Sun, 24 Sep 2023 14:05:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46704 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229437AbjIXSFn (ORCPT ); Sun, 24 Sep 2023 14:05:43 -0400 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9B68AFA; Sun, 24 Sep 2023 11:05:37 -0700 (PDT) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 030CCC433C8; Sun, 24 Sep 2023 18:05:32 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1695578737; bh=iru/77/T+RQ94qKNjJz/efepLg+hlk3IoPzLAJ8FxpQ=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=t6SeVMYYgWxh7g8Nik0J1P1ug48IZ1oVlkA4OHK/Mo00XsWTwizEIPMMzbqvLwqtT Xip4HYeGyFMsEcFm/vHSa5eRR4mLtBPvKs44/xZ0docrnLEjwJhtsrNMuq+gwT4FaA gOdUJJ+7DFSdAM9cdxLHp5o2tqzAfvJwEFbNa5JqaZIYqjnShxkURpymuK1atWkbZL BlL4x7GSk1aO4lFWOaA0weopPmm+beK6cq4SUjNFCQM32wb4wGYqEetKZJtuC/Nu+J n9/RuTQIiNDTzD9AYQAOYcRyvIYpWyuQf8M3jvmcMhxSzV0y6iVjfztsUgTOrYmvsm 7PJi+ARK1snZQ== Date: Sun, 24 Sep 2023 19:05:29 +0100 From: Jonathan Cameron To: David Lechner Cc: linux-iio@vger.kernel.org, devicetree@vger.kernel.org, linux-staging@lists.linux.dev, linux-kernel@vger.kernel.org, Rob Herring , Krzysztof Kozlowski , Conor Dooley , Michael Hennerich , Nuno =?UTF-8?B?U8Oh?= , Axel Haslam , Philip Molloy Subject: Re: [PATCH v2 13/19] staging: iio: resolver: ad2s1210: implement hysteresis as channel attr Message-ID: <20230924190529.08411ba8@jic23-huawei> In-Reply-To: <20230921144400.62380-14-dlechner@baylibre.com> References: <20230921144400.62380-1-dlechner@baylibre.com> <20230921144400.62380-14-dlechner@baylibre.com> X-Mailer: Claws Mail 4.1.1 (GTK 3.24.38; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (howler.vger.email [0.0.0.0]); Sun, 24 Sep 2023 11:05:40 -0700 (PDT) On Thu, 21 Sep 2023 09:43:54 -0500 David Lechner wrote: > The AD2S1210 resolver has a hysteresis feature that can be used to > prevent flicker in the LSB of the position register. This can be either > enabled or disabled. Disabling hysteresis is useful for increasing > precision by oversampling. > > Signed-off-by: David Lechner I'd forgotten we even had hysteresis defined other than for events. This seems like what it was for, it's just rarely seen in hardware as trivial for software to do the same. Maybe some good uses of the new cleanup.h auto releasing of locks stuff in here. > --- > drivers/staging/iio/resolver/ad2s1210.c | 88 ++++++++++++++++++++++++- > 1 file changed, 85 insertions(+), 3 deletions(-) > > diff --git a/drivers/staging/iio/resolver/ad2s1210.c b/drivers/staging/iio/resolver/ad2s1210.c > index 7a1069d948eb..fe413759deb9 100644 > --- a/drivers/staging/iio/resolver/ad2s1210.c > +++ b/drivers/staging/iio/resolver/ad2s1210.c > @@ -80,7 +80,6 @@ struct ad2s1210_state { > /** The external oscillator frequency in Hz. */ > unsigned long fclkin; > unsigned int fexcit; > - bool hysteresis; > u8 resolution; > u8 rx[2] __aligned(IIO_DMA_MINALIGN); > u8 tx[2]; > @@ -456,6 +455,27 @@ static int ad2s1210_read_raw(struct iio_dev *indio_dev, > } > break; > > + case IIO_CHAN_INFO_HYSTERESIS: > + switch (chan->type) { > + case IIO_ANGL: > + mutex_lock(&st->lock); > + ret = regmap_test_bits(st->regmap, AD2S1210_REG_CONTROL, > + AD2S1210_ENABLE_HYSTERESIS); > + if (ret < 0) > + goto error_info_hysteresis; > + > + *val = !!ret; > + ret = IIO_VAL_INT; > + > +error_info_hysteresis: scoped_guard might be a good solution here that avoids messy labels within deeply nested code. > + mutex_unlock(&st->lock); > + break; > + default: > + ret = -EINVAL; > + break; > + } > + break; > + > default: > ret = -EINVAL; > break; > @@ -464,6 +484,64 @@ static int ad2s1210_read_raw(struct iio_dev *indio_dev, > return ret; > } > > +static int ad2s1210_read_avail(struct iio_dev *indio_dev, > + struct iio_chan_spec const *chan, > + const int **vals, int *type, > + int *length, long mask) > +{ > + static const int available[] = { 0, 1 }; > + int ret = -EINVAL; > + > + switch (mask) { > + case IIO_CHAN_INFO_HYSTERESIS: > + switch (chan->type) { > + case IIO_ANGL: > + *vals = available; > + *type = IIO_VAL_INT; > + *length = ARRAY_SIZE(available); > + ret = IIO_AVAIL_LIST; > + break; > + default: > + break; > + } > + default: > + break; > + } > + > + return ret; > +} > + > +static int ad2s1210_write_raw(struct iio_dev *indio_dev, > + struct iio_chan_spec const *chan, > + int val, int val2, long mask) > +{ > + struct ad2s1210_state *st = iio_priv(indio_dev); > + int ret = -EINVAL; > + > + switch (mask) { > + case IIO_CHAN_INFO_HYSTERESIS: > + switch (chan->type) { > + case IIO_ANGL: > + mutex_lock(&st->lock); > + ret = regmap_update_bits(st->regmap, AD2S1210_REG_CONTROL, > + AD2S1210_ENABLE_HYSTERESIS, > + val ? AD2S1210_ENABLE_HYSTERESIS > + : 0); > + mutex_unlock(&st->lock); > + break; I'd return in these as easier to follow at this function grows. > + > + default: > + break; > + } > + break; > + > + default: > + break; > + } > + > + return ret; > +} > + > static IIO_DEVICE_ATTR(fexcit, 0644, > ad2s1210_show_fexcit, ad2s1210_store_fexcit, 0); > static IIO_DEVICE_ATTR(bits, 0644, > @@ -499,7 +577,10 @@ static const struct iio_chan_spec ad2s1210_channels[] = { > .indexed = 1, > .channel = 0, > .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | > - BIT(IIO_CHAN_INFO_SCALE), > + BIT(IIO_CHAN_INFO_SCALE) | > + BIT(IIO_CHAN_INFO_HYSTERESIS), > + .info_mask_separate_available = > + BIT(IIO_CHAN_INFO_HYSTERESIS), > }, { > .type = IIO_ANGL_VEL, > .indexed = 1, > @@ -573,6 +654,8 @@ static int ad2s1210_debugfs_reg_access(struct iio_dev *indio_dev, > > static const struct iio_info ad2s1210_info = { > .read_raw = ad2s1210_read_raw, > + .read_avail = ad2s1210_read_avail, > + .write_raw = ad2s1210_write_raw, > .attrs = &ad2s1210_attribute_group, > .debugfs_reg_access = &ad2s1210_debugfs_reg_access, > }; > @@ -689,7 +772,6 @@ static int ad2s1210_probe(struct spi_device *spi) > > mutex_init(&st->lock); > st->sdev = spi; > - st->hysteresis = true; > st->resolution = 12; > st->fexcit = AD2S1210_DEF_EXCIT; >