2 * File: arch/blackfin/mach-common/pm.c
3 * Based on: arm/mach-omap/pm.c
4 * Author: Cliff Brake <cbrake@accelent.com> Copyright (c) 2001
7 * Description: Blackfin power management
9 * Modified: Nicolas Pitre - PXA250 support
10 * Copyright (c) 2002 Monta Vista Software, Inc.
11 * David Singleton - OMAP1510
12 * Copyright (c) 2002 Monta Vista Software, Inc.
13 * Dirk Behme <dirk.behme@de.bosch.com> - OMAP1510/1610
15 * Copyright 2004-2008 Analog Devices Inc.
17 * Bugs: Enter bugs at http://blackfin.uclinux.org/
19 * This program is free software; you can redistribute it and/or modify
20 * it under the terms of the GNU General Public License as published by
21 * the Free Software Foundation; either version 2 of the License, or
22 * (at your option) any later version.
24 * This program is distributed in the hope that it will be useful,
25 * but WITHOUT ANY WARRANTY; without even the implied warranty of
26 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
27 * GNU General Public License for more details.
29 * You should have received a copy of the GNU General Public License
30 * along with this program; if not, see the file COPYING, or write
31 * to the Free Software Foundation, Inc.,
32 * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
35 #include <linux/suspend.h>
36 #include <linux/sched.h>
37 #include <linux/proc_fs.h>
39 #include <linux/irq.h>
44 #ifdef CONFIG_PM_WAKEUP_GPIO_POLAR_H
45 #define WAKEUP_TYPE PM_WAKE_HIGH
48 #ifdef CONFIG_PM_WAKEUP_GPIO_POLAR_L
49 #define WAKEUP_TYPE PM_WAKE_LOW
52 #ifdef CONFIG_PM_WAKEUP_GPIO_POLAR_EDGE_F
53 #define WAKEUP_TYPE PM_WAKE_FALLING
56 #ifdef CONFIG_PM_WAKEUP_GPIO_POLAR_EDGE_R
57 #define WAKEUP_TYPE PM_WAKE_RISING
60 #ifdef CONFIG_PM_WAKEUP_GPIO_POLAR_EDGE_B
61 #define WAKEUP_TYPE PM_WAKE_BOTH_EDGES
64 void bfin_pm_suspend_standby_enter(void)
66 #ifdef CONFIG_PM_WAKEUP_BY_GPIO
67 gpio_pm_wakeup_request(CONFIG_PM_WAKEUP_GPIO_NUMBER
, WAKEUP_TYPE
);
72 local_irq_save(flags
);
75 #ifdef CONFIG_PM_BFIN_SLEEP_DEEPER
76 sleep_deeper(bfin_sic_iwr
[0], bfin_sic_iwr
[1], bfin_sic_iwr
[2]);
78 sleep_mode(bfin_sic_iwr
[0], bfin_sic_iwr
[1], bfin_sic_iwr
[2]);
83 #if defined(CONFIG_BF54x) || defined(CONFIG_BF52x) || defined(CONFIG_BF561)
84 bfin_write_SIC_IWR0(IWR_ENABLE_ALL
);
85 bfin_write_SIC_IWR1(IWR_ENABLE_ALL
);
87 bfin_write_SIC_IWR2(IWR_ENABLE_ALL
);
90 bfin_write_SIC_IWR(IWR_ENABLE_ALL
);
93 local_irq_restore(flags
);
97 * bfin_pm_valid - Tell the PM core that we only support the standby sleep
99 * @state: suspend state we're checking.
102 static int bfin_pm_valid(suspend_state_t state
)
104 return (state
== PM_SUSPEND_STANDBY
);
108 * bfin_pm_enter - Actually enter a sleep state.
109 * @state: State we're entering.
112 static int bfin_pm_enter(suspend_state_t state
)
115 case PM_SUSPEND_STANDBY
:
116 bfin_pm_suspend_standby_enter();
129 struct platform_suspend_ops bfin_pm_ops
= {
130 .enter
= bfin_pm_enter
,
131 .valid
= bfin_pm_valid
,
134 static int __init
bfin_pm_init(void)
136 suspend_set_ops(&bfin_pm_ops
);
140 __initcall(bfin_pm_init
);