Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp1132936ybt; Tue, 7 Jul 2020 08:29:18 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy0jXYHF4vjntQzoqdtlk62bnrpCUAcByC2ewMrmJBscwW4EpC/O90IGrsXzNnxZS2bzB/q X-Received: by 2002:a17:906:b354:: with SMTP id cd20mr44967342ejb.296.1594135758603; Tue, 07 Jul 2020 08:29:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594135758; cv=none; d=google.com; s=arc-20160816; b=mblIpRBTMeS0TU49LiKWjW3BoROm0c8rM6QEd/JkPAuILfrzxvQHO2+KdiBiK6LU8L HvOndxki9e0Y+kgIIKsEhkZXPIf8Kjjh6tacEPA8KRmqCJhmviytgiEQhJnqnikp+lAc ULCN8gruHt0r82uj1EeAq0Mor0ImB+Q45oMUJg7H8myoWSZXxlMbkt03quPyX52avANW zxwhmxw8DJtzZesuLU+dh2MfL1iXYrUVjl1T7rwhYV9ZgfusSNnrSoBYm8arh9yOziwI fUnTa0rYFSAsNmKwt5ARYIbK/bTRJBOe/3d5NfkUujv90Csfy2UcSru0EUZj3Gu+6cxv Oexw== 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=zWx5ZT56nZQRILEOysO0Mq9i90DH4hFPnY1KANjE5brPCdRGvVXNxZRzNeTIkvoxVR G+HowOqtt2vm5JEeQvE38Vhy9PFsXD0qHZzObLnB7Wq+xawU2y5AaMXrmvuezutnBDA6 +MmawRMY7bF5XQOc6w9DKugM6Yw+6FClMc/Vi+7EAXrlyj6fUc4n0i9paFEnYgomFqyx ueEoqs7t/5BXXmtMk7+vgsFG7+UNa2k/HBH/KG8Piw3+CdoAOpUHlGCZw2YqgLKuF8MF IvslLF+MknG6TrZDIPcuSxoTsDMknPSFZk3JxTl8jatzcjHT8oqb9j0V1ygVIDovqjNZ 2ZaQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=VwYzyzrg; 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 u18si15719270edx.489.2020.07.07.08.28.55; Tue, 07 Jul 2020 08:29:18 -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=VwYzyzrg; 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 S1730271AbgGGP0W (ORCPT + 99 others); Tue, 7 Jul 2020 11:26:22 -0400 Received: from mail.kernel.org ([198.145.29.99]:40456 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728500AbgGGP0O (ORCPT ); Tue, 7 Jul 2020 11:26:14 -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 09103206F6; Tue, 7 Jul 2020 15:26:12 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1594135573; bh=gZ3+xywpq6HFNvCTLfeu8PDvu8ayxT0YNwIo59vIrgo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=VwYzyzrgOhUl7ZGIOqJlgdCluA6YG/Dxe4ZzwmmKvygruSlY2fOAg25a0gCB/MqHV ROklfkrpfigfjdLbwto9QdbfxuneDOYxkSOnGvzEuhRFTTvEvPMGtzDENpAdj7riTR zTNw7mQltRsdReMA324ECMnhIaCCv/2YSOKG+PpA= 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.7 064/112] hwmon: (max6697) Make sure the OVERT mask is set correctly Date: Tue, 7 Jul 2020 17:17:09 +0200 Message-Id: <20200707145804.044514573@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200707145800.925304888@linuxfoundation.org> References: <20200707145800.925304888@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