Re: [PATCH v5] soc: samsung: exynos-pmu: Enable CPU Idle for gs101

From: Sudeep Holla
Date: Wed Jul 09 2025 - 12:13:16 EST


On Wed, Jul 09, 2025 at 02:26:27PM +0100, Peter Griffin wrote:
> Register cpu pm notifiers for gs101 which call the
> gs101_cpu_pmu_online/offline callbacks which in turn program the ACPM
> C2 hint. This hint is required to actually enter the C2 idle state.
>
> A couple of corner cases are handled, namely when the system is rebooting
> or suspending we ignore the request. Additionally the request is ignored if
> the CPU is in CPU hot plug. Some common code is refactored so that it can
> be called from both the CPU hot plug callbacks and CPU PM notifier taking
> into account that CPU PM notifiers are called with IRQs disabled whereas
> CPU hotplug callbacks are not.
>
> Additionally due to CPU PM notifiers using raw_spinlock the locking is
> updated to use raw_spinlock variants, this includes updating the pmu_regs
> regmap to use .use_raw_spinlock = true and additionally creating and
> registering a custom pmu-intr-gen regmap instead of using the regmap
> provided by syscon.
>
> Note: this patch has a runtime dependency on adding 'local-timer-stop' dt
> property to the CPU nodes. This informs the time framework to switch to a
> broadcast timer as the local timer will be shutdown. Without that DT
> property specified the system hangs in early boot with this patch applied.
>

Assuming this is arm64 platform and using PSCI for all the power management,
can you please briefly explain why all these dance is absolutely necessary
when PSCI calls can be the clue for the EL3 firmware. I am basing my question
on this information in the file:

/*
* CPU_INFORM register hint values which are used by
* EL3 firmware (el3mon).
*/

This clearly sounds like workaround for the firmware limitations. That
needs to be clearly documented IMO.

--
Regards,
Sudeep