Commit f996a5f7 authored by Andrew F. Davis's avatar Andrew F. Davis
Browse files

PSCI: Do not flush cache when unneeded



When a platform enables its caches before it accesses the
psci_non_cpu_pd_nodes structure then explicit cache maintenance
is not needed.
Signed-off-by: default avatarAndrew F. Davis <afd@ti.com>
parent c98db6c6
...@@ -267,7 +267,7 @@ static plat_local_state_t *psci_get_req_local_pwr_states(unsigned int pwrlvl, ...@@ -267,7 +267,7 @@ static plat_local_state_t *psci_get_req_local_pwr_states(unsigned int pwrlvl,
static plat_local_state_t get_non_cpu_pd_node_local_state( static plat_local_state_t get_non_cpu_pd_node_local_state(
unsigned int parent_idx) unsigned int parent_idx)
{ {
#if !(USE_COHERENT_MEM || HW_ASSISTED_COHERENCY) #if !(USE_COHERENT_MEM || HW_ASSISTED_COHERENCY || WARMBOOT_ENABLE_DCACHE_EARLY)
flush_dcache_range( flush_dcache_range(
(uintptr_t) &psci_non_cpu_pd_nodes[parent_idx], (uintptr_t) &psci_non_cpu_pd_nodes[parent_idx],
sizeof(psci_non_cpu_pd_nodes[parent_idx])); sizeof(psci_non_cpu_pd_nodes[parent_idx]));
...@@ -283,7 +283,7 @@ static void set_non_cpu_pd_node_local_state(unsigned int parent_idx, ...@@ -283,7 +283,7 @@ static void set_non_cpu_pd_node_local_state(unsigned int parent_idx,
plat_local_state_t state) plat_local_state_t state)
{ {
psci_non_cpu_pd_nodes[parent_idx].local_state = state; psci_non_cpu_pd_nodes[parent_idx].local_state = state;
#if !(USE_COHERENT_MEM || HW_ASSISTED_COHERENCY) #if !(USE_COHERENT_MEM || HW_ASSISTED_COHERENCY || WARMBOOT_ENABLE_DCACHE_EARLY)
flush_dcache_range( flush_dcache_range(
(uintptr_t) &psci_non_cpu_pd_nodes[parent_idx], (uintptr_t) &psci_non_cpu_pd_nodes[parent_idx],
sizeof(psci_non_cpu_pd_nodes[parent_idx])); sizeof(psci_non_cpu_pd_nodes[parent_idx]));
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment