nds32: Power management for nds32
authorNick Hu <nickhu@andestech.com>
Wed, 24 Oct 2018 10:14:32 +0000 (18:14 +0800)
committerGreentime Hu <greentime@andestech.com>
Tue, 6 Nov 2018 10:01:41 +0000 (18:01 +0800)
commit7938e6315c9af3d4a40185b537733bbce842305a
tree4239f342490d2a7c1c2753ab3e3bcbea20bcde8b
parentcf26edd840dc65b122a0f5e22d2d81ad05eccb2d
nds32: Power management for nds32

There are three sleep states in nds32:
suspend to idle,
suspend to standby,
suspend to ram

In suspend to ram, we use the 'standby' instruction to emulate
power management device to hang the system util wakeup source
send wakeup events to break the loop.

First, we push the general purpose registers and system registers
to stack. Second, we translate stack pointer to physical address
and store to memory to save the stack pointer. Third, after write
back and invalid the cache we hang in 'standby' intruction.
When wakeup source trigger wake up events, the loop will be break
and resume the system.

Signed-off-by: Nick Hu <nickhu@andestech.com>
Acked-by: Pavel Machek <pavel@ucw.cz>
Acked-by: Greentime Hu <greentime@andestech.com>
Signed-off-by: Greentime Hu <greentime@andestech.com>
arch/nds32/Kconfig
arch/nds32/include/asm/suspend.h [new file with mode: 0644]
arch/nds32/kernel/Makefile
arch/nds32/kernel/pm.c [new file with mode: 0644]
arch/nds32/kernel/sleep.S [new file with mode: 0644]
drivers/irqchip/irq-ativic32.c