Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp1136832ybt; Tue, 7 Jul 2020 08:33:46 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw4x2AfV9UWRDCVb550O0G8dBNYXCoFDHAMPxq5vdw6HobikXig+hC/oYaV8lLR3DyoTDZQ X-Received: by 2002:a17:906:4c48:: with SMTP id d8mr45409117ejw.331.1594136026332; Tue, 07 Jul 2020 08:33:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594136026; cv=none; d=google.com; s=arc-20160816; b=DFb47/SQSZ78Y9vu/imoE9V7YMW1ZnKKqc8NhFGsgizHqVMO18fgtK1pQkNJk4nAQv TZ70mwEWgdvTIqcMXoErV2eUFS3NkOnsQukcR4ibFHj2/g0u8Rf7xhpcQvTsTv50x55z OWOK8wE2J1BTrpCgsLTiydsKJmtafxSDiQo8wgYWw0jbRUDnZv7LxApWGBHrcKinEWgO /EFwntbZW7Sj7P7TbN0/dMTTwY27pv0FHYMDUhfUHJ5SmPF/hzla75JdW3rLwe8pI9Pr wD/ZFHfc/BSY+vYJfhjhvz0519C4pw4Zer1U8HKaFbAcB0I7gibFuaj1QsQX+rl2vRDj rxvg== 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=di4eCeeuSrZDTHw0SyjysT63OAZRWtgb4S+Zjp6C1ug=; b=lr3Uo0y62uoZyxHsMhnEPvULCmq2K3fWl84VLBaA4sPngjb4+1uirZGCGS7NsWcNVc da2jr9krXIbcfVxh/KKTTUb34jfmsQ1mMJMNDlU4I+BXkFh0MBQBOAo/VcQkKb2bytpR tupSBj5qPzx9J7buEGUv8icwgLGaVJH7hItTvhlPwiOTwOU4iWuN8giBpZ4myq2Rcf5F vW8NQkbQgBnGtg4HvvAqxgGxBT1XED9MUzlTl/E4Pl3QvvvptLz2/UnN+K4Qf9YhWxep C/SzQX7KseWfPTu9LK4zvC3NI7m5FBA9h+RC5lbQ8BZeRQdAPzYlbVLEVcrNpwTCaJUC Nc2A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=a397CYXU; 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 zp8si13361416ejb.255.2020.07.07.08.33.22; Tue, 07 Jul 2020 08:33:46 -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=a397CYXU; 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 S1729591AbgGGPUu (ORCPT + 99 others); Tue, 7 Jul 2020 11:20:50 -0400 Received: from mail.kernel.org ([198.145.29.99]:60948 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728645AbgGGPUq (ORCPT ); Tue, 7 Jul 2020 11:20:46 -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 D988E20663; Tue, 7 Jul 2020 15:20:44 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1594135245; bh=gZ3+xywpq6HFNvCTLfeu8PDvu8ayxT0YNwIo59vIrgo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=a397CYXU+ZMyxzgeCQ0xUd/CzEK1mPxktUbM7AIedUdn6s4PU38zHImiLUHffu9Dy G2QpZgYwLubKNpFsxD1+rGXoFhNyLopH/EMb1lr9bHOjHJWiFgtMUazuTfXgn/AyOC +klTSKlmKUp4vqsDz9MhOWzgnAif/0mgYOCTDxRc= 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 5.4 30/65] hwmon: (max6697) Make sure the OVERT mask is set correctly Date: Tue, 7 Jul 2020 17:17:09 +0200 Message-Id: <20200707145753.931334575@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200707145752.417212219@linuxfoundation.org> References: <20200707145752.417212219@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 743752a2467a2..64122eb38060d 100644 --- a/drivers/hwmon/max6697.c +++ b/drivers/hwmon/max6697.c @@ -38,8 +38,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)) @@ -562,12 +563,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