Received: by 2002:a05:7412:37c9:b0:e2:908c:2ebd with SMTP id jz9csp2476653rdb; Thu, 21 Sep 2023 22:33:51 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEIVnEuqL2spc7n5w+0n1Pd0OU7rpBBMGgET7phbuhWc/b6Cl+lYVtabsU/U1I8eAWTNWBE X-Received: by 2002:a05:6870:304c:b0:1d5:ef9d:5564 with SMTP id u12-20020a056870304c00b001d5ef9d5564mr7512597oau.11.1695360831180; Thu, 21 Sep 2023 22:33:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695360831; cv=none; d=google.com; s=arc-20160816; b=yMzP3i89e8/frbk/nXKAMekLf/jOSKvfpNYKmPoo5qHoafTX96AyErA6uIDCKoKlL/ Bq66wqlknCvZiGZvMbz7ig5A1eFVHzasKsTeSthDOH0JDkO99vCxpNgjgbSvFnfIS79H zrSrxtCSAKy4OZv5g2/SANld9jp92WIfyr+uuCrXgdO1C+m3fIaU5iCdDX8dlLkPeaNR Wqm6RcYIcYrBA2nVqvRE5D9Y377+Bf3cCUq0CVHSVc1dJaAEZj9B3aGOnTg50191qSAu cIBl1d90fFVtTELxXhHFZDgO+k1+LfUwBx9cw2H0tFwwBRA0DhmvE3pJulzHRgrCUZDo 4eHA== 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:date:subject:cc:to:from :dkim-signature; bh=AZybWEnlutF3BnUcq+xH7uoi35RICanW/277eMaA8Sc=; fh=rOC7q8UJisRayejF6PsoKdRfRTtXVZOwgDCXOG0B/ws=; b=aQkCTokWvr97T4uwsu8Tt/vT0tRk6Ahdv60KwjGmD6ogBTljZ43WkHf3oyNjT9aKtI e5SiZLu3lWOLkwhKsZQYiJr84b4RgABpEBSo2RK9KZguSriXIJTHwgUxWhIaGnNa88Qk 8XXuUH7ZyQdrfaa+MHw6TFqR5oBvNtNMp6Dwpg2Vv8EwLWFRDkWmOerRWnLj5BFhosVY RVH87FbCbUjVOIOf1cjv8XQdG2OypJtsHdGizsfXdpTUxnWmHvMazeXR5OmJxghIZJN6 TvJYDX/NyfXdQElfmoBRPI1yHlQUw+i1PsHSRDJ21ReW9qlEgVbqKoc2JYWsrdBedCUU DOtg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20230601.gappssmtp.com header.s=20230601 header.b=QX7oj5np; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from fry.vger.email (fry.vger.email. [23.128.96.38]) by mx.google.com with ESMTPS id k5-20020a634b45000000b00578b8d202b0si2963166pgl.536.2023.09.21.22.33.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 21 Sep 2023 22:33:51 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) client-ip=23.128.96.38; Authentication-Results: mx.google.com; dkim=pass header.i=@baylibre-com.20230601.gappssmtp.com header.s=20230601 header.b=QX7oj5np; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by fry.vger.email (Postfix) with ESMTP id 21F4A81C50AC; Thu, 21 Sep 2023 14:46:42 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at fry.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232775AbjIUVqd (ORCPT + 99 others); Thu, 21 Sep 2023 17:46:33 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46218 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231576AbjIUVqS (ORCPT ); Thu, 21 Sep 2023 17:46:18 -0400 Received: from mail-wm1-x336.google.com (mail-wm1-x336.google.com [IPv6:2a00:1450:4864:20::336]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A728451024 for ; Thu, 21 Sep 2023 10:15:31 -0700 (PDT) Received: by mail-wm1-x336.google.com with SMTP id 5b1f17b1804b1-40537481094so7267745e9.0 for ; Thu, 21 Sep 2023 10:15:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20230601.gappssmtp.com; s=20230601; t=1695316530; x=1695921330; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=AZybWEnlutF3BnUcq+xH7uoi35RICanW/277eMaA8Sc=; b=QX7oj5np2ycSjEfo16DJk51/6otI5U4wdTk4MHhhoZqEQq2sMNOVJURgTOW08Lsntk p+5j6M+bsd9jDRVI1qImshIFkGzeYKzMnKImUUSvGZSCAjwsq/NyO9E8dl/geDjzbXuc p5KIAuQ+0oHnvPZgKxkoEmE88wCFB0UjpnE5moyhtJyWckY6oKGO3zOXfT/tf+668uFf hyDGFgXL38Bgc75KJsHub0gvKOIgBuCQ7WmCFlbosnp+qWsg/EAMG0MrtskE9YJ2Ovvw EVsCjYIKnDqWDvi64gG+OqlnVR/fCtZs6922yIbyzSj4p7oLGRSjDqPHhom42j4xiSAz pd2Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1695316530; x=1695921330; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=AZybWEnlutF3BnUcq+xH7uoi35RICanW/277eMaA8Sc=; b=aV0zjsK0mQxc97cnskrh6OQWizP7nHbWml+2wzu0zdFjwyT9KCDp2Fn1+Sg6fIXeVs QrdgPZHyz3+CMSAbAUkh479962QS5nxPgaQQo99d+QdJifrjJ6Ii+ExBhl6pP/M36h+t NccoGWo47bvxPRg5wNkc3yS9XfsGz1n0QqA7IsdY/l7sQ535b6LfjvAqszJ5kghaUBIc oE81/4VX9fqvmhes2RbW5tMNPVhvMpyHvOa4QOBv7zzaZoZSBWzC9RhD6bnyBkaLELXe ZzmjLviKuULMR0n4ybBMA5eC9UuM20M+W1+jRmbgpuPhK+M7ZnZQM5AMkpAcy/EvQoH4 Gw/w== X-Gm-Message-State: AOJu0YxEtrso9ynsfHtXviTruqJqiQ6+ZeeDdPeeGX5oFv4TAXt/s1Jx 9aXOmpTXCvRIFpChiZNaTKQqY1bsZzgEjfqqUPlN2JAn X-Received: by 2002:adf:f68c:0:b0:320:b1b:86a9 with SMTP id v12-20020adff68c000000b003200b1b86a9mr5129294wrp.24.1695306163828; Thu, 21 Sep 2023 07:22:43 -0700 (PDT) Received: from localhost.localdomain (abordeaux-655-1-129-86.w90-5.abo.wanadoo.fr. [90.5.10.86]) by smtp.gmail.com with ESMTPSA id n11-20020a5d4c4b000000b0031fbbe347ebsm1901426wrt.22.2023.09.21.07.22.43 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 21 Sep 2023 07:22:43 -0700 (PDT) From: David Lechner To: linux-iio@vger.kernel.org, devicetree@vger.kernel.org, linux-staging@lists.linux.dev Cc: linux-kernel@vger.kernel.org, Jonathan Cameron , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Michael Hennerich , =?UTF-8?q?Nuno=20S=C3=A1?= , Axel Haslam , Philip Molloy , David Lechner Subject: [v2 13/19] staging: iio: resolver: ad2s1210: implement hysteresis as channel attr Date: Thu, 21 Sep 2023 09:19:41 -0500 Message-Id: <20230921141947.57784-16-dlechner@baylibre.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20230921141947.57784-1-dlechner@baylibre.com> References: <20230921141947.57784-1-dlechner@baylibre.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-0.8 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on fry.vger.email 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 (fry.vger.email [0.0.0.0]); Thu, 21 Sep 2023 14:46:42 -0700 (PDT) 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 --- 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: + 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; + + 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; -- 2.34.1