Hi Rafael, On 12/30/21 17:23, Rafael J. Wysocki wrote: > On Wed, Dec 22, 2021 at 8:14 PM Manfred Spraul wrote: >> cpu_has_cpufreq() stores a 'struct cpufreq_policy' on the stack. >> Unfortunately, with debugging options enabled, the structure can be >> larger than 1024 bytes, which causes a compiler warning/error. >> >> (actually observed: 1184 bytes). >> >> Therefore: Switch to cpufreq_cpu_get(). >> >> Signed-off-by: Manfred Spraul >> >> --- >> drivers/acpi/processor_thermal.c | 15 ++++++++++++--- >> 1 file changed, 12 insertions(+), 3 deletions(-) >> >> diff --git a/drivers/acpi/processor_thermal.c b/drivers/acpi/processor_thermal.c >> index a3d34e3f9f94..74210d63f62c 100644 >> --- a/drivers/acpi/processor_thermal.c >> +++ b/drivers/acpi/processor_thermal.c >> @@ -53,10 +53,19 @@ static int phys_package_first_cpu(int cpu) >> >> static int cpu_has_cpufreq(unsigned int cpu) >> { >> - struct cpufreq_policy policy; >> - if (!acpi_processor_cpufreq_init || cpufreq_get_policy(&policy, cpu)) >> + struct cpufreq_policy *policy; >> + int retval; > Why is this needed? You are right, this can be simplified. Updated patch is attached. >> + >> + if (!acpi_processor_cpufreq_init) >> return 0; >> - return 1; >> + >> + retval = 0; >> + policy = cpufreq_cpu_get(cpu); >> + if (policy) { >> + cpufreq_cpu_put(policy); > return 1; > >> + retval = 1; >> + } >> + return retval; > return 0; > >> } >> >> static int cpufreq_get_max_state(unsigned int cpu) >> -- >> 2.33.1 >>