bf60x: pm: add smc nor flash syscore ops
authorSteven Miao <realmz6@gmail.com>
Thu, 7 Jun 2012 06:17:12 +0000 (14:17 +0800)
committerBob Liu <lliubbo@gmail.com>
Tue, 24 Jul 2012 05:39:50 +0000 (13:39 +0800)
Signed-off-by: Steven Miao <realmz6@gmail.com>
Signed-off-by: Bob Liu <lliubbo@gmail.com>
arch/blackfin/mach-bf609/include/mach/pm.h
arch/blackfin/mach-bf609/pm.c

index 68435f9bafca4cd9118685918f119f93a8b8c240..3ca0fb965636ed3fad126ae021d9d87a6518ea8a 100644 (file)
@@ -18,4 +18,7 @@ extern void bf609_pm_finish(void);
 void bf609_hibernate(void);
 void bfin_sec_raise_irq(unsigned int sid);
 void coreb_enable(void);
+
+int bf609_nor_flash_init(void);
+void bf609_nor_flash_exit(void);
 #endif
index 6094c7d3b1f2cd564643a5ee91d70624bfd8db70..4f6977762630d5647c0614506ad73719a80547f6 100644 (file)
@@ -11,8 +11,8 @@
 #include <linux/interrupt.h>
 #include <linux/gpio.h>
 #include <linux/irq.h>
-
 #include <linux/delay.h>
+#include <linux/syscore_ops.h>
 
 #include <asm/dpmc.h>
 #include <asm/pm.h>
@@ -293,6 +293,23 @@ static struct bfin_cpu_pm_fns bf609_cpu_pm = {
        .finish         = bf609_cpu_pm_finish,
 };
 
+#if defined(CONFIG_MTD_PHYSMAP) || defined(CONFIG_MTD_PHYSMAP_MODULE)
+static void smc_pm_syscore_suspend(void)
+{
+       bf609_nor_flash_exit();
+}
+
+static void smc_pm_syscore_resume(void)
+{
+       bf609_nor_flash_init();
+}
+
+static struct syscore_ops smc_pm_syscore_ops = {
+       .suspend        = smc_pm_syscore_suspend,
+       .resume         = smc_pm_syscore_resume,
+};
+#endif
+
 static irqreturn_t test_isr(int irq, void *dev_id)
 {
        printk(KERN_DEBUG "gpio irq %d\n", irq);
@@ -312,6 +329,10 @@ static int __init bf609_init_pm(void)
        int irq;
        int error;
 
+#if defined(CONFIG_MTD_PHYSMAP) || defined(CONFIG_MTD_PHYSMAP_MODULE)
+       register_syscore_ops(&smc_pm_syscore_ops);
+#endif
+
 #ifdef CONFIG_PM_BFIN_WAKE_PE12
        irq = gpio_to_irq(GPIO_PE12);
        if (irq < 0) {