Received: by 2002:a05:6a10:a852:0:0:0:0 with SMTP id d18csp494406pxy; Wed, 5 May 2021 07:12:31 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx2kNxtdE3+GkbQDtPoNccYO5IZct7ttUUwVSCsUfWTUT2lO0cXXR4oZ2N6vL7PeLVDwRW0 X-Received: by 2002:a17:90a:de17:: with SMTP id m23mr34798224pjv.16.1620223951064; Wed, 05 May 2021 07:12:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620223951; cv=none; d=google.com; s=arc-20160816; b=Zq4/69QvR9ZxqzGtIgJxyoe3E23nsVXzz5ozPal1Br8zh7quvUHYuAN3LxdRRJny+k hcWRGFn8eg8UTMj8i1Yu6X0yMXbtQNVe0w7c1QqHYgQt65L6ZIgweA5IOsS2PqiNgYyu KbaypUxHgWNcOGybIeqzey6iZc3hRf5uyN8hMeiFggYZNc/Y5gyhB1lsf4rVNVMmhh55 v+ptnxo5cWuVC0RsvZ918VehQb7974kR+UtLOzO92mKQ4iDalr/TfLbYWGiMfcoCe+om 2fh8ITK/fZwYqw3k7aTHhAVwy31b1gd3E0NpvzUzuD3gcS8MeDQCR3mRryROa689o/AL OWEw== 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=ZHlNShXZRV7EklRA/9Tg1HgXcs9YNa6XPY0cbr67h84=; b=L1zdq1LU8ej/l6G3v80LFwmoyIISuFOLHPGHrWPreVIscHRi4orgN+kuSTK5x4/exh mC1p7W9FshchYhvS/uLjeeCUYadeykK+YbEWO6srShlvgxdd0f1imJP9WskaAG+0ha3W 2hDSlvvTNhzVfCwpqA45r6cPtNsx9KZfgPyAxxHLCkNF0oTvAe8YvVXmjdb75/cwDfti xTxjO3F6ifOiL+2Ln+tfPULzG3HFGAZ03LSfE1YSa2eboVLhAv/TOzW7WWPUonhOkXqB xQ9MxQHH7uMKCqlQavuKo+wYIKVKkW26ZaJ6KFsPfSCAHzTh3RJJkX7zrFVnbTC2aq0z F+Vg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=nZWJqJCL; 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 v12si7158315pju.83.2021.05.05.07.12.09; Wed, 05 May 2021 07:12:31 -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=nZWJqJCL; 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 S234027AbhEEMOl (ORCPT + 99 others); Wed, 5 May 2021 08:14:41 -0400 Received: from mail.kernel.org ([198.145.29.99]:48308 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233299AbhEEMKe (ORCPT ); Wed, 5 May 2021 08:10:34 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 8189C613F3; Wed, 5 May 2021 12:09:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620216562; bh=iYnhpWZVYHdO4upwoPcSOtF+UPjCwydCeOm4QV8fhLg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=nZWJqJCLHlPLz+aMwYDAC9uB8hOO/z86YDMFOCysRRxZ4O7PPNmvldWlS6RyylLYD 1SDZOoeqKXIWMdzN+kBnNzW3vmeX1SVK0ONsVM3v2FDQ14JWdwXYDQ2zXTQ31ijn54 Ia1CjQ8EsByaExdS51sFttO1rtE/NwuCGhmU5cZA= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Mark Pearson , Hans de Goede Subject: [PATCH 5.11 30/31] platform/x86: thinkpad_acpi: Correct thermal sensor allocation Date: Wed, 5 May 2021 14:06:19 +0200 Message-Id: <20210505112327.661995664@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210505112326.672439569@linuxfoundation.org> References: <20210505112326.672439569@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: Mark Pearson commit 6759e18e5cd8745a5dfc5726e4a3db5281ec1639 upstream. On recent Thinkpad platforms it was reported that temp sensor 11 was always incorrectly displaying 66C. It turns out the reason for this is that this location in EC RAM is not a temperature sensor but is the power supply ID (offset 0xC2). Based on feedback from the Lenovo firmware team the EC RAM version can be determined and for the current version (3) only the 0x78 to 0x7F range is used for temp sensors. I don't have any details for earlier versions so I have left the implementation unaltered there. Note - in this block only 0x78 and 0x79 are officially designated (CPU & GPU sensors). The use of the other locations in the block will vary from platform to platform; but the existing logic to detect a sensor presence holds. Signed-off-by: Mark Pearson Link: https://lore.kernel.org/r/20210407212015.298222-1-markpearson@lenovo.com Reviewed-by: Hans de Goede Signed-off-by: Hans de Goede Signed-off-by: Greg Kroah-Hartman --- drivers/platform/x86/thinkpad_acpi.c | 31 ++++++++++++++++++++++--------- 1 file changed, 22 insertions(+), 9 deletions(-) --- a/drivers/platform/x86/thinkpad_acpi.c +++ b/drivers/platform/x86/thinkpad_acpi.c @@ -6259,6 +6259,7 @@ enum thermal_access_mode { enum { /* TPACPI_THERMAL_TPEC_* */ TP_EC_THERMAL_TMP0 = 0x78, /* ACPI EC regs TMP 0..7 */ TP_EC_THERMAL_TMP8 = 0xC0, /* ACPI EC regs TMP 8..15 */ + TP_EC_FUNCREV = 0xEF, /* ACPI EC Functional revision */ TP_EC_THERMAL_TMP_NA = -128, /* ACPI EC sensor not available */ TPACPI_THERMAL_SENSOR_NA = -128000, /* Sensor not available */ @@ -6457,7 +6458,7 @@ static const struct attribute_group ther static int __init thermal_init(struct ibm_init_struct *iibm) { - u8 t, ta1, ta2; + u8 t, ta1, ta2, ver = 0; int i; int acpi_tmp7; int res; @@ -6472,7 +6473,14 @@ static int __init thermal_init(struct ib * 0x78-0x7F, 0xC0-0xC7. Registers return 0x00 for * non-implemented, thermal sensors return 0x80 when * not available + * The above rule is unfortunately flawed. This has been seen with + * 0xC2 (power supply ID) causing thermal control problems. + * The EC version can be determined by offset 0xEF and at least for + * version 3 the Lenovo firmware team confirmed that registers 0xC0-0xC7 + * are not thermal registers. */ + if (!acpi_ec_read(TP_EC_FUNCREV, &ver)) + pr_warn("Thinkpad ACPI EC unable to access EC version\n"); ta1 = ta2 = 0; for (i = 0; i < 8; i++) { @@ -6482,11 +6490,13 @@ static int __init thermal_init(struct ib ta1 = 0; break; } - if (acpi_ec_read(TP_EC_THERMAL_TMP8 + i, &t)) { - ta2 |= t; - } else { - ta1 = 0; - break; + if (ver < 3) { + if (acpi_ec_read(TP_EC_THERMAL_TMP8 + i, &t)) { + ta2 |= t; + } else { + ta1 = 0; + break; + } } } if (ta1 == 0) { @@ -6499,9 +6509,12 @@ static int __init thermal_init(struct ib thermal_read_mode = TPACPI_THERMAL_NONE; } } else { - thermal_read_mode = - (ta2 != 0) ? - TPACPI_THERMAL_TPEC_16 : TPACPI_THERMAL_TPEC_8; + if (ver >= 3) + thermal_read_mode = TPACPI_THERMAL_TPEC_8; + else + thermal_read_mode = + (ta2 != 0) ? + TPACPI_THERMAL_TPEC_16 : TPACPI_THERMAL_TPEC_8; } } else if (acpi_tmp7) { if (tpacpi_is_ibm() &&