cpuidle: psci: Fail cpuidle registration if set OSI mode failed

Currently we allow the cpuidle driver registration to succeed, even if we
failed to enable the OSI mode when the hierarchical DT layout is used. This
means running in a degraded mode, by using the available idle states per
CPU, while also preventing the domain idle states.

Moving forward, this behaviour looks quite questionable to maintain, as
complexity seems to grow around it, especially when trying to add support
for deferred probe, for example.

Therefore, let's make the cpuidle driver registration to fail in this
situation, thus relying on the default architectural cpuidle backend for
WFI to be used.

Reviewed-by: Lina Iyer <ilina@codeaurora.org>
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
This commit is contained in:
Ulf Hansson 2020-07-07 14:58:01 +02:00 committed by Rafael J. Wysocki
parent 0317561912
commit 4b072cd6ac

View File

@ -26,7 +26,6 @@ struct psci_pd_provider {
}; };
static LIST_HEAD(psci_pd_providers); static LIST_HEAD(psci_pd_providers);
static bool osi_mode_enabled __initdata;
static int psci_pd_power_off(struct generic_pm_domain *pd) static int psci_pd_power_off(struct generic_pm_domain *pd)
{ {
@ -272,7 +271,6 @@ static int __init psci_idle_init_domains(void)
goto remove_pd; goto remove_pd;
} }
osi_mode_enabled = true;
of_node_put(np); of_node_put(np);
pr_info("Initialized CPU PM domain topology\n"); pr_info("Initialized CPU PM domain topology\n");
return pd_count; return pd_count;
@ -293,9 +291,6 @@ struct device __init *psci_dt_attach_cpu(int cpu)
{ {
struct device *dev; struct device *dev;
if (!osi_mode_enabled)
return NULL;
dev = dev_pm_domain_attach_by_name(get_cpu_device(cpu), "psci"); dev = dev_pm_domain_attach_by_name(get_cpu_device(cpu), "psci");
if (IS_ERR_OR_NULL(dev)) if (IS_ERR_OR_NULL(dev))
return dev; return dev;