Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2825087pxv; Mon, 12 Jul 2021 02:52:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw3Usic/5oHCIk5eMn2uNRkpaMaD8srjnyQVzV/rBGu/HlA8bTZqrCuARDqrDjam+BWoGge X-Received: by 2002:a05:6638:2111:: with SMTP id n17mr3861677jaj.76.1626083537418; Mon, 12 Jul 2021 02:52:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626083537; cv=none; d=google.com; s=arc-20160816; b=ujoZYF0kGXw9NfCZ9JggvCbjyy3hCMxUGDXjTGLpKCb0c8yqpytDU2SRTUgPXC/X54 PeQMc68z1eznXgIduL2JId60G5M+8ByvynC4IMQRC8M6hH3701uX9nrY2on9UhTpfNCl KiBr5put1WMVu6mrcamSmtc2cLy6L2OsnWHX/PwP/5QhSMzlw2I+VcAEgKcQwC9DliYU 9UmxU7MJ/KdYYwPqiWIfYeRhL13EWeTwGwBRahwCoECa9LJrqOJ8W39PbDUnpjWtOHyP fWzUFXnfpPjui9I+HeHESImXKInFDnv00+7IRceM8gQQGfNkqkQ6bLzUKPLRDzk/8sBg cMhw== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=S0Trz+TeAUXpDN4AsHDe6K5wzmv97lbwp8pJnCMU1l8=; b=xWj+oZn7BhTSzvbhlWxyNxwnIxJTyHBqdAPDu/dPriJPvbMv+vyKV7+pp/3kri7Xt7 JwJOFx/3Mas7uvPKLHFJuQJDKnygN9jYovocQxmMg6KYy6WzmFGgCtGjZHK/98x86qMY x84hu1HreENoTh0ESfOx9r5nr/IPaHxnCsROxXP+Rarkhsk5TWn66ilZQF18vkxkG2ja WGuWLKmw1f92mUfNMOCPmL9H6rO0eNc6vaZ5prGDA9nFBFWpTx7WQcBCMP4Qeol8BXEu JTVW25f5HT46XU4vF/s5h3VdtOrirlMvor4iUuGVbwYgYIZq0IoGD55faJOq21r2SwcK U/Mw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=Sd91AbZu; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w13si16572186jar.0.2021.07.12.02.52.05; Mon, 12 Jul 2021 02:52:17 -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=@linuxfoundation.org header.s=korg header.b=Sd91AbZu; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238200AbhGLGse (ORCPT + 99 others); Mon, 12 Jul 2021 02:48:34 -0400 Received: from mail.kernel.org ([198.145.29.99]:34338 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236792AbhGLGhq (ORCPT ); Mon, 12 Jul 2021 02:37:46 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 48C8361154; Mon, 12 Jul 2021 06:33:55 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626071635; bh=VuBZkuYORyCKJqQ3ug2x8UyRbKpNijoZunM6p8muHn4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Sd91AbZuPgYU3OTMWa3j+Kfd3RhMrYf0Mi9wyFMru8A+T1Aa81KIOvcTKiirXJ34n gHPjpVSZVnsE62gBic0BopBdMAoWR1YhEBrkUJHXj040wXvxck3m8wB8DeR8QJxMkS LfdpbkLv4s3TzZ/Y+yoy+b/YaNox7aRSaRBsBuWc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, =?UTF-8?q?Jan=20Kundr=C3=A1t?= , =?UTF-8?q?V=C3=A1clav=20Kubern=C3=A1t?= , Guenter Roeck , =?UTF-8?q?V=C3=A1clav=20Kubern=C3=A1t?= , Sasha Levin Subject: [PATCH 5.10 152/593] hwmon: (max31790) Report correct current pwm duty cycles Date: Mon, 12 Jul 2021 08:05:12 +0200 Message-Id: <20210712060859.750703061@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210712060843.180606720@linuxfoundation.org> References: <20210712060843.180606720@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 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