PSCI: Lookup list of parent nodes to lock only once
When acquiring or releasing the power domain locks for a given CPU the
parent nodes are looked up by walking the up the PD tree list on both the
acquire and release path, only one set of lookups is needed. Fetch the
parent nodes first and pass this list into both the acquire and release
functions to avoid the double lookup.

This also allows us to not have to do this lookup after coherency has
been exited during the core power down sequence. The shared struct
psci_cpu_pd_nodes is not placed in coherent memory like is done
for psci_non_cpu_pd_nodes and doing so would negatively affect
performance. With this patch we remove the need to have it in coherent
memory by moving the access out of psci_release_pwr_domain_locks().

Signed-off-by: Andrew F. Davis <afd@ti.com>
Change-Id: I7b9cfa9d31148dea0f5e21091c8b45ef7fe4c4ab
1 parent 0f95565 commit 74d27d006279753f2036b6d3ccfdc6c4357c96d8
@Andrew F. Davis Andrew F. Davis authored on 4 Jun 2019
Showing 4 changed files
View
lib/psci/psci_common.c
View
lib/psci/psci_off.c
View
lib/psci/psci_private.h
View
lib/psci/psci_suspend.c