Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3526068pxf; Mon, 15 Mar 2021 11:30:51 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzyAiozRgl/FXPf8lbWbPgXkFQuWa5seLQKYA0jEjtnidA/ZfAs7xhmL9iar9FkB81z2mX7 X-Received: by 2002:a50:fe81:: with SMTP id d1mr6512062edt.308.1615833051449; Mon, 15 Mar 2021 11:30:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615833051; cv=none; d=google.com; s=arc-20160816; b=QMWsUqA1zM+HjK74nM8ZXIFZToxJ5Xk9yLV2se8Dnrn+KN3l0DNZHn8wgqHlp90Mzt tmzZGdIyUictaM3fwHIsQpMksETjXGSI66wIEE+pH6Zi3tjcT0NlDOQJWoBUa0n/1WJd 24hILPO3166PE2RREGrzhSsrnRV5H7xaTZ5Tz3almp02XJ3SDFG1po5Y8dG5ojjctopF tIM2fe3SacZ/QaufkghHlwrTTiSK1D6F/hjCOz2+bPIFNzaF8RByQ3Ey+jQcgKuNccf0 gYwwMeS+AhbT8J75XF+PK0qt8pzQzJ2gwIjNZbHTskLqtahbEZ5lFfRxwCuGivvgirXY h19g== 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=vBfy+AFjUJoFzhi5VWQD2X0ozSxEqM44TrhkxQ7Eftc=; b=VHNZAHMVfDnF1/SSjE0xFozhmqpP6CfgjwXibCqmHlVyixWm6n8QB4ClK1fj9SNYpF pchXRNFHJgblxwcyV3LrXz1DeZKfLUMHZL+tev6O0+1N7u/opYpuKtpZ9Rv48cKr1zd+ guzY34fvrQj+BiifdBr92hTZ42vQKjbor3f3SRE+evr+IiwoQDzXML7xVR9G6rU+EUqP ftxl+vZzcLelTVQdjo17L7vHjLfWBdVT6N7QgNWJTmOUP8P+Co+H/gldGLgKmnn+9dk9 9e6SSa2mBMJfv7pax3j5a7s3mTRR37lImJLH+ebRKDeueEd+ce1DmjI94N9LDFrl/ONG ZurQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="BEnzd/8E"; 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 p9si11630215edq.59.2021.03.15.11.30.28; Mon, 15 Mar 2021 11:30:51 -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="BEnzd/8E"; 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 S240304AbhCOOhb (ORCPT + 99 others); Mon, 15 Mar 2021 10:37:31 -0400 Received: from mail.kernel.org ([198.145.29.99]:37820 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231130AbhCOOBb (ORCPT ); Mon, 15 Mar 2021 10:01:31 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 5C18B64F89; Mon, 15 Mar 2021 14:01:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1615816862; bh=G5Ly4m8YQK16F/DM72YCVJVXhsPGh8FQM0w0iDYFpkg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=BEnzd/8E/1KQAcy4vsZAHCYhkjIiNaTZRczbSHjABRFr/UmJGLRqegbY2cNCgx0M8 YDTuM44/vN6evanvS+hHWpGKwbNt5PFvjZ5LjSpXPeswlFAC0Kd5krDyDL36w65qDb fN/t7md4ZMlonsF5zQKaowJ3uV6yfWg4m7m6J95s= From: gregkh@linuxfoundation.org To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Boyang Yu , Guenter Roeck , Paul Menzel Subject: [PATCH 4.19 116/120] hwmon: (lm90) Fix max6658 sporadic wrong temperature reading Date: Mon, 15 Mar 2021 14:57:47 +0100 Message-Id: <20210315135723.778813020@linuxfoundation.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210315135720.002213995@linuxfoundation.org> References: <20210315135720.002213995@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: Greg Kroah-Hartman From: Boyang Yu commit 62456189f3292c62f87aef363f204886dc1d4b48 upstream. max6658 may report unrealistically high temperature during the driver initialization, for which, its overtemp alarm pin also gets asserted. For certain devices implementing overtemp protection based on that pin, it may further trigger a reset to the device. By reproducing the problem, the wrong reading is found to be coincident with changing the conversion rate. To mitigate this issue, set the stop bit before changing the conversion rate and unset it thereafter. After such change, the wrong reading is not reproduced. Apply this change only to the max6657 kind for now, controlled by flag LM90_PAUSE_ON_CONFIG. Signed-off-by: Boyang Yu Signed-off-by: Guenter Roeck Cc: Paul Menzel Signed-off-by: Greg Kroah-Hartman --- drivers/hwmon/lm90.c | 42 ++++++++++++++++++++++++++++++++++++++---- 1 file changed, 38 insertions(+), 4 deletions(-) --- a/drivers/hwmon/lm90.c +++ b/drivers/hwmon/lm90.c @@ -187,6 +187,7 @@ enum chips { lm90, adm1032, lm99, lm86, #define LM90_HAVE_EMERGENCY_ALARM (1 << 5)/* emergency alarm */ #define LM90_HAVE_TEMP3 (1 << 6) /* 3rd temperature sensor */ #define LM90_HAVE_BROKEN_ALERT (1 << 7) /* Broken alert */ +#define LM90_PAUSE_FOR_CONFIG (1 << 8) /* Pause conversion for config */ /* LM90 status */ #define LM90_STATUS_LTHRM (1 << 0) /* local THERM limit tripped */ @@ -380,6 +381,7 @@ static const struct lm90_params lm90_par .reg_local_ext = MAX6657_REG_R_LOCAL_TEMPL, }, [max6657] = { + .flags = LM90_PAUSE_FOR_CONFIG, .alert_alarms = 0x7c, .max_convrate = 8, .reg_local_ext = MAX6657_REG_R_LOCAL_TEMPL, @@ -580,6 +582,38 @@ static inline int lm90_select_remote_cha return 0; } +static int lm90_write_convrate(struct i2c_client *client, + struct lm90_data *data, int val) +{ + int err; + int config_orig, config_stop; + + /* Save config and pause conversion */ + if (data->flags & LM90_PAUSE_FOR_CONFIG) { + config_orig = lm90_read_reg(client, LM90_REG_R_CONFIG1); + if (config_orig < 0) + return config_orig; + config_stop = config_orig | 0x40; + if (config_orig != config_stop) { + err = i2c_smbus_write_byte_data(client, + LM90_REG_W_CONFIG1, + config_stop); + if (err < 0) + return err; + } + } + + /* Set conv rate */ + err = i2c_smbus_write_byte_data(client, LM90_REG_W_CONVRATE, val); + + /* Revert change to config */ + if (data->flags & LM90_PAUSE_FOR_CONFIG && config_orig != config_stop) + i2c_smbus_write_byte_data(client, LM90_REG_W_CONFIG1, + config_orig); + + return err; +} + /* * Set conversion rate. * client->update_lock must be held when calling this function (unless we are @@ -600,7 +634,7 @@ static int lm90_set_convrate(struct i2c_ if (interval >= update_interval * 3 / 4) break; - err = i2c_smbus_write_byte_data(client, LM90_REG_W_CONVRATE, i); + err = lm90_write_convrate(client, data, i); data->update_interval = DIV_ROUND_CLOSEST(update_interval, 64); return err; } @@ -1606,8 +1640,7 @@ static void lm90_restore_conf(void *_dat struct i2c_client *client = data->client; /* Restore initial configuration */ - i2c_smbus_write_byte_data(client, LM90_REG_W_CONVRATE, - data->convrate_orig); + lm90_write_convrate(client, data, data->convrate_orig); i2c_smbus_write_byte_data(client, LM90_REG_W_CONFIG1, data->config_orig); } @@ -1624,12 +1657,13 @@ static int lm90_init_client(struct i2c_c /* * Start the conversions. */ - lm90_set_convrate(client, data, 500); /* 500ms; 2Hz conversion rate */ config = lm90_read_reg(client, LM90_REG_R_CONFIG1); if (config < 0) return config; data->config_orig = config; + lm90_set_convrate(client, data, 500); /* 500ms; 2Hz conversion rate */ + /* Check Temperature Range Select */ if (data->kind == adt7461 || data->kind == tmp451) { if (config & 0x04)