Message ID | 5665899.DvuYhMxLoT@kreacher |
---|---|
Headers |
Return-Path: <linux-kernel-owner@vger.kernel.org> Delivered-To: ouuuleilei@gmail.com Received: by 2002:adf:eb09:0:0:0:0:0 with SMTP id s9csp322856wrn; Wed, 25 Jan 2023 07:07:47 -0800 (PST) X-Google-Smtp-Source: AMrXdXup9LQ+w3aUcgTEzKlt49Q9U33taLKGQMjvQv9ZtJdu3X9UIaKeWCJRU2+BpVks/cDoKPy4 X-Received: by 2002:a05:6402:28ca:b0:499:c294:77af with SMTP id ef10-20020a05640228ca00b00499c29477afmr34348733edb.12.1674659266854; Wed, 25 Jan 2023 07:07:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1674659266; cv=none; d=google.com; s=arc-20160816; b=wpmfEKw/G7bjiRFGPUu90zkeE7SmfW5hTxYdwyHTU86tWkhODvxP3SJgPa+izr6xGr CnNNdhFkEv3IdzOXwi9vIt/CgVilGbSv7P4RRKBqtuLti6MnhAjR8Kf21Ab/fizXLO1o DoLNVMIRvsuKV4j1vYaC8Jc8WfyIbVqw10dixkK4jmWuA991FHY2yeZKqja/1KDEDGxm kVMHHMs3H+7c7YiPYkns0AAigP1FHgzHOzSY6degQJXlxerna4m5bycTL5Ji0YQ8nK3A FJD6rRt7lWTYnMcJx1mVCFgWuE0HGdAXypVYrN874Izy/AMTRe7UbbSbvI0tRgwXcEnO nfKA== 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 :message-id:date:subject:cc:to:from; bh=2vsiOwQtVYq7dVBEv7GPXpicCg6rWi5j+iLtyCrMHfo=; b=dYlf58tu287oMsxtOiMr/neye9bQr+maESRvXlx6RZxFg1h5bxgtKJ9osotIaG5Z/i onxMyr0+eE38FVp8kYiiEzm5EWElxqKlG+Kdjgp6jbXb1i9TzVlKFPtWnguRT661p1kG Rbl8UP59dfFT1aba0xTiwbE3bA0AhJcg7w5ZKA+QikSJ7eypsHLN+ghc4ZY7c2UpNIan hoq4rMa2sMsUhDQyziApu+mlglFr9pzdqsEmlwmqDI4tLzcXRMWJYwzVSPzw5Ke7YV/z OE57L5D01pNskafya1HX+fwsAMYOin7SN1aPmSZ6TAgPXpHYkIVIOUHd5EdVf5UFtE5W 0BXQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id y20-20020a50ce14000000b0047aa75ad9a0si7047991edi.484.2023.01.25.07.07.20; Wed, 25 Jan 2023 07:07:46 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235943AbjAYOzy (ORCPT <rfc822;rust.linux@gmail.com> + 99 others); Wed, 25 Jan 2023 09:55:54 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55756 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235896AbjAYOzq (ORCPT <rfc822;linux-kernel@vger.kernel.org>); Wed, 25 Jan 2023 09:55:46 -0500 Received: from cloudserver094114.home.pl (cloudserver094114.home.pl [79.96.170.134]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E014159DC; Wed, 25 Jan 2023 06:55:42 -0800 (PST) Received: from localhost (127.0.0.1) (HELO v370.home.net.pl) by /usr/run/smtp (/usr/run/postfix/private/idea_relay_lmtp) via UNIX with SMTP (IdeaSmtpServer 5.1.0) id ff3293611b14e255; Wed, 25 Jan 2023 15:55:41 +0100 Received: from kreacher.localnet (unknown [213.134.163.149]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by v370.home.net.pl (Postfix) with ESMTPSA id 9F8BF2201948; Wed, 25 Jan 2023 15:55:40 +0100 (CET) From: "Rafael J. Wysocki" <rjw@rjwysocki.net> To: Linux PM <linux-pm@vger.kernel.org> Cc: LKML <linux-kernel@vger.kernel.org>, Linux ACPI <linux-acpi@vger.kernel.org>, Zhang Rui <rui.zhang@intel.com>, Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com>, Daniel Lezcano <daniel.lezcano@linaro.org> Subject: [PATCH v1 0/3] thermal: intel: int340x: Use generic trip points table Date: Wed, 25 Jan 2023 15:49:09 +0100 Message-ID: <5665899.DvuYhMxLoT@kreacher> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="UTF-8" X-CLIENT-IP: 213.134.163.149 X-CLIENT-HOSTNAME: 213.134.163.149 X-VADE-SPAMSTATE: clean X-VADE-SPAMCAUSE: gggruggvucftvghtrhhoucdtuddrgedvhedruddvvddgjedtucetufdoteggodetrfdotffvucfrrhhofhhilhgvmecujffqoffgrffnpdggtffipffknecuuegrihhlohhuthemucduhedtnecusecvtfgvtghiphhivghnthhsucdlqddutddtmdenucfjughrpefhvfevufffkfgggfgtsehtufertddttdejnecuhfhrohhmpedftfgrfhgrvghlucflrdcuhgihshhotghkihdfuceorhhjfiesrhhjfiihshhotghkihdrnhgvtheqnecuggftrfgrthhtvghrnhepgeffhfdujeelhfdtgeffkeetudfhtefhhfeiteethfekvefgvdfgfeeikeeigfehnecuffhomhgrihhnpehkvghrnhgvlhdrohhrghenucfkphepvddufedrudefgedrudeifedrudegleenucevlhhushhtvghrufhiiigvpedtnecurfgrrhgrmhepihhnvghtpedvudefrddufeegrdduieefrddugeelpdhhvghlohepkhhrvggrtghhvghrrdhlohgtrghlnhgvthdpmhgrihhlfhhrohhmpedftfgrfhgrvghlucflrdcuhgihshhotghkihdfuceorhhjfiesrhhjfiihshhotghkihdrnhgvtheqpdhnsggprhgtphhtthhopeeipdhrtghpthhtoheplhhinhhugidqphhmsehvghgvrhdrkhgvrhhnvghlrdhorhhgpdhrtghpthhtoheplhhinhhugidqkhgvrhhnvghlsehvghgvrhdrkhgvrhhnvghlrdhorhhgpdhrtghpthhtoheplhhinhhugidqrggtphhisehvghgvrhdrkhgvrhhnvghlrdhorhhgpdhrtghpthhtoheprhhuihdriihhrghn ghesihhnthgvlhdrtghomhdprhgtphhtthhopehsrhhinhhivhgrshdrphgrnhgurhhuvhgruggrsehlihhnuhigrdhinhhtvghlrdgtohhmpdhrtghpthhtohepuggrnhhivghlrdhlvgiitggrnhhosehlihhnrghrohdrohhrgh X-DCC--Metrics: v370.home.net.pl 1024; Body=6 Fuz1=6 Fuz2=6 X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_HELO_NONE, SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: <linux-kernel.vger.kernel.org> X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1756007515350751964?= X-GMAIL-MSGID: =?utf-8?q?1756007515350751964?= |
Series |
thermal: intel: int340x: Use generic trip points table
|
|
Message
Rafael J. Wysocki
Jan. 25, 2023, 2:49 p.m. UTC
Hi All, This series replaces the following patch: https://patchwork.kernel.org/project/linux-pm/patch/2147918.irdbgypaU6@kreacher/ but it has been almost completely rewritten, so I've dropped all tags from it. The most significant difference is that firmware-induced trip point updates are now handled in a less controversial manner (no renumbering, just temperature updates if applicable). Please refer to the individual patch changelogs for details. The series is on top of this patch: https://patchwork.kernel.org/project/linux-pm/patch/2688799.mvXUDI8C0e@kreacher/ which applies on top of the linux-next branch in linux-pm.git from today. Thanks!
Comments
Hi Srinivas, On Wed, Jan 25, 2023 at 3:55 PM Rafael J. Wysocki <rjw@rjwysocki.net> wrote: > > Hi All, > > This series replaces the following patch: > > https://patchwork.kernel.org/project/linux-pm/patch/2147918.irdbgypaU6@kreacher/ > > but it has been almost completely rewritten, so I've dropped all tags from it. > > The most significant difference is that firmware-induced trip point updates are > now handled in a less controversial manner (no renumbering, just temperature > updates if applicable). > > Please refer to the individual patch changelogs for details. > > The series is on top of this patch: > > https://patchwork.kernel.org/project/linux-pm/patch/2688799.mvXUDI8C0e@kreacher/ > > which applies on top of the linux-next branch in linux-pm.git from today. There are two additional branches in linux-pm.git: thermal-intel-fixes thermal-intel-testing The former is just fixes to go on top of 6.2-rc5 and the latter - this series on top of those and the current thermal-intel branch I have locally with the Intel thermal drivers changes for 6.3. I would appreciate giving each of them a go in your test setup. Cheers!
Hi Rafael, On Wed, 2023-01-25 at 16:20 +0100, Rafael J. Wysocki wrote: > Hi Srinivas, > > On Wed, Jan 25, 2023 at 3:55 PM Rafael J. Wysocki <rjw@rjwysocki.net> > wrote: > > > > Hi All, > > > > This series replaces the following patch: > > > > https://patchwork.kernel.org/project/linux-pm/patch/2147918.irdbgypaU6@kreacher/ > > > > but it has been almost completely rewritten, so I've dropped all > > tags from it. > > > > [...] > > The series is on top of this patch: > > > > https://patchwork.kernel.org/project/linux-pm/patch/2688799.mvXUDI8C0e@kreacher/ > > > > which applies on top of the linux-next branch in linux-pm.git from > > today. > > There are two additional branches in linux-pm.git: > > thermal-intel-fixes On two systems test, no issues are observed. > thermal-intel-testing branch: thermal-intel-test No issues, but number of trips are not same as invalid trips are not registered. Not sure if this is correct. At boot up they may be invalid, but firmware may update later (Not aware of such scenario). For example, the hot is not registered. Current: thermal_zone9/trip_point_0_type:critical thermal_zone9/trip_point_0_temp:125050 thermal_zone9/trip_point_0_hyst:0 thermal_zone9/trip_point_1_type:hot thermal_zone9/trip_point_1_temp:-273250 thermal_zone9/trip_point_1_hyst:0 thermal_zone9/trip_point_2_type:passive thermal_zone9/trip_point_2_temp:103050 thermal_zone9/trip_point_2_hyst:0 thermal_zone9/trip_point_3_type:active thermal_zone9/trip_point_3_temp:103050 thermal_zone9/trip_point_3_hyst:0 thermal_zone9/trip_point_4_type:active thermal_zone9/trip_point_4_temp:101050 thermal_zone9/trip_point_4_hyst:0 thermal_zone9/trip_point_5_type:active thermal_zone9/trip_point_5_temp:100050 thermal_zone9/trip_point_5_hyst:0 thermal_zone9/trip_point_6_type:active thermal_zone9/trip_point_6_temp:98550 thermal_zone9/trip_point_6_hyst:0 thermal_zone9/trip_point_7_type:active thermal_zone9/trip_point_7_temp:97050 thermal_zone9/trip_point_7_hyst:0 with 6.3-rc1 changes thermal_zone9/trip_point_0_type:critical thermal_zone9/trip_point_0_temp:125050 thermal_zone9/trip_point_0_hyst:0 thermal_zone9/trip_point_1_type:passive thermal_zone9/trip_point_1_temp:103050 thermal_zone9/trip_point_1_hyst:0 thermal_zone9/trip_point_2_type:active thermal_zone9/trip_point_2_temp:103050 thermal_zone9/trip_point_2_hyst:0 thermal_zone9/trip_point_3_type:active thermal_zone9/trip_point_3_temp:101050 thermal_zone9/trip_point_3_hyst:0 thermal_zone9/trip_point_4_type:active thermal_zone9/trip_point_4_temp:100050 thermal_zone9/trip_point_4_hyst:0 thermal_zone9/trip_point_5_type:active thermal_zone9/trip_point_5_temp:98550 thermal_zone9/trip_point_5_hyst:0 thermal_zone9/trip_point_6_hyst:0 thermal_zone9/trip_point_6_temp:97050 thermal_zone9/trip_point_6_type:active Thanks, Srinivas > > The former is just fixes to go on top of 6.2-rc5 and the latter - > this > series on top of those and the current thermal-intel branch I have > locally with the Intel thermal drivers changes for 6.3. > > I would appreciate giving each of them a go in your test setup. > > Cheers!
On Thursday, January 26, 2023 1:02:59 AM CET srinivas pandruvada wrote: > Hi Rafael, > > > On Wed, 2023-01-25 at 16:20 +0100, Rafael J. Wysocki wrote: > > Hi Srinivas, > > > > On Wed, Jan 25, 2023 at 3:55 PM Rafael J. Wysocki <rjw@rjwysocki.net> > > wrote: > > > > > > Hi All, > > > > > > This series replaces the following patch: > > > > > > https://patchwork.kernel.org/project/linux-pm/patch/2147918.irdbgypaU6@kreacher/ > > > > > > but it has been almost completely rewritten, so I've dropped all > > > tags from it. > > > > > > > > [...] > > > > The series is on top of this patch: > > > > > > https://patchwork.kernel.org/project/linux-pm/patch/2688799.mvXUDI8C0e@kreacher/ > > > > > > which applies on top of the linux-next branch in linux-pm.git from > > > today. > > > > There are two additional branches in linux-pm.git: > > > > thermal-intel-fixes > On two systems test, no issues are observed. Great! I'll move this to linux-next then. > > thermal-intel-testing > branch: thermal-intel-test > > No issues, but number of trips are not same as invalid trips are not > registered. > Not sure if this is correct. It may not be. At least it is a change in behavior that is not expected to happen after these changes. > At boot up they may be invalid, but > firmware may update later (Not aware of such scenario). > > For example, the hot is not registered. > > Current: > > thermal_zone9/trip_point_0_type:critical > thermal_zone9/trip_point_0_temp:125050 > thermal_zone9/trip_point_0_hyst:0 > > thermal_zone9/trip_point_1_type:hot > thermal_zone9/trip_point_1_temp:-273250 > thermal_zone9/trip_point_1_hyst:0 So this means that _HOT is evaluated successfully (or the trip point index would be negative), but it probably returned an invalid temperature (likely 0) that has been turned into an error by the temperature range check in the new ACPI helper introduced by the change. OK, thanks for testing! I've added the appended patch to the thermal-intel-test branch. Can you please check if it makes that difference in behavior go away? --- From: Rafael J. Wysocki <rafael.j.wysocki@intel.com> Subject: [PATCH] thermal: ACPI: Initialize trips if temperature is out of range In some cases it is still useful to register a trip point if the temperature returned by the corresponding ACPI thermal object (for example, _HOT) is invalid to start with, because the same ACPI thermal object may start to return a valid temperature after a system configuration change (for example, from an AC power source to battery an vice versa). For this reason, if the ACPI thermal object evaluated by thermal_acpi_trip_init() successfully returns a temperature value that is out of the range of values taken into account, initialize the trip point using THERMAL_TEMP_INVALID as the temperature value instead of returning an error to allow the user of the trip point to decide what to do with it. Also update pch_wpt_add_acpi_psv_trip() to reject trip points with invalid temperature values. Fixes: 7a0e39748861 ("thermal: ACPI: Add ACPI trip point routines") Reported-by: Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com> --- drivers/thermal/intel/intel_pch_thermal.c | 2 +- drivers/thermal/thermal_acpi.c | 7 ++++--- 2 files changed, 5 insertions(+), 4 deletions(-) Index: linux-pm/drivers/thermal/thermal_acpi.c =================================================================== --- linux-pm.orig/drivers/thermal/thermal_acpi.c +++ linux-pm/drivers/thermal/thermal_acpi.c @@ -64,13 +64,14 @@ static int thermal_acpi_trip_init(struct return -ENODATA; } - if (temp < TEMP_MIN_DECIK || temp >= TEMP_MAX_DECIK) { + if (temp >= TEMP_MIN_DECIK && temp <= TEMP_MAX_DECIK) { + trip->temperature = deci_kelvin_to_millicelsius(temp); + } else { acpi_handle_debug(adev->handle, "%s result %llu out of range\n", obj_name, temp); - return -ENODATA; + trip->temperature = THERMAL_TEMP_INVALID; } - trip->temperature = deci_kelvin_to_millicelsius(temp); trip->hysteresis = 0; trip->type = type; Index: linux-pm/drivers/thermal/intel/intel_pch_thermal.c =================================================================== --- linux-pm.orig/drivers/thermal/intel/intel_pch_thermal.c +++ linux-pm/drivers/thermal/intel/intel_pch_thermal.c @@ -107,7 +107,7 @@ static void pch_wpt_add_acpi_psv_trip(st return; ret = thermal_acpi_trip_passive(adev, &ptd->trips[*nr_trips]); - if (ret) + if (ret || ptd->trips[*nr_trips].temperature <= 0) return; ++(*nr_trips);
Hi Rafael, On Thu, 2023-01-26 at 14:13 +0100, Rafael J. Wysocki wrote: > On Thursday, January 26, 2023 1:02:59 AM CET srinivas pandruvada > wrote: > > Hi Rafael, > > > > > [...] > I've added the appended patch to the thermal-intel-test branch. Can > you please > check if it makes that difference in behavior go away? I synced the tree again and your patch in thermal-intel-test fixes the issue. Thanks, Srinivas > > --- > From: Rafael J. Wysocki <rafael.j.wysocki@intel.com> > Subject: [PATCH] thermal: ACPI: Initialize trips if temperature is > out of range > > In some cases it is still useful to register a trip point if the > temperature returned by the corresponding ACPI thermal object (for > example, _HOT) is invalid to start with, because the same ACPI > thermal object may start to return a valid temperature after a > system configuration change (for example, from an AC power source > to battery an vice versa). > > For this reason, if the ACPI thermal object evaluated by > thermal_acpi_trip_init() successfully returns a temperature value > that > is out of the range of values taken into account, initialize the trip > point using THERMAL_TEMP_INVALID as the temperature value instead of > returning an error to allow the user of the trip point to decide what > to do with it. > > Also update pch_wpt_add_acpi_psv_trip() to reject trip points with > invalid temperature values. > > Fixes: 7a0e39748861 ("thermal: ACPI: Add ACPI trip point routines") > Reported-by: Srinivas Pandruvada > <srinivas.pandruvada@linux.intel.com> > Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com> > --- > drivers/thermal/intel/intel_pch_thermal.c | 2 +- > drivers/thermal/thermal_acpi.c | 7 ++++--- > 2 files changed, 5 insertions(+), 4 deletions(-) > > Index: linux-pm/drivers/thermal/thermal_acpi.c > =================================================================== > --- linux-pm.orig/drivers/thermal/thermal_acpi.c > +++ linux-pm/drivers/thermal/thermal_acpi.c > @@ -64,13 +64,14 @@ static int thermal_acpi_trip_init(struct > return -ENODATA; > } > > - if (temp < TEMP_MIN_DECIK || temp >= TEMP_MAX_DECIK) { > + if (temp >= TEMP_MIN_DECIK && temp <= TEMP_MAX_DECIK) { > + trip->temperature = > deci_kelvin_to_millicelsius(temp); > + } else { > acpi_handle_debug(adev->handle, "%s result %llu out > of range\n", > obj_name, temp); > - return -ENODATA; > + trip->temperature = THERMAL_TEMP_INVALID; > } > > - trip->temperature = deci_kelvin_to_millicelsius(temp); > trip->hysteresis = 0; > trip->type = type; > > Index: linux-pm/drivers/thermal/intel/intel_pch_thermal.c > =================================================================== > --- linux-pm.orig/drivers/thermal/intel/intel_pch_thermal.c > +++ linux-pm/drivers/thermal/intel/intel_pch_thermal.c > @@ -107,7 +107,7 @@ static void pch_wpt_add_acpi_psv_trip(st > return; > > ret = thermal_acpi_trip_passive(adev, &ptd- > >trips[*nr_trips]); > - if (ret) > + if (ret || ptd->trips[*nr_trips].temperature <= 0) > return; > > ++(*nr_trips); > > >
Hi Srinivas, On Thu, Jan 26, 2023 at 6:17 PM srinivas pandruvada <srinivas.pandruvada@linux.intel.com> wrote: > > Hi Rafael, > > On Thu, 2023-01-26 at 14:13 +0100, Rafael J. Wysocki wrote: > > On Thursday, January 26, 2023 1:02:59 AM CET srinivas pandruvada > > wrote: > > > Hi Rafael, > > > > > > > > > > [...] > > > I've added the appended patch to the thermal-intel-test branch. Can > > you please > > check if it makes that difference in behavior go away? > I synced the tree again and your patch in thermal-intel-test fixes the > issue. Thanks a lot for testing and the confirmation! In the meantime, I've merged the thermal-intel-test into the bleeding-edge branch and if 0-day reports success with building it, I'll move the patches to linux-next. Cheers!