Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp1139586ybt; Tue, 7 Jul 2020 08:36:59 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwz1dDYyDyYOji3UuHrNWCXoXDrU9ytVixZ7bcOLQesTVJwhjjudEGG996CY6f+QSWuYGVH X-Received: by 2002:a05:6402:542:: with SMTP id i2mr62366647edx.318.1594136219508; Tue, 07 Jul 2020 08:36:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594136219; cv=none; d=google.com; s=arc-20160816; b=O6e0SN9fxdcqk/HAQ840vqi/ag+NF7PE5oTIyjPg58f0egBklmRWYHWuWJ1xC+6q5/ aGw6ONRNP5u1zeTOfZn8fUcWvtxUk6k9bIjIeG0ejbLQ/1tMh2AkxXPNQhSDi2IwxQ4m itVC76WudzI8wJ5n73QGR0gItqBSuQ+DRalxHGGv1QjqsLe4RrO1EIK05EqCps1yonQz 8HgWCgkW9m42H6Pmi8dr2zlHeunhfUOOoiI5is7o2cHD1vLIkM0v380xQMYmWR7N2nyV JmMSf/FOjF/1KfOq5O7QNKdCym2m8mltrjleB8az/aU2HWYFNd+t3n94uj5QbtmdA1gy R73g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=9X5exGMiEeRFJvE3Cg7StJ3m0mONPZ7Q6PVjwvD+eiM=; b=LGAEAh6SnJwYDkdm4vpU3XiXcVaB88C+gqt0xwtkfXMx1UsK7+DaOOYUKv5KSAmtUa 133zf2P2dtSGCnrhbYa85T0SELoD4lgZoexsILSL3tvKOGkSSOXM8iVEA0FLvS/0Vcux pjJHyfV9u8Asg7FVRjrxqR9gAKaIwpgCbLw3EHJR/03VFlJSHdkynMMxnQWWDgVDPdb6 VkVdz2Wd5ekuvwJu/08+Fq+4MWM6RLP0lxD9I6wh0agRIkRYIDOKs7lJISI3QVac2Uty 1S/1RPKnLdhAvTxaPPltyWJJzx9VpwyVpR4mtZ4+Fs+OvVmQNM3uNybbaNXSH2rM4FAG 21ug== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=ar7FmcmY; 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 bc21si15797248edb.51.2020.07.07.08.36.36; Tue, 07 Jul 2020 08:36:59 -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=default header.b=ar7FmcmY; 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 S1728632AbgGGPei (ORCPT + 99 others); Tue, 7 Jul 2020 11:34:38 -0400 Received: from mail.kernel.org ([198.145.29.99]:58092 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728422AbgGGPSk (ORCPT ); Tue, 7 Jul 2020 11:18:40 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 6A2C320663; Tue, 7 Jul 2020 15:18:39 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1594135120; bh=xkymQXiS3eOpuljz4jMxRKZ+J/A6bYNQ4D/KVgyO4Z8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ar7FmcmYcrkQ8UQPPhVGDLohC/EA/lYvw1Ah2kCperHp879ZpjV8gD7JHidG/5xOj VIDy/D6TqnYSdG/dfGJnpJ0zW9m0+4U7pmUcGaO2/BW1QoImRmwTCgFeJukKiObC93 6b1drxb5keWsyO55A+Byvy8w8UFK0HijCFzyT12A= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Chu Lin , Guenter Roeck , Sasha Levin Subject: [PATCH 4.19 19/36] hwmon: (max6697) Make sure the OVERT mask is set correctly Date: Tue, 7 Jul 2020 17:17:11 +0200 Message-Id: <20200707145750.053560653@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200707145749.130272978@linuxfoundation.org> References: <20200707145749.130272978@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Chu Lin [ Upstream commit 016983d138cbe99a5c0aaae0103ee88f5300beb3 ] Per the datasheet for max6697, OVERT mask and ALERT mask are different. For example, the 7th bit of OVERT is the local channel but for alert mask, the 6th bit is the local channel. Therefore, we can't apply the same mask for both registers. In addition to that, the max6697 driver is supposed to be compatibale with different models. I manually went over all the listed chips and made sure all chip types have the same layout. Testing; mask value of 0x9 should map to 0x44 for ALERT and 0x84 for OVERT. I used iotool to read the reg value back to verify. I only tested this change on max6581. Reference: https://datasheets.maximintegrated.com/en/ds/MAX6581.pdf https://datasheets.maximintegrated.com/en/ds/MAX6697.pdf https://datasheets.maximintegrated.com/en/ds/MAX6699.pdf Signed-off-by: Chu Lin Fixes: 5372d2d71c46e ("hwmon: Driver for Maxim MAX6697 and compatibles") Signed-off-by: Guenter Roeck Signed-off-by: Sasha Levin --- drivers/hwmon/max6697.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/drivers/hwmon/max6697.c b/drivers/hwmon/max6697.c index 221fd14920576..6df28fe0577da 100644 --- a/drivers/hwmon/max6697.c +++ b/drivers/hwmon/max6697.c @@ -47,8 +47,9 @@ static const u8 MAX6697_REG_CRIT[] = { * Map device tree / platform data register bit map to chip bit map. * Applies to alert register and over-temperature register. */ -#define MAX6697_MAP_BITS(reg) ((((reg) & 0x7e) >> 1) | \ +#define MAX6697_ALERT_MAP_BITS(reg) ((((reg) & 0x7e) >> 1) | \ (((reg) & 0x01) << 6) | ((reg) & 0x80)) +#define MAX6697_OVERT_MAP_BITS(reg) (((reg) >> 1) | (((reg) & 0x01) << 7)) #define MAX6697_REG_STAT(n) (0x44 + (n)) @@ -587,12 +588,12 @@ static int max6697_init_chip(struct max6697_data *data, return ret; ret = i2c_smbus_write_byte_data(client, MAX6697_REG_ALERT_MASK, - MAX6697_MAP_BITS(pdata->alert_mask)); + MAX6697_ALERT_MAP_BITS(pdata->alert_mask)); if (ret < 0) return ret; ret = i2c_smbus_write_byte_data(client, MAX6697_REG_OVERT_MASK, - MAX6697_MAP_BITS(pdata->over_temperature_mask)); + MAX6697_OVERT_MAP_BITS(pdata->over_temperature_mask)); if (ret < 0) return ret; -- 2.25.1