[<prev] [next>] [day] [month] [year] [list]
Message-Id: <20250620110933.3364359-1-arnd@kernel.org>
Date: Fri, 20 Jun 2025 13:09:28 +0200
From: Arnd Bergmann <arnd@...nel.org>
To: Suzuki K Poulose <suzuki.poulose@....com>,
Alexander Shishkin <alexander.shishkin@...ux.intel.com>,
Leo Yan <leo.yan@...ux.dev>,
Mathieu Poirier <mathieu.poirier@...aro.org>,
Greg Kroah-Hartman <gregkh@...uxfoundation.org>
Cc: Arnd Bergmann <arnd@...db.de>,
Mike Leach <mike.leach@...aro.org>,
James Clark <james.clark@...aro.org>,
Junhao He <hejunhao3@...wei.com>,
coresight@...ts.linaro.org,
linux-arm-kernel@...ts.infradead.org,
linux-kernel@...r.kernel.org
Subject: [PATCH] coresight: fix building with CONFIG_CPUMASK_OFFSTACK
From: Arnd Bergmann <arnd@...db.de>
Building with a ridiculous CONFIG_NR_CPUS shows that this function
fails to build because of incorrectly moving the mask offstack:
drivers/hwtracing/coresight/coresight-cpu-debug.c: In function ‘debug_enable_func’:
drivers/hwtracing/coresight/coresight-cpu-debug.c:452:1: error: the frame size of 8528 bytes is larger than 1536 bytes [-Werror=frame-larger-than=]
Use the recommended interface instead.
Fixes: 2227b7c74634 ("coresight: add support for CPU debug module")
Signed-off-by: Arnd Bergmann <arnd@...db.de>
---
drivers/hwtracing/coresight/coresight-cpu-debug.c | 13 +++++++++----
1 file changed, 9 insertions(+), 4 deletions(-)
diff --git a/drivers/hwtracing/coresight/coresight-cpu-debug.c b/drivers/hwtracing/coresight/coresight-cpu-debug.c
index a871d997330b..6ecd8e755ef3 100644
--- a/drivers/hwtracing/coresight/coresight-cpu-debug.c
+++ b/drivers/hwtracing/coresight/coresight-cpu-debug.c
@@ -416,13 +416,16 @@ static int debug_enable_func(void)
{
struct debug_drvdata *drvdata;
int cpu, ret = 0;
- cpumask_t mask;
+ cpumask_var_t mask;
+
+ if (!alloc_cpumask_var(&mask, GFP_KERNEL))
+ return -ENOMEM;
/*
* Use cpumask to track which debug power domains have
* been powered on and use it to handle failure case.
*/
- cpumask_clear(&mask);
+ cpumask_clear(mask);
for_each_possible_cpu(cpu) {
drvdata = per_cpu(debug_drvdata, cpu);
@@ -433,9 +436,10 @@ static int debug_enable_func(void)
if (ret < 0)
goto err;
else
- cpumask_set_cpu(cpu, &mask);
+ cpumask_set_cpu(cpu, mask);
}
+ free_cpumask_var(mask);
return 0;
err:
@@ -443,11 +447,12 @@ static int debug_enable_func(void)
* If pm_runtime_get_sync() has failed, need rollback on
* all the other CPUs that have been enabled before that.
*/
- for_each_cpu(cpu, &mask) {
+ for_each_cpu(cpu, mask) {
drvdata = per_cpu(debug_drvdata, cpu);
pm_runtime_put_noidle(drvdata->dev);
}
+ free_cpumask_var(mask);
return ret;
}
--
2.39.5
Powered by blists - more mailing lists