From patchwork Wed May 24 00:01:11 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: George Stark X-Patchwork-Id: 98221 Return-Path: Delivered-To: ouuuleilei@gmail.com Received: by 2002:a59:b0ea:0:b0:3b6:4342:cba0 with SMTP id b10csp2497885vqo; Tue, 23 May 2023 17:11:40 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ4kJhkxv34XWlqMc3KCYMmfN4DcS+9vzljTQvctxLQ9zKJuv185z9dFuRmRmOxYFdlGndwV X-Received: by 2002:a05:6a00:1a13:b0:646:3c2:4d30 with SMTP id g19-20020a056a001a1300b0064603c24d30mr868491pfv.30.1684887099713; Tue, 23 May 2023 17:11:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1684887099; cv=none; d=google.com; s=arc-20160816; b=utai1LbuhVqhE8JNyogns5xnE0o4W50xfy57gZM5uMaoW8BYGarvmJmg2X/7dSMY6s BWJGxKlFdnzJxOPF5SV+S8zxJBycgAEmPtK7Vhxh+WJsKioT7F2Wg+eGibe5F+PWHLa+ mgDA+ZCob7EYaRXkqQYNrsprW4SdVIWhSNlCkJEerv2F8/W28VD+RgNjuAJqrj1eYBFA YDo+kB3RmnP77S8pJcqBGHJMKtjz+ZOTThdTIGzQIlUIa+HWfAPfiV5cgBb4k7Mxo//r 23o3q04IA8h0tj9SLgaJ4p+llvDrvp39fbcsbCAoacVECI2x2vgb+XCO1tZogZFIqE3h 4T2Q== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=axVJ7641uXabYayO/3wTwP3lkBTzWLtoTnUTKuJMnlU=; b=bYgdzPaYa077qV5qCc/DEH8xRqjW/VHE85jRXElQSZB+wc8p4sk0Q46E+0WqjLVXZi k+G9RJ46Umbcht0mAFhXVO0zP5eMbPfkxZVjQqN5L7GfOIe0cj1J90W72cWIfydgE2RQ MOeap7xaITQZOxRrslUEE5HleKTmkQOSal8L9Yb7Ud5RCzsFQKTPcQrdfl+UIY5wMwg9 xNR8YFRzN1WE424AFpDqdtkkqBV8ZhP0+D76A7tIl+ghLyVbE/1ERWkd35gbJfrOgW2O CzbOvp872xa4PJgGBPsNgq6ioomyfFrQD38etW489/NvFhVfUpOwEhyCbUvt6ZLzVtnR o2wg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@sberdevices.ru header.s=mail header.b=N6Dn84VO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=sberdevices.ru Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id e5-20020a056a0000c500b0064d4d472935si6597434pfj.18.2023.05.23.17.11.27; Tue, 23 May 2023 17:11:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@sberdevices.ru header.s=mail header.b=N6Dn84VO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=sberdevices.ru Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238912AbjEXAB6 (ORCPT + 99 others); Tue, 23 May 2023 20:01:58 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33002 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238567AbjEXAB5 (ORCPT ); Tue, 23 May 2023 20:01:57 -0400 Received: from mx.sberdevices.ru (mx.sberdevices.ru [45.89.227.171]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A99BC1A4; Tue, 23 May 2023 17:01:41 -0700 (PDT) Received: from s-lin-edge02.sberdevices.ru (localhost [127.0.0.1]) by mx.sberdevices.ru (Postfix) with ESMTP id 6B18B5FD03; Wed, 24 May 2023 03:01:39 +0300 (MSK) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sberdevices.ru; s=mail; t=1684886499; bh=axVJ7641uXabYayO/3wTwP3lkBTzWLtoTnUTKuJMnlU=; h=From:To:Subject:Date:Message-ID:MIME-Version:Content-Type; b=N6Dn84VO8YczLUkTXu1/6KwcMcOKfsCHELP7x2SJ4mj8q9TdMGlZEIraS3Mi4DHzB 2Zp4RAVgmCp/ZFW4MaBjMvD3k7PseFKJMtsJXxQdJUBkcutFURW64Fi3uxWqKQUWOS EGWjnerpyp2Od6HiiriocffF3q0chriYYjDKgIvwOLl//DaA+/JO+oB5D0noGvYUfy 4xTT1V28WmZ6YIwo8GZ/K/W5EqOSUcj7z4PfHbiwrcEBDIYD2dIvMfYHiRD3ickzIt PvSobGwPaaxhEbKm8VBkV3CaAaAPpxo2FR/lYMdjxBg72sFgoCtWpaTyP8AgZhgFrH +EB2MFhAkG8eQ== Received: from S-MS-EXCH01.sberdevices.ru (S-MS-EXCH01.sberdevices.ru [172.16.1.4]) by mx.sberdevices.ru (Postfix) with ESMTP; Wed, 24 May 2023 03:01:36 +0300 (MSK) From: George Stark To: , , , , , , , , CC: , , , , , George Stark Subject: [PATCH v1] meson saradc: add iio device attrib to switch channel 7 mux Date: Wed, 24 May 2023 03:01:11 +0300 Message-ID: <20230524000111.14370-1-gnstark@sberdevices.ru> X-Mailer: git-send-email 2.40.1 MIME-Version: 1.0 X-Originating-IP: [172.16.1.6] X-ClientProxiedBy: S-MS-EXCH02.sberdevices.ru (172.16.1.5) To S-MS-EXCH01.sberdevices.ru (172.16.1.4) X-KSMG-Rule-ID: 4 X-KSMG-Message-Action: clean X-KSMG-AntiSpam-Status: not scanned, disabled by settings X-KSMG-AntiSpam-Interceptor-Info: not scanned X-KSMG-AntiPhishing: not scanned, disabled by settings X-KSMG-AntiVirus: Kaspersky Secure Mail Gateway, version 1.1.2.30, bases: 2023/05/23 21:43:00 #21378639 X-KSMG-AntiVirus-Status: Clean, skipped X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_NONE,SPF_NONE, T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED 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-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1766732175155544237?= X-GMAIL-MSGID: =?utf-8?q?1766732175155544237?= Patch adds two sysfs nodes: chan7_mux to set mux state and chan7_mux_available to show available mux states. Mux can be used to debug and calibrate adc by switching and measuring well-known inputs like gnd, vdd etc. Signed-off-by: George Stark --- drivers/iio/adc/meson_saradc.c | 66 ++++++++++++++++++++++++++++++++++ 1 file changed, 66 insertions(+) diff --git a/drivers/iio/adc/meson_saradc.c b/drivers/iio/adc/meson_saradc.c index e05e51900c35..77ef2b55f6f4 100644 --- a/drivers/iio/adc/meson_saradc.c +++ b/drivers/iio/adc/meson_saradc.c @@ -11,6 +11,7 @@ #include #include #include +#include #include #include #include @@ -320,6 +321,7 @@ struct meson_sar_adc_priv { bool temperature_sensor_calibrated; u8 temperature_sensor_coefficient; u16 temperature_sensor_adc_val; + u8 chan7_mux_sel; }; static const struct regmap_config meson_sar_adc_regmap_config_gxbb = { @@ -483,6 +485,7 @@ static void meson_sar_adc_set_chan7_mux(struct iio_dev *indio_dev, regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG3, MESON_SAR_ADC_REG3_CTRL_CHAN7_MUX_SEL_MASK, regval); + priv->chan7_mux_sel = sel; usleep_range(10, 20); } @@ -1130,8 +1133,71 @@ static int meson_sar_adc_calib(struct iio_dev *indio_dev) return ret; } +static const char * const chan7_vol[] = { + "gnd", + "vdd/4", + "vdd/2", + "vdd*3/4", + "vdd", + "ch7_input", +}; + +static ssize_t chan7_mux_show(struct device *dev, struct device_attribute *attr, + char *buf) +{ + struct iio_dev *indio_dev = dev_to_iio_dev(dev); + struct meson_sar_adc_priv *priv = iio_priv(indio_dev); + unsigned int index = priv->chan7_mux_sel; + + if (index >= ARRAY_SIZE(chan7_vol)) + index = ARRAY_SIZE(chan7_vol) - 1; + + return sysfs_emit(buf, "%s\n", chan7_vol[index]); +} + +static ssize_t chan7_mux_store(struct device *dev, + struct device_attribute *attr, + const char *buf, size_t count) +{ + struct iio_dev *indio_dev = dev_to_iio_dev(dev); + int i; + + for (i = 0; i < ARRAY_SIZE(chan7_vol); i++) + if (!strcmp(chan7_vol[i], buf)) { + meson_sar_adc_set_chan7_mux(indio_dev, i); + return count; + } + + return -EINVAL; +} + +static ssize_t chan7_mux_available_show(struct device *dev, struct device_attribute *attr, + char *buf) +{ + int i, len = 0; + + for (i = 0; i < ARRAY_SIZE(chan7_vol); i++) + len += sysfs_emit_at(buf, len, "%s ", chan7_vol[i]); + + return len; +} + +static IIO_DEVICE_ATTR_RW(chan7_mux, -1); +static IIO_DEVICE_ATTR_RO(chan7_mux_available, -1); + +static struct attribute *meson_sar_adc_attrs[] = { + &iio_dev_attr_chan7_mux_available.dev_attr.attr, + &iio_dev_attr_chan7_mux.dev_attr.attr, + NULL, +}; + +static const struct attribute_group meson_sar_adc_attr_group = { + .attrs = meson_sar_adc_attrs, +}; + static const struct iio_info meson_sar_adc_iio_info = { .read_raw = meson_sar_adc_iio_info_read_raw, + .attrs = &meson_sar_adc_attr_group, }; static const struct meson_sar_adc_param meson_sar_adc_meson8_param = {