diff options
author | danh-arm <dan.handley@arm.com> | 2016-05-11 10:56:25 +0100 |
---|---|---|
committer | danh-arm <dan.handley@arm.com> | 2016-05-11 10:56:25 +0100 |
commit | 789a6d492fe23866659b932e5e52187a3e611ee9 (patch) | |
tree | 04a5acbf780d1f77247c040e1af1ec9a2909127f | |
parent | 8fc835775b850446f021d1085f92adba6788e01c (diff) | |
parent | 80fb66b3e62f48c9ea55b14796bf7fcc3f3a869d (diff) |
Merge pull request #619 from sandrine-bailleux-arm/sb/rockchip-assertions
Rockchip: Add some debug assertions in the PMU driver
-rw-r--r-- | plat/rockchip/rk3368/drivers/pmu/pmu.c | 1 | ||||
-rw-r--r-- | plat/rockchip/rk3399/drivers/pmu/pmu.c | 4 |
2 files changed, 5 insertions, 0 deletions
diff --git a/plat/rockchip/rk3368/drivers/pmu/pmu.c b/plat/rockchip/rk3368/drivers/pmu/pmu.c index 50e2bf87..53d333b3 100644 --- a/plat/rockchip/rk3368/drivers/pmu/pmu.c +++ b/plat/rockchip/rk3368/drivers/pmu/pmu.c @@ -349,6 +349,7 @@ static int cores_pwr_domain_on(unsigned long mpidr, uint64_t entrypoint) cpus_id_power_domain(cluster, cpu, pmu_pd_off, CKECK_WFEI_MSK); cpuon_id = (cluster * PLATFORM_CLUSTER0_CORE_COUNT) + cpu; + assert(cpuon_id < PLATFORM_CORE_COUNT); assert(cpuson_flags[cpuon_id] == 0); cpuson_flags[cpuon_id] = PMU_CPU_HOTPLUG; cpuson_entry_point[cpuon_id] = entrypoint; diff --git a/plat/rockchip/rk3399/drivers/pmu/pmu.c b/plat/rockchip/rk3399/drivers/pmu/pmu.c index 1493a4dd..859e89f5 100644 --- a/plat/rockchip/rk3399/drivers/pmu/pmu.c +++ b/plat/rockchip/rk3399/drivers/pmu/pmu.c @@ -132,11 +132,13 @@ void plat_rockchip_pmusram_prepare(void) static inline uint32_t get_cpus_pwr_domain_cfg_info(uint32_t cpu_id) { + assert(cpu_id < PLATFORM_CORE_COUNT); return core_pm_cfg_info[cpu_id]; } static inline void set_cpus_pwr_domain_cfg_info(uint32_t cpu_id, uint32_t value) { + assert(cpu_id < PLATFORM_CORE_COUNT); core_pm_cfg_info[cpu_id] = value; #if !USE_COHERENT_MEM flush_dcache_range((uintptr_t)&core_pm_cfg_info[cpu_id], @@ -234,6 +236,7 @@ static int cores_pwr_domain_on(unsigned long mpidr, uint64_t entrypoint) { uint32_t cpu_id = plat_core_pos_by_mpidr(mpidr); + assert(cpu_id < PLATFORM_CORE_COUNT); assert(cpuson_flags[cpu_id] == 0); cpuson_flags[cpu_id] = PMU_CPU_HOTPLUG; cpuson_entry_point[cpu_id] = entrypoint; @@ -257,6 +260,7 @@ static int cores_pwr_domain_suspend(void) { uint32_t cpu_id = plat_my_core_pos(); + assert(cpu_id < PLATFORM_CORE_COUNT); assert(cpuson_flags[cpu_id] == 0); cpuson_flags[cpu_id] = PMU_CPU_AUTO_PWRDN; cpuson_entry_point[cpu_id] = (uintptr_t)psci_entrypoint; |