Commit 325f29da authored by Rajendra Nayak's avatar Rajendra Nayak Committed by Nishanth Menon

ARM: OMAP5 / DRA7: PM: Avoid all SAR saves

Get rid of all assumptions about always having a sar base on *all*
OMAP4+ platforms. We dont need one on DRA7 and it is not necessary at
this point for OMAP5 either.
Signed-off-by: default avatarRajendra Nayak <rnayak@ti.com>
[nm@ti.com: Split and optimize]
Signed-off-by: default avatarNishanth Menon <nm@ti.com>
Reviewed-by: default avatarKevin Hilman <khilman@linaro.org>
Tested-by: default avatarKevin Hilman <khilman@linaro.org>
parent 6d846c46
...@@ -118,6 +118,7 @@ static inline void set_cpu_wakeup_addr(unsigned int cpu_id, u32 addr) ...@@ -118,6 +118,7 @@ static inline void set_cpu_wakeup_addr(unsigned int cpu_id, u32 addr)
{ {
struct omap4_cpu_pm_info *pm_info = &per_cpu(omap4_pm_info, cpu_id); struct omap4_cpu_pm_info *pm_info = &per_cpu(omap4_pm_info, cpu_id);
if (pm_info->wkup_sar_addr)
writel_relaxed(addr, pm_info->wkup_sar_addr); writel_relaxed(addr, pm_info->wkup_sar_addr);
} }
...@@ -143,6 +144,7 @@ static void scu_pwrst_prepare(unsigned int cpu_id, unsigned int cpu_state) ...@@ -143,6 +144,7 @@ static void scu_pwrst_prepare(unsigned int cpu_id, unsigned int cpu_state)
break; break;
} }
if (pm_info->scu_sar_addr)
writel_relaxed(scu_pwr_st, pm_info->scu_sar_addr); writel_relaxed(scu_pwr_st, pm_info->scu_sar_addr);
} }
...@@ -181,6 +183,7 @@ static void l2x0_pwrst_prepare(unsigned int cpu_id, unsigned int save_state) ...@@ -181,6 +183,7 @@ static void l2x0_pwrst_prepare(unsigned int cpu_id, unsigned int save_state)
{ {
struct omap4_cpu_pm_info *pm_info = &per_cpu(omap4_pm_info, cpu_id); struct omap4_cpu_pm_info *pm_info = &per_cpu(omap4_pm_info, cpu_id);
if (pm_info->l2x0_sar_addr)
writel_relaxed(save_state, pm_info->l2x0_sar_addr); writel_relaxed(save_state, pm_info->l2x0_sar_addr);
} }
...@@ -191,10 +194,14 @@ static void l2x0_pwrst_prepare(unsigned int cpu_id, unsigned int save_state) ...@@ -191,10 +194,14 @@ static void l2x0_pwrst_prepare(unsigned int cpu_id, unsigned int save_state)
#ifdef CONFIG_CACHE_L2X0 #ifdef CONFIG_CACHE_L2X0
static void __init save_l2x0_context(void) static void __init save_l2x0_context(void)
{ {
void __iomem *l2x0_base = omap4_get_l2cache_base();
if (l2x0_base && sar_base) {
writel_relaxed(l2x0_saved_regs.aux_ctrl, writel_relaxed(l2x0_saved_regs.aux_ctrl,
sar_base + L2X0_AUXCTRL_OFFSET); sar_base + L2X0_AUXCTRL_OFFSET);
writel_relaxed(l2x0_saved_regs.prefetch_ctrl, writel_relaxed(l2x0_saved_regs.prefetch_ctrl,
sar_base + L2X0_PREFETCH_CTRL_OFFSET); sar_base + L2X0_PREFETCH_CTRL_OFFSET);
}
} }
#else #else
static void __init save_l2x0_context(void) static void __init save_l2x0_context(void)
...@@ -347,13 +354,17 @@ int __init omap4_mpuss_init(void) ...@@ -347,13 +354,17 @@ int __init omap4_mpuss_init(void)
return -ENODEV; return -ENODEV;
} }
if (cpu_is_omap44xx())
sar_base = omap4_get_sar_ram_base(); sar_base = omap4_get_sar_ram_base();
/* Initilaise per CPU PM information */ /* Initilaise per CPU PM information */
pm_info = &per_cpu(omap4_pm_info, 0x0); pm_info = &per_cpu(omap4_pm_info, 0x0);
if (sar_base) {
pm_info->scu_sar_addr = sar_base + SCU_OFFSET0; pm_info->scu_sar_addr = sar_base + SCU_OFFSET0;
pm_info->wkup_sar_addr = sar_base + CPU0_WAKEUP_NS_PA_ADDR_OFFSET; pm_info->wkup_sar_addr = sar_base +
CPU0_WAKEUP_NS_PA_ADDR_OFFSET;
pm_info->l2x0_sar_addr = sar_base + L2X0_SAVE_OFFSET0; pm_info->l2x0_sar_addr = sar_base + L2X0_SAVE_OFFSET0;
}
pm_info->pwrdm = pwrdm_lookup("cpu0_pwrdm"); pm_info->pwrdm = pwrdm_lookup("cpu0_pwrdm");
if (!pm_info->pwrdm) { if (!pm_info->pwrdm) {
pr_err("Lookup failed for CPU0 pwrdm\n"); pr_err("Lookup failed for CPU0 pwrdm\n");
...@@ -368,9 +379,12 @@ int __init omap4_mpuss_init(void) ...@@ -368,9 +379,12 @@ int __init omap4_mpuss_init(void)
pwrdm_set_next_pwrst(pm_info->pwrdm, PWRDM_POWER_ON); pwrdm_set_next_pwrst(pm_info->pwrdm, PWRDM_POWER_ON);
pm_info = &per_cpu(omap4_pm_info, 0x1); pm_info = &per_cpu(omap4_pm_info, 0x1);
if (sar_base) {
pm_info->scu_sar_addr = sar_base + SCU_OFFSET1; pm_info->scu_sar_addr = sar_base + SCU_OFFSET1;
pm_info->wkup_sar_addr = sar_base + CPU1_WAKEUP_NS_PA_ADDR_OFFSET; pm_info->wkup_sar_addr = sar_base +
CPU1_WAKEUP_NS_PA_ADDR_OFFSET;
pm_info->l2x0_sar_addr = sar_base + L2X0_SAVE_OFFSET1; pm_info->l2x0_sar_addr = sar_base + L2X0_SAVE_OFFSET1;
}
if (cpu_is_omap446x()) if (cpu_is_omap446x())
pm_info->secondary_startup = omap4460_secondary_startup; pm_info->secondary_startup = omap4460_secondary_startup;
else else
...@@ -397,13 +411,12 @@ int __init omap4_mpuss_init(void) ...@@ -397,13 +411,12 @@ int __init omap4_mpuss_init(void)
pwrdm_clear_all_prev_pwrst(mpuss_pd); pwrdm_clear_all_prev_pwrst(mpuss_pd);
mpuss_clear_prev_logic_pwrst(); mpuss_clear_prev_logic_pwrst();
if (sar_base) {
/* Save device type on scratchpad for low level code to use */ /* Save device type on scratchpad for low level code to use */
if (omap_type() != OMAP2_DEVICE_TYPE_GP) writel_relaxed((omap_type() != OMAP2_DEVICE_TYPE_GP) ? 1 : 0,
writel_relaxed(1, sar_base + OMAP_TYPE_OFFSET); sar_base + OMAP_TYPE_OFFSET);
else
writel_relaxed(0, sar_base + OMAP_TYPE_OFFSET);
save_l2x0_context(); save_l2x0_context();
}
if (cpu_is_omap44xx()) { if (cpu_is_omap44xx()) {
omap_pm_ops.finish_suspend = omap4_finish_suspend; omap_pm_ops.finish_suspend = omap4_finish_suspend;
......
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