Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp3345309pxv; Sun, 4 Jul 2021 16:08:50 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwOpZ1zLkJUmrwyGkUQoIXxdZwjHv6dxYUR8DdcLi/fQLtUvJwHXCxA83NrPT0uvm5UCYZN X-Received: by 2002:a02:aa8b:: with SMTP id u11mr4549219jai.43.1625440130462; Sun, 04 Jul 2021 16:08:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625440130; cv=none; d=google.com; s=arc-20160816; b=epOU6TBxspT/r0/MLs4rTf1Mx3TI+TWpINBSx7yigVBoCQ8S8ijxWx8FZWTfJm+0hV L0hNYXCuuFN0+Pxtzau8d0OXudSCbHq7V3Jqb9GsoBxfgAcJ+ZEfN6Og5rZ7k3E8QIg1 +R6NZ6uzzjwZ8EOQEDbYJq3FsvZ7tolQfCVdT7duuRB457ttXAqHWNlqrBUUoq8+teSo PYsi92/ZU65+3t9eLJdQkZajSZ/ucxmuuhX34ffm4a2nPKXpnUqCOj544YnntRT8WeEf hy/cWMYuO5UuhWqajeZ4PfJVOS9DOUdgfnMn9HqckqciO927wrqQaUb4wN6aOa9Wir+Z ilvA== 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=S0Trz+TeAUXpDN4AsHDe6K5wzmv97lbwp8pJnCMU1l8=; b=h29kXI7PGvS97UWt5lqEL+A3TfORCLGM0JtbGekXDqzwW/FylBM2KS27XfCXD4uL+x K2n1A6E2JsstpGo1Kv+KtuUMB8kb84qjAQGVEQrW7S2OYidJa2Z+XoWQj5zgJ3LSil8m naxIs4ze9i5kOfOXvh9eWlER8YF7ZeQv2gczvsAvCD4e/cBuIugqr1iCJcawj6x5z83o 4P6p5TLDOcDqiyyQyoQPFnVBw6Ri0kf/GYgjCm/jQJzB/JV/+kYGlI1ij++lmA5jjekC t9SXfgUmVDHIdEaSiIzCk6HQLI2i2O/cm3fAyqn+8EoLNrNcWC8ZjQk8FAN/fKdEeeTw D0hA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=H4g7AlQB; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y7si10890080iln.70.2021.07.04.16.08.38; Sun, 04 Jul 2021 16:08:50 -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=@kernel.org header.s=k20201202 header.b=H4g7AlQB; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231455AbhGDXJL (ORCPT + 99 others); Sun, 4 Jul 2021 19:09:11 -0400 Received: from mail.kernel.org ([198.145.29.99]:47420 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231246AbhGDXIW (ORCPT ); Sun, 4 Jul 2021 19:08:22 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id F121861364; Sun, 4 Jul 2021 23:05:45 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1625439946; bh=VuBZkuYORyCKJqQ3ug2x8UyRbKpNijoZunM6p8muHn4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=H4g7AlQByb8WaBj7T9mKTqshIt93Gd85peR7OocyKdc11Ln2fquKFVhaUhw7kKVYP v0jEf+Wtva063Q2VbHRBIuCll8epEDw77z6CnI6h4lsTYXNHwycvJ+9fKlJvSuoTok YPqhC/cRcjWRJ3WJU5fy8ZHUzbp3nDiJGwPMShMCd4CrS5Jw3zF2vE63j6kmXEIZbG nDAIpWtfnfU6G7DCVaT31jWk2K2Z7TTM0WgioZD7NG6sQiaPfGAyp8yl6fp5HiBqZc zXuyUWLfZELlgkof4EdZFN9CC/bqgRgtX68S8zBK2+avyFlrY1hTzW5LgZRoKD7bq2 Q72LWBwVQeSsQ== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Guenter Roeck , =?UTF-8?q?Jan=20Kundr=C3=A1t?= , =?UTF-8?q?V=C3=A1clav=20Kubern=C3=A1t?= , =?UTF-8?q?V=C3=A1clav=20Kubern=C3=A1t?= , Sasha Levin , linux-hwmon@vger.kernel.org, linux-doc@vger.kernel.org Subject: [PATCH AUTOSEL 5.13 63/85] hwmon: (max31790) Report correct current pwm duty cycles Date: Sun, 4 Jul 2021 19:03:58 -0400 Message-Id: <20210704230420.1488358-63-sashal@kernel.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210704230420.1488358-1-sashal@kernel.org> References: <20210704230420.1488358-1-sashal@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Guenter Roeck [ Upstream commit 897f6339893b741a5d68ae8e2475df65946041c2 ] The MAX31790 has two sets of registers for pwm duty cycles, one to request a duty cycle and one to read the actual current duty cycle. Both do not have to be the same. When reporting the pwm duty cycle to the user, the actual pwm duty cycle from pwm duty cycle registers needs to be reported. When setting it, the pwm target duty cycle needs to be written. Since we don't know the actual pwm duty cycle after a target pwm duty cycle has been written, set the valid flag to false to indicate that actual pwm duty cycle should be read from the chip instead of using cached values. Cc: Jan Kundrát Cc: Václav Kubernát Signed-off-by: Guenter Roeck Tested-by: Václav Kubernát Reviewed-by: Jan Kundrát Link: https://lore.kernel.org/r/20210526154022.3223012-3-linux@roeck-us.net Signed-off-by: Sasha Levin --- Documentation/hwmon/max31790.rst | 3 ++- drivers/hwmon/max31790.c | 6 +++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/Documentation/hwmon/max31790.rst b/Documentation/hwmon/max31790.rst index f301385d8cef..54ff0f49e28f 100644 --- a/Documentation/hwmon/max31790.rst +++ b/Documentation/hwmon/max31790.rst @@ -39,5 +39,6 @@ fan[1-12]_input RO fan tachometer speed in RPM fan[1-12]_fault RO fan experienced fault fan[1-6]_target RW desired fan speed in RPM pwm[1-6]_enable RW regulator mode, 0=disabled, 1=manual mode, 2=rpm mode -pwm[1-6] RW fan target duty cycle (0-255) +pwm[1-6] RW read: current pwm duty cycle, + write: target pwm duty cycle (0-255) ================== === ======================================================= diff --git a/drivers/hwmon/max31790.c b/drivers/hwmon/max31790.c index 86e6c71db685..8ad7a45bfe68 100644 --- a/drivers/hwmon/max31790.c +++ b/drivers/hwmon/max31790.c @@ -104,7 +104,7 @@ static struct max31790_data *max31790_update_device(struct device *dev) data->tach[NR_CHANNEL + i] = rv; } else { rv = i2c_smbus_read_word_swapped(client, - MAX31790_REG_PWMOUT(i)); + MAX31790_REG_PWM_DUTY_CYCLE(i)); if (rv < 0) goto abort; data->pwm[i] = rv; @@ -299,10 +299,10 @@ static int max31790_write_pwm(struct device *dev, u32 attr, int channel, err = -EINVAL; break; } - data->pwm[channel] = val << 8; + data->valid = false; err = i2c_smbus_write_word_swapped(client, MAX31790_REG_PWMOUT(channel), - data->pwm[channel]); + val << 8); break; case hwmon_pwm_enable: fan_config = data->fan_config[channel]; -- 2.30.2