Go to the documentation of this file.
34 #ifndef __ARCH_ARM_MACH_OMAP1_PM_H
35 #define __ARCH_ARM_MACH_OMAP1_PM_H
42 #define CLKGEN_REG_ASM_BASE OMAP1_IO_ADDRESS(0xfffece00)
43 #define ARM_IDLECT1_ASM_OFFSET 0x04
44 #define ARM_IDLECT2_ASM_OFFSET 0x08
46 #define TCMIF_ASM_BASE OMAP1_IO_ADDRESS(0xfffecc00)
47 #define EMIFS_CONFIG_ASM_OFFSET 0x0c
48 #define EMIFF_SDRAM_CONFIG_ASM_OFFSET 0x20
55 #define IDLE_WAIT_CYCLES 0x00000fff
56 #define PERIPHERAL_ENABLE 0x2
58 #define SELF_REFRESH_MODE 0x0c000001
59 #define IDLE_EMIFS_REQUEST 0xc
60 #define MODEM_32K_EN 0x1
63 #define CPU_SUSPEND_SIZE 200
64 #define ULPD_LOW_PWR_EN 0x0001
65 #define ULPD_DEEP_SLEEP_TRANSITION_EN 0x0010
66 #define ULPD_SETUP_ANALOG_CELL_3_VAL 0
67 #define ULPD_POWER_CTRL_REG_VAL 0x0219
69 #define DSP_IDLE_DELAY 10
70 #define DSP_IDLE 0x0040
71 #define DSP_RST 0x0004
72 #define DSP_ENABLE 0x0002
73 #define SUFFICIENT_DSP_RESET_TIME 1000
74 #define DEFAULT_MPUI_CONFIG 0x05cf
75 #define ENABLE_XORCLK 0x2
76 #define DSP_CLOCK_ENABLE 0x2000
77 #define DSP_IDLE_MODE 0x2
78 #define TC_IDLE_REQUEST (0x0000000c)
80 #define IRQ_LEVEL2 (1<<0)
81 #define IRQ_KEYBOARD (1<<1)
82 #define IRQ_UART2 (1<<15)
85 #define PWD_EN_BIT 0x04
86 #define EN_PERCK_BIT 0x04
88 #define OMAP1510_DEEP_SLEEP_REQUEST 0x0ec7
89 #define OMAP1510_BIG_SLEEP_REQUEST 0x0cc5
90 #define OMAP1510_IDLE_LOOP_REQUEST 0x0c00
91 #define OMAP1510_IDLE_CLOCK_DOMAINS 0x2
94 #define OMAP1610_IDLECT1_SLEEP_VAL 0x13c7
95 #define OMAP1610_IDLECT2_SLEEP_VAL 0x09c7
96 #define OMAP1610_IDLECT3_VAL 0x3f
97 #define OMAP1610_IDLECT3_SLEEP_ORMASK 0x2c
98 #define OMAP1610_IDLECT3 0xfffece24
99 #define OMAP1610_IDLE_LOOP_REQUEST 0x0400
101 #define OMAP7XX_IDLECT1_SLEEP_VAL 0x16c7
102 #define OMAP7XX_IDLECT2_SLEEP_VAL 0x09c7
103 #define OMAP7XX_IDLECT3_VAL 0x3f
104 #define OMAP7XX_IDLECT3 0xfffece24
105 #define OMAP7XX_IDLE_LOOP_REQUEST 0x0C00
107 #if !defined(CONFIG_ARCH_OMAP730) && \
108 !defined(CONFIG_ARCH_OMAP850) && \
109 !defined(CONFIG_ARCH_OMAP15XX) && \
110 !defined(CONFIG_ARCH_OMAP16XX)
111 #warning "Power management for this processor not implemented yet"
114 #ifndef __ASSEMBLER__
140 #ifdef CONFIG_OMAP_SERIAL_WAKE
143 #define omap_serial_wakeup_init() {}
144 #define omap_serial_wake_trigger(x) {}
147 #define ARM_SAVE(x) arm_sleep_save[ARM_SLEEP_SAVE_##x] = omap_readl(x)
148 #define ARM_RESTORE(x) omap_writel((arm_sleep_save[ARM_SLEEP_SAVE_##x]), (x))
149 #define ARM_SHOW(x) arm_sleep_save[ARM_SLEEP_SAVE_##x]
151 #define DSP_SAVE(x) dsp_sleep_save[DSP_SLEEP_SAVE_##x] = __raw_readw(x)
152 #define DSP_RESTORE(x) __raw_writew((dsp_sleep_save[DSP_SLEEP_SAVE_##x]), (x))
153 #define DSP_SHOW(x) dsp_sleep_save[DSP_SLEEP_SAVE_##x]
155 #define ULPD_SAVE(x) ulpd_sleep_save[ULPD_SLEEP_SAVE_##x] = omap_readw(x)
156 #define ULPD_RESTORE(x) omap_writew((ulpd_sleep_save[ULPD_SLEEP_SAVE_##x]), (x))
157 #define ULPD_SHOW(x) ulpd_sleep_save[ULPD_SLEEP_SAVE_##x]
159 #define MPUI7XX_SAVE(x) mpui7xx_sleep_save[MPUI7XX_SLEEP_SAVE_##x] = omap_readl(x)
160 #define MPUI7XX_RESTORE(x) omap_writel((mpui7xx_sleep_save[MPUI7XX_SLEEP_SAVE_##x]), (x))
161 #define MPUI7XX_SHOW(x) mpui7xx_sleep_save[MPUI7XX_SLEEP_SAVE_##x]
163 #define MPUI1510_SAVE(x) mpui1510_sleep_save[MPUI1510_SLEEP_SAVE_##x] = omap_readl(x)
164 #define MPUI1510_RESTORE(x) omap_writel((mpui1510_sleep_save[MPUI1510_SLEEP_SAVE_##x]), (x))
165 #define MPUI1510_SHOW(x) mpui1510_sleep_save[MPUI1510_SLEEP_SAVE_##x]
167 #define MPUI1610_SAVE(x) mpui1610_sleep_save[MPUI1610_SLEEP_SAVE_##x] = omap_readl(x)
168 #define MPUI1610_RESTORE(x) omap_writel((mpui1610_sleep_save[MPUI1610_SLEEP_SAVE_##x]), (x))
169 #define MPUI1610_SHOW(x) mpui1610_sleep_save[MPUI1610_SLEEP_SAVE_##x]
229 #if defined(CONFIG_ARCH_OMAP15XX)
250 #if defined(CONFIG_ARCH_OMAP730) || defined(CONFIG_ARCH_OMAP850)
273 #if defined(CONFIG_ARCH_OMAP16XX)