[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250604203518.2330533-1-srinivas.pandruvada@linux.intel.com>
Date: Wed, 4 Jun 2025 13:35:17 -0700
From: Srinivas Pandruvada <srinivas.pandruvada@...ux.intel.com>
To: rui.zhang@...el.com,
daniel.lezcano@...aro.org,
rafael@...nel.org,
lukasz.luba@....com
Cc: linux-kernel@...r.kernel.org,
linux-pm@...r.kernel.org,
Srinivas Pandruvada <srinivas.pandruvada@...ux.intel.com>
Subject: [PATCH 1/2] thermal: intel: int340x: Add performance control for platform temperature control
Add additional attribute to control performance of platform temperature
control feature. Two attributes are added:
gain: 0-7 levels, with 0 being most aggressive.
7 – graceful, favors performance at the expense of temperature
overshoots
0 – aggressive, favors tight regulation over performance
min_performance_level: A value from 0-255. Specifies minimum Performance
level below which the there will be no throttling.
0 - all levels of throttling allowed including survivability
actions.
255 - no throttling allowed.
Signed-off-by: Srinivas Pandruvada <srinivas.pandruvada@...ux.intel.com>
---
Documentation/driver-api/thermal/intel_dptf.rst | 10 ++++++++++
.../platform_temperature_control.c | 15 ++++++++++++++-
2 files changed, 24 insertions(+), 1 deletion(-)
diff --git a/Documentation/driver-api/thermal/intel_dptf.rst b/Documentation/driver-api/thermal/intel_dptf.rst
index ec5769accae0..794f5cce548e 100644
--- a/Documentation/driver-api/thermal/intel_dptf.rst
+++ b/Documentation/driver-api/thermal/intel_dptf.rst
@@ -206,6 +206,16 @@ All these controls needs admin privilege to update.
Update a new temperature target in milli degree celsius for hardware to
use for the temperature control.
+``gain`` (RW)
+ A value in the range 0-7. Sets the aggressiveness of control loop.
+ 7 – graceful, favors performance at the expense of temperature overshoots.
+ 0 – aggressive, favors tight regulation over performance.
+
+``min_performance_level`` (RW)
+ Minimum Performance level below which the there will be no throttling.
+ 0 - all levels of throttling allowed including survivability actions.
+ 256 - no throttling allowed.
+
Given that this is platform temperature control, it is expected that a
single user-level manager owns and manages the controls. If multiple
user-level software applications attempt to write different targets, it
diff --git a/drivers/thermal/intel/int340x_thermal/platform_temperature_control.c b/drivers/thermal/intel/int340x_thermal/platform_temperature_control.c
index 2d6504514893..6cd05783a52d 100644
--- a/drivers/thermal/intel/int340x_thermal/platform_temperature_control.c
+++ b/drivers/thermal/intel/int340x_thermal/platform_temperature_control.c
@@ -49,7 +49,7 @@ struct mmio_reg {
};
#define MAX_ATTR_GROUP_NAME_LEN 32
-#define PTC_MAX_ATTRS 3
+#define PTC_MAX_ATTRS 5
struct ptc_data {
u32 offset;
@@ -57,6 +57,8 @@ struct ptc_data {
struct attribute *ptc_attrs[PTC_MAX_ATTRS];
struct device_attribute temperature_target_attr;
struct device_attribute enable_attr;
+ struct device_attribute gain_attr;
+ struct device_attribute min_performance_level_attr;
char group_name[MAX_ATTR_GROUP_NAME_LEN];
};
@@ -78,6 +80,8 @@ static u32 ptc_offsets[PTC_MAX_INSTANCES] = {0x5B20, 0x5B28, 0x5B30};
static const char * const ptc_strings[] = {
"temperature_target",
"enable",
+ "gain",
+ "min_performance_level",
NULL
};
@@ -177,6 +181,11 @@ PTC_SHOW(temperature_target);
PTC_STORE(temperature_target);
PTC_SHOW(enable);
PTC_STORE(enable);
+PTC_SHOW(gain);
+PTC_STORE(gain);
+PTC_SHOW(min_performance_level);
+PTC_STORE(min_performance_level);
+
#define ptc_init_attribute(_name)\
do {\
@@ -193,9 +202,13 @@ static int ptc_create_groups(struct pci_dev *pdev, int instance, struct ptc_data
ptc_init_attribute(temperature_target);
ptc_init_attribute(enable);
+ ptc_init_attribute(gain);
+ ptc_init_attribute(min_performance_level);
data->ptc_attrs[index++] = &data->temperature_target_attr.attr;
data->ptc_attrs[index++] = &data->enable_attr.attr;
+ data->ptc_attrs[index++] = &data->gain_attr.attr;
+ data->ptc_attrs[index++] = &data->min_performance_level_attr.attr;
data->ptc_attrs[index] = NULL;
snprintf(data->group_name, MAX_ATTR_GROUP_NAME_LEN,
--
2.49.0
Powered by blists - more mailing lists