Received: by 2002:a05:7412:3784:b0:e2:908c:2ebd with SMTP id jk4csp1416rdb; Fri, 29 Sep 2023 14:23:27 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGpko8WD0qhgaKufEMGMlE+IWAinqV8zVWJLLCutpFnJXQHQ/jQ5kFsIfn97r4LMRhOG2FF X-Received: by 2002:a17:903:244d:b0:1b8:8682:62fb with SMTP id l13-20020a170903244d00b001b8868262fbmr9571617pls.4.1696022607062; Fri, 29 Sep 2023 14:23:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1696022607; cv=none; d=google.com; s=arc-20160816; b=VvVG1+BA1dcNdYBahTMKH1UGCWE3wRy1bHqRxlTfkGwr5VGgznrJ6NsdPv5kwPG4Cw uCXXU8G18ZbzWQGfzzJM4Bzggu0ei3vR2yCMHSnK+KLBn9ZfKySOWx4I17UqCCyHFYb2 cVaI0Kcw2XA5zHTxZO2OD5jMObghMHx/B97TgmxVoj0WQcui7AAErtbk3JlsG8qbS9JH ywS7Kseaq2wgv/J8S4ysrZ8FIo3IeR/5AAkOUs5aaVVo/uQccz1DLmYrLjkRO4tOFLVm bM7UE7uGbORrh8IM6MGiWNGdxZt5covIDnYligUoa2dgxZaQ2gI6JycLH0LkJEZzflLe QQjQ== 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=XaRQ3hF7+3HvdPllkPSlqP2DtFhNZG/Nd/UsLFqUiwk=; fh=mQTAMmW6tHAsSZ8mqTltNHQ9PsuN6nvkG3CwQo0ASM0=; b=jhFpbtTFDshI8RuO8KjzVkQezAYOimJF65usd50bMx/4eVLUK/hd9qcXRXWsMaxurs xpe3hk8bj6r6AubrNZf0O6YCJlZd/VhRf8MTJC0Noybz1+SufdwQL4Myo0NUQa1hR+Ay irnMrEK+vE4/x6jqnDp6X2mUeMu0ElUa0ac5Kwd2Pr4dJGgoLt/4NA+t8P+OUhgmTjQD BeNL/nOHrVuB1/r+iuyU4UbpvB8tsj3szaXSXMXrVCDYOpGUpga0yaMGrof0gpsLCJwA zIk8d9Rno/hj/iKhdOqdmZKMplfQGMq3wr/SeM973fZqW1JWG3VFzMBatU+KAwut6ux2 f1GQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bewilderbeest.net header.s=thorn header.b=ih8Lvmwm; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=bewilderbeest.net Return-Path: Received: from lipwig.vger.email (lipwig.vger.email. [2620:137:e000::3:3]) by mx.google.com with ESMTPS id h2-20020a635302000000b0056336fb99aasi21263561pgb.850.2023.09.29.14.23.26 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 29 Sep 2023 14:23:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) client-ip=2620:137:e000::3:3; Authentication-Results: mx.google.com; dkim=pass header.i=@bewilderbeest.net header.s=thorn header.b=ih8Lvmwm; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=bewilderbeest.net Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by lipwig.vger.email (Postfix) with ESMTP id 1C6678325183; Fri, 29 Sep 2023 13:08:46 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233152AbjI2UIg (ORCPT + 99 others); Fri, 29 Sep 2023 16:08:36 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33324 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232923AbjI2UIf (ORCPT ); Fri, 29 Sep 2023 16:08:35 -0400 Received: from thorn.bewilderbeest.net (thorn.bewilderbeest.net [71.19.156.171]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 138F41A7 for ; Fri, 29 Sep 2023 13:08:32 -0700 (PDT) Received: from hatter.bewilderbeest.net (unknown [IPv6:2602:61:7e5d:5300::2]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) (Authenticated sender: zev) by thorn.bewilderbeest.net (Postfix) with ESMTPSA id 6E1BC674; Fri, 29 Sep 2023 13:08:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bewilderbeest.net; s=thorn; t=1696018112; bh=XaRQ3hF7+3HvdPllkPSlqP2DtFhNZG/Nd/UsLFqUiwk=; h=From:To:Cc:Subject:Date:From; b=ih8LvmwmLvPNHvlZgHhZs0XrrvesXFkQ72sE/2t303C89uFRkEvlBBkfuKFLonnLf PdPzGWKFMJU31pD3Cvc/LzS6nfRMiQb+kJPDJEv54r8wvxEflSoQX+D6sjSsI3XH0j HFhjHthMflQ6oq4eE56OKnUP3+fnTq+z+LmIwvVo= From: Zev Weiss To: Guenter Roeck , Jean Delvare , linux-hwmon@vger.kernel.org Cc: Zev Weiss , Joel Stanley , linux-kernel@vger.kernel.org, Thomas Zajic , stable@vger.kernel.org Subject: [PATCH] hwmon: nct6775: Fix incorrect variable reuse in fan_div calculation Date: Fri, 29 Sep 2023 13:08:23 -0700 Message-ID: <20230929200822.964-2-zev@bewilderbeest.net> X-Mailer: git-send-email 2.42.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,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 lipwig.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 (lipwig.vger.email [0.0.0.0]); Fri, 29 Sep 2023 13:08:46 -0700 (PDT) In the regmap conversion in commit 4ef2774511dc ("hwmon: (nct6775) Convert register access to regmap API") I reused the 'reg' variable for all three register reads in the fan speed calculation loop in nct6775_update_device(), but failed to notice that the value from the first one (data->REG_FAN[i]) is actually used in the call to nct6775_select_fan_div() at the end of the loop body. Since that patch the register value passed to nct6775_select_fan_div() has been (conditionally) incorrectly clobbered with the value of a different register than intended, which has in at least some cases resulted in fan speeds being adjusted down to zero. Fix this by using dedicated temporaries for the two intermediate register reads instead of 'reg'. Signed-off-by: Zev Weiss Fixes: 4ef2774511dc ("hwmon: (nct6775) Convert register access to regmap API") Reported-by: Thomas Zajic Tested-by: Thomas Zajic Cc: stable@vger.kernel.org # v5.19+ --- drivers/hwmon/nct6775-core.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/drivers/hwmon/nct6775-core.c b/drivers/hwmon/nct6775-core.c index b5b81bd83bb1..d928eb8ae5a3 100644 --- a/drivers/hwmon/nct6775-core.c +++ b/drivers/hwmon/nct6775-core.c @@ -1614,17 +1614,21 @@ struct nct6775_data *nct6775_update_device(struct device *dev) data->fan_div[i]); if (data->has_fan_min & BIT(i)) { - err = nct6775_read_value(data, data->REG_FAN_MIN[i], ®); + u16 tmp; + + err = nct6775_read_value(data, data->REG_FAN_MIN[i], &tmp); if (err) goto out; - data->fan_min[i] = reg; + data->fan_min[i] = tmp; } if (data->REG_FAN_PULSES[i]) { - err = nct6775_read_value(data, data->REG_FAN_PULSES[i], ®); + u16 tmp; + + err = nct6775_read_value(data, data->REG_FAN_PULSES[i], &tmp); if (err) goto out; - data->fan_pulses[i] = (reg >> data->FAN_PULSE_SHIFT[i]) & 0x03; + data->fan_pulses[i] = (tmp >> data->FAN_PULSE_SHIFT[i]) & 0x03; } err = nct6775_select_fan_div(dev, data, i, reg); -- 2.42.0