Commit d364eecf authored by Andrew Lunn's avatar Andrew Lunn Committed by Jason Cooper

ARM: kirkwood: ioremap memory control register

To allow removal of the global map of registers, make the pm code
ioremap the registers it needs.
Signed-off-by: default avatarAndrew Lunn <andrew@lunn.ch>
Acked-by: default avatarArnd Bergmann <arnd@arndb.de>
Acked-by: default avatarEzequiel Garcia <ezequiel.garcia@free-electrons.com>
Tested-by: default avatarJason Gunthorpe <jgunthorpe@obsidianresearch.com>
Signed-off-by: default avatarJason Cooper <jason@lakedaemon.net>
parent 7f28fd6e
...@@ -80,5 +80,6 @@ ...@@ -80,5 +80,6 @@
#define CGC_RESERVED (0x6 << 21) #define CGC_RESERVED (0x6 << 21)
#define MEMORY_PM_CTRL (BRIDGE_VIRT_BASE + 0x118) #define MEMORY_PM_CTRL (BRIDGE_VIRT_BASE + 0x118)
#define MEMORY_PM_CTRL_PHYS (BRIDGE_PHYS_BASE + 0x118)
#endif #endif
...@@ -21,15 +21,16 @@ ...@@ -21,15 +21,16 @@
#include "common.h" #include "common.h"
static void __iomem *ddr_operation_base; static void __iomem *ddr_operation_base;
static void __iomem *memory_pm_ctrl;
static void kirkwood_low_power(void) static void kirkwood_low_power(void)
{ {
u32 mem_pm_ctrl; u32 mem_pm_ctrl;
mem_pm_ctrl = readl(MEMORY_PM_CTRL); mem_pm_ctrl = readl(memory_pm_ctrl);
/* Set peripherals to low-power mode */ /* Set peripherals to low-power mode */
writel_relaxed(~0, MEMORY_PM_CTRL); writel_relaxed(~0, memory_pm_ctrl);
/* Set DDR in self-refresh */ /* Set DDR in self-refresh */
writel_relaxed(0x7, ddr_operation_base); writel_relaxed(0x7, ddr_operation_base);
...@@ -41,7 +42,7 @@ static void kirkwood_low_power(void) ...@@ -41,7 +42,7 @@ static void kirkwood_low_power(void)
*/ */
cpu_do_idle(); cpu_do_idle();
writel_relaxed(mem_pm_ctrl, MEMORY_PM_CTRL); writel_relaxed(mem_pm_ctrl, memory_pm_ctrl);
} }
static int kirkwood_suspend_enter(suspend_state_t state) static int kirkwood_suspend_enter(suspend_state_t state)
...@@ -69,5 +70,7 @@ static const struct platform_suspend_ops kirkwood_suspend_ops = { ...@@ -69,5 +70,7 @@ static const struct platform_suspend_ops kirkwood_suspend_ops = {
void __init kirkwood_pm_init(void) void __init kirkwood_pm_init(void)
{ {
ddr_operation_base = ioremap(DDR_OPERATION_BASE, 4); ddr_operation_base = ioremap(DDR_OPERATION_BASE, 4);
memory_pm_ctrl = ioremap(MEMORY_PM_CTRL_PHYS, 4);
suspend_set_ops(&kirkwood_suspend_ops); suspend_set_ops(&kirkwood_suspend_ops);
} }
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