ARM: mvebu: prepare mvebu_pm_store_bootinfo() to support multiple SoCs
As we are going to introduce support for Armada 38x in pm.c, split out the Armada XP part of mvebu_pm_store_bootinfo() into mvebu_pm_store_armadaxp_bootinfo(), and make the former retunr an error when an unsupported SoC is used. Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> Acked-by: Gregory CLEMENT <gregory.clement@free-electrons.com> Signed-off-by: Gregory CLEMENT <gregory.clement@free-electrons.com>
This commit is contained in:
parent
a101b53d3a
commit
88ed69f2a1
|
@ -105,12 +105,10 @@ static phys_addr_t mvebu_internal_reg_base(void)
|
||||||
return of_translate_address(np, in_addr);
|
return of_translate_address(np, in_addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void mvebu_pm_store_bootinfo(void)
|
static void mvebu_pm_store_armadaxp_bootinfo(u32 *store_addr)
|
||||||
{
|
{
|
||||||
u32 *store_addr;
|
|
||||||
phys_addr_t resume_pc;
|
phys_addr_t resume_pc;
|
||||||
|
|
||||||
store_addr = phys_to_virt(BOOT_INFO_ADDR);
|
|
||||||
resume_pc = virt_to_phys(armada_370_xp_cpu_resume);
|
resume_pc = virt_to_phys(armada_370_xp_cpu_resume);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -151,14 +149,33 @@ static void mvebu_pm_store_bootinfo(void)
|
||||||
writel(BOOT_MAGIC_LIST_END, store_addr);
|
writel(BOOT_MAGIC_LIST_END, store_addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int mvebu_pm_store_bootinfo(void)
|
||||||
|
{
|
||||||
|
u32 *store_addr;
|
||||||
|
|
||||||
|
store_addr = phys_to_virt(BOOT_INFO_ADDR);
|
||||||
|
|
||||||
|
if (of_machine_is_compatible("marvell,armadaxp"))
|
||||||
|
mvebu_pm_store_armadaxp_bootinfo(store_addr);
|
||||||
|
else
|
||||||
|
return -ENODEV;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int mvebu_pm_enter(suspend_state_t state)
|
static int mvebu_pm_enter(suspend_state_t state)
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
if (state != PM_SUSPEND_MEM)
|
if (state != PM_SUSPEND_MEM)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
|
ret = mvebu_pm_store_bootinfo();
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
cpu_pm_enter();
|
cpu_pm_enter();
|
||||||
|
|
||||||
mvebu_pm_store_bootinfo();
|
|
||||||
cpu_suspend(0, mvebu_pm_powerdown);
|
cpu_suspend(0, mvebu_pm_powerdown);
|
||||||
|
|
||||||
outer_resume();
|
outer_resume();
|
||||||
|
|
Loading…
Reference in New Issue