Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp1153033pxb; Sun, 10 Oct 2021 22:38:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxidTGctoNgHGrqNZKN+RLyHx326kFuB/cKd74pIvzoNFZQkf3H3vMOZD8S5nrCS5KSpZnS X-Received: by 2002:a65:6a4b:: with SMTP id o11mr15960217pgu.278.1633930729749; Sun, 10 Oct 2021 22:38:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633930729; cv=none; d=google.com; s=arc-20160816; b=ThlH9pqfgcgazG07ifSJJifBZGAiGMTsiZVbQ+jCLiP37NJjtP9qaNRVgQf0N9FbGR 1pjUhd3O+/VOZKkOb6YM6Hs/y89dx5HuxJS9lyFpN0zKaJ0L/5VOo3/xMk3HezZhlRml ySOADN8FmYnG9pF59QOc2tzVnEHnoGMHDpPTBa9CMvyQ39ze3FuZbhZZS8nmM7UykZkb zz0uL1+6zelWmsLKrpjQZktQx8JY6tyRTa6+6jO+x/hZOy6k3cKnIlZ9LxbBuBLZh0mO m7w/ZncnbDgwvn9KnSxop5nwOj5idDi7OBTWgJVdBMoM7pAzHa/gUfC5aprMMUSRrIkQ f5DA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:sender:dkim-signature; bh=QunyXUt74Gx3GYDTkgdqDinXhHjEbO9JIPtdoMQbpkY=; b=k01XLy1j4CP8f0bGRj9hmyOD5lpUSB8NIoQU5bpO4QRw6ashyikwqd/chnITOOQ0LH xa5WsJoSzHXAXHtX/hmBoFXb5jtMnnoOFjhqU2cyRbYFUm5JDFtzB1ava+6yxTwsugwo ndiWx0rky24VxDnNCES0pM9zcMAn7AmX9HewwvZQshtFK9mctHirYo29OCd4e10saefx Fg7QFTyvA+9pKdcQe4oqpVwFX814TzxmHvM0k2C5HorVxfxavRWqPcw6Uy2od6n+xUFf tPfkN4GwnrCwGIPkYUKIdbDuGSgZvwnT8mRgsU7U6096hhFxZNtcioKJQg7TfhJrSmQZ ZKOQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=DHbZF6Kg; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r17si9878979pgh.182.2021.10.10.22.38.37; Sun, 10 Oct 2021 22:38:49 -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 header.i=@gmail.com header.s=20210112 header.b=DHbZF6Kg; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233887AbhJKELC (ORCPT + 99 others); Mon, 11 Oct 2021 00:11:02 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43506 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232145AbhJKELA (ORCPT ); Mon, 11 Oct 2021 00:11:00 -0400 Received: from mail-ot1-x32d.google.com (mail-ot1-x32d.google.com [IPv6:2607:f8b0:4864:20::32d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CDDF8C061570; Sun, 10 Oct 2021 21:09:00 -0700 (PDT) Received: by mail-ot1-x32d.google.com with SMTP id x33-20020a9d37a4000000b0054733a85462so20040183otb.10; Sun, 10 Oct 2021 21:09:00 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=sender:subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=QunyXUt74Gx3GYDTkgdqDinXhHjEbO9JIPtdoMQbpkY=; b=DHbZF6KgPcU6w2KvrVB6smtJTD/qX+YmRqw+mcDxwjVuNdIObUKwIPmW+mb3XZu966 eXi6kgXlFCjkhBQ/MbruKhbA6qI1qDZrTY+FUwELNqhmSan5vjejAghLN7jWjGTcYoSi l9wZ/56Mgvkf/nLAkOJQbHz4PQOgGh//Uu+Q33v+pFbYhGHP/lVpNXxwTF00D145QnnR eVVmOsiaspsKPHM4YzBdlUD4Gdc+Gr+/oMCZOOrzmf4EuZrgzVRO0uZUz54DLolRXlda HVAnNl7oSbfV5pLkFCJfo00Q1HPTTERZPhctrjalhL0QVAUCyjLdEfR6sX6blGBT5Rza v1aA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:sender:subject:to:cc:references:from:message-id :date:user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=QunyXUt74Gx3GYDTkgdqDinXhHjEbO9JIPtdoMQbpkY=; b=HQTxEjBtQConlcjfmyn3wntAQ31GFYgLzjksR8sUBjb3JmSwmg+UCdrT17Uk8hUrV7 +KVr1O/FGsXW3RmtftU1WewS03goOeQEwCrevSUpytbpUIYhiiq+lTMjBvfYUQkqjQwF b3oRwb3vl+MHUW/lk7xI8+zXpnmWy10IgKrWmlH4JRoXESi+KxdpXYSCk9BdMxoSDbi+ dSO2qjdG+dVkEHqIRqNBNFQjj6ne56snixhsC4VSHTrICobfeB0gBOfjiL6/Shm0yTuk z17D2/mqhJIsAGMUcqxPl+djXeUxkrVfHMKh/xegIyHq4KN86Nuk5E0LmjsuuMxm4W2r qYGQ== X-Gm-Message-State: AOAM530hxxN/CJEXTIzfnakpSVJGcutyE4sCdRBb0yEvg2SnBd5NelZv 6h9/ldej5tshIv5RgzoPsGzSbIVPjUg= X-Received: by 2002:a9d:7018:: with SMTP id k24mr5484280otj.168.1633925339859; Sun, 10 Oct 2021 21:08:59 -0700 (PDT) Received: from server.roeck-us.net ([2600:1700:e321:62f0:329c:23ff:fee3:9d7c]) by smtp.gmail.com with ESMTPSA id az14sm589495oib.51.2021.10.10.21.08.58 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Sun, 10 Oct 2021 21:08:59 -0700 (PDT) Sender: Guenter Roeck Subject: Re: [PATCH v7 2/2] hwmon: (nct7802) Make temperature/voltage sensors configurable To: Oskar Senft Cc: Jean Delvare , Rob Herring , linux-hwmon@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org References: <20211011012212.91357-1-osk@google.com> <20211011012212.91357-2-osk@google.com> <98dcaa85-d04c-7a9c-1901-8786d361477c@roeck-us.net> From: Guenter Roeck Message-ID: <518a6ab3-80af-bbe9-69e5-55e6741bdcbe@roeck-us.net> Date: Sun, 10 Oct 2021 21:08:57 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.13.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/10/21 6:53 PM, Oskar Senft wrote: > I wasn't sure if submitting JUST a v7 of nuvoton,nct7802.yaml (i.e. > the 1/2 in this series) would be the right thing to do and thought it > would be easier to follow if I dropped both. I couldn't find > documentation on what's the right thing to do in that case. Would it > have been better to only submit nuvoton,nct7802.yaml as "PATCH v7" ? > First, please don't top-post. Second, no, submitting both patches was the right thing to do, but you should not drop a Reviewed-by: tag if there was no change to the patch. Guenter > Oskar. > > On Sun, Oct 10, 2021 at 9:49 PM Guenter Roeck wrote: >> >> On 10/10/21 6:22 PM, Oskar Senft wrote: >>> This change allows LTD and RTD inputs to be configured via >>> device tree bindings. If the DT bindings are not present or >>> invalid, the input configuration is not modified and left at >>> HW defaults. >>> >>> Signed-off-by: Oskar Senft >> >> I sent a Reviewed-by: for v6 of this patch. >> >>> --- >>> Changes from PATCH v6: >>> - None (resubmitted due to changes in nuvoton,nct7802.yaml). >>> >> >> Why did you drop it if there was no change ? >> >> Guenter >> >>> Changes from PATCH v5: >>> - Removed unused "found_channel_config" variable. >>> - Initialize mode_mask and mode_val to defaults. >>> --- >>> drivers/hwmon/nct7802.c | 129 ++++++++++++++++++++++++++++++++++++++-- >>> 1 file changed, 125 insertions(+), 4 deletions(-) >>> >>> diff --git a/drivers/hwmon/nct7802.c b/drivers/hwmon/nct7802.c >>> index 604af2f6103a..d56f78327619 100644 >>> --- a/drivers/hwmon/nct7802.c >>> +++ b/drivers/hwmon/nct7802.c >>> @@ -51,6 +51,23 @@ static const u8 REG_VOLTAGE_LIMIT_MSB_SHIFT[2][5] = { >>> #define REG_CHIP_ID 0xfe >>> #define REG_VERSION_ID 0xff >>> >>> +/* >>> + * Resistance temperature detector (RTD) modes according to 7.2.32 Mode >>> + * Selection Register >>> + */ >>> +#define RTD_MODE_CURRENT 0x1 >>> +#define RTD_MODE_THERMISTOR 0x2 >>> +#define RTD_MODE_VOLTAGE 0x3 >>> + >>> +#define MODE_RTD_MASK 0x3 >>> +#define MODE_LTD_EN 0x40 >>> + >>> +/* >>> + * Bit offset for sensors modes in REG_MODE. >>> + * Valid for index 0..2, indicating RTD1..3. >>> + */ >>> +#define MODE_BIT_OFFSET_RTD(index) ((index) * 2) >>> + >>> /* >>> * Data structures and manipulation thereof >>> */ >>> @@ -1038,7 +1055,112 @@ static const struct regmap_config nct7802_regmap_config = { >>> .volatile_reg = nct7802_regmap_is_volatile, >>> }; >>> >>> -static int nct7802_init_chip(struct nct7802_data *data) >>> +static int nct7802_get_channel_config(struct device *dev, >>> + struct device_node *node, u8 *mode_mask, >>> + u8 *mode_val) >>> +{ >>> + u32 reg; >>> + const char *type_str, *md_str; >>> + u8 md; >>> + >>> + if (!node->name || of_node_cmp(node->name, "channel")) >>> + return 0; >>> + >>> + if (of_property_read_u32(node, "reg", ®)) { >>> + dev_err(dev, "Could not read reg value for '%s'\n", >>> + node->full_name); >>> + return -EINVAL; >>> + } >>> + >>> + if (reg > 3) { >>> + dev_err(dev, "Invalid reg (%u) in '%s'\n", reg, >>> + node->full_name); >>> + return -EINVAL; >>> + } >>> + >>> + if (reg == 0) { >>> + if (!of_device_is_available(node)) >>> + *mode_val &= ~MODE_LTD_EN; >>> + else >>> + *mode_val |= MODE_LTD_EN; >>> + *mode_mask |= MODE_LTD_EN; >>> + return 0; >>> + } >>> + >>> + /* At this point we have reg >= 1 && reg <= 3 */ >>> + >>> + if (!of_device_is_available(node)) { >>> + *mode_val &= ~(MODE_RTD_MASK << MODE_BIT_OFFSET_RTD(reg - 1)); >>> + *mode_mask |= MODE_RTD_MASK << MODE_BIT_OFFSET_RTD(reg - 1); >>> + return 0; >>> + } >>> + >>> + if (of_property_read_string(node, "sensor-type", &type_str)) { >>> + dev_err(dev, "No type for '%s'\n", node->full_name); >>> + return -EINVAL; >>> + } >>> + >>> + if (!strcmp(type_str, "voltage")) { >>> + *mode_val |= (RTD_MODE_VOLTAGE & MODE_RTD_MASK) >>> + << MODE_BIT_OFFSET_RTD(reg - 1); >>> + *mode_mask |= MODE_RTD_MASK << MODE_BIT_OFFSET_RTD(reg - 1); >>> + return 0; >>> + } >>> + >>> + if (strcmp(type_str, "temperature")) { >>> + dev_err(dev, "Invalid type '%s' for '%s'\n", type_str, >>> + node->full_name); >>> + return -EINVAL; >>> + } >>> + >>> + if (reg == 3) { >>> + /* RTD3 only supports thermistor mode */ >>> + md = RTD_MODE_THERMISTOR; >>> + } else { >>> + if (of_property_read_string(node, "temperature-mode", >>> + &md_str)) { >>> + dev_err(dev, "No mode for '%s'\n", node->full_name); >>> + return -EINVAL; >>> + } >>> + >>> + if (!strcmp(md_str, "thermal-diode")) >>> + md = RTD_MODE_CURRENT; >>> + else if (!strcmp(md_str, "thermistor")) >>> + md = RTD_MODE_THERMISTOR; >>> + else { >>> + dev_err(dev, "Invalid mode '%s' for '%s'\n", md_str, >>> + node->full_name); >>> + return -EINVAL; >>> + } >>> + } >>> + >>> + *mode_val |= (md & MODE_RTD_MASK) << MODE_BIT_OFFSET_RTD(reg - 1); >>> + *mode_mask |= MODE_RTD_MASK << MODE_BIT_OFFSET_RTD(reg - 1); >>> + >>> + return 0; >>> +} >>> + >>> +static int nct7802_configure_channels(struct device *dev, >>> + struct nct7802_data *data) >>> +{ >>> + /* Enable local temperature sensor by default */ >>> + u8 mode_mask = MODE_LTD_EN, mode_val = MODE_LTD_EN; >>> + struct device_node *node; >>> + int err; >>> + >>> + if (dev->of_node) { >>> + for_each_child_of_node(dev->of_node, node) { >>> + err = nct7802_get_channel_config(dev, node, &mode_mask, >>> + &mode_val); >>> + if (err) >>> + return err; >>> + } >>> + } >>> + >>> + return regmap_update_bits(data->regmap, REG_MODE, mode_mask, mode_val); >>> +} >>> + >>> +static int nct7802_init_chip(struct device *dev, struct nct7802_data *data) >>> { >>> int err; >>> >>> @@ -1047,8 +1169,7 @@ static int nct7802_init_chip(struct nct7802_data *data) >>> if (err) >>> return err; >>> >>> - /* Enable local temperature sensor */ >>> - err = regmap_update_bits(data->regmap, REG_MODE, 0x40, 0x40); >>> + err = nct7802_configure_channels(dev, data); >>> if (err) >>> return err; >>> >>> @@ -1074,7 +1195,7 @@ static int nct7802_probe(struct i2c_client *client) >>> mutex_init(&data->access_lock); >>> mutex_init(&data->in_alarm_lock); >>> >>> - ret = nct7802_init_chip(data); >>> + ret = nct7802_init_chip(dev, data); >>> if (ret < 0) >>> return ret; >>> >>> >>