diff options
-rw-r--r-- | arch/arm/mach-at91/pm.c | 74 | ||||
-rw-r--r-- | include/asm-arm/arch-at91/at91_shdwc.h | 2 |
2 files changed, 76 insertions, 0 deletions
diff --git a/arch/arm/mach-at91/pm.c b/arch/arm/mach-at91/pm.c index 77d9669810ed..39733b6992aa 100644 --- a/arch/arm/mach-at91/pm.c +++ b/arch/arm/mach-at91/pm.c | |||
@@ -83,6 +83,79 @@ static inline void sdram_selfrefresh_enable(void) | |||
83 | #endif | 83 | #endif |
84 | 84 | ||
85 | 85 | ||
86 | /* | ||
87 | * Show the reason for the previous system reset. | ||
88 | */ | ||
89 | #if defined(AT91_SHDWC) | ||
90 | |||
91 | #include <asm/arch/at91_rstc.h> | ||
92 | #include <asm/arch/at91_shdwc.h> | ||
93 | |||
94 | static void __init show_reset_status(void) | ||
95 | { | ||
96 | static char reset[] __initdata = "reset"; | ||
97 | |||
98 | static char general[] __initdata = "general"; | ||
99 | static char wakeup[] __initdata = "wakeup"; | ||
100 | static char watchdog[] __initdata = "watchdog"; | ||
101 | static char software[] __initdata = "software"; | ||
102 | static char user[] __initdata = "user"; | ||
103 | static char unknown[] __initdata = "unknown"; | ||
104 | |||
105 | static char signal[] __initdata = "signal"; | ||
106 | static char rtc[] __initdata = "rtc"; | ||
107 | static char rtt[] __initdata = "rtt"; | ||
108 | static char restore[] __initdata = "power-restored"; | ||
109 | |||
110 | char *reason, *r2 = reset; | ||
111 | u32 reset_type, wake_type; | ||
112 | |||
113 | reset_type = at91_sys_read(AT91_RSTC_SR) & AT91_RSTC_RSTTYP; | ||
114 | wake_type = at91_sys_read(AT91_SHDW_SR); | ||
115 | |||
116 | switch (reset_type) { | ||
117 | case AT91_RSTC_RSTTYP_GENERAL: | ||
118 | reason = general; | ||
119 | break; | ||
120 | case AT91_RSTC_RSTTYP_WAKEUP: | ||
121 | /* board-specific code enabled the wakeup sources */ | ||
122 | reason = wakeup; | ||
123 | |||
124 | /* "wakeup signal" */ | ||
125 | if (wake_type & AT91_SHDW_WAKEUP0) | ||
126 | r2 = signal; | ||
127 | else { | ||
128 | r2 = reason; | ||
129 | if (wake_type & AT91_SHDW_RTTWK) /* rtt wakeup */ | ||
130 | reason = rtt; | ||
131 | else if (wake_type & AT91_SHDW_RTCWK) /* rtc wakeup */ | ||
132 | reason = rtc; | ||
133 | else if (wake_type == 0) /* power-restored wakeup */ | ||
134 | reason = restore; | ||
135 | else /* unknown wakeup */ | ||
136 | reason = unknown; | ||
137 | } | ||
138 | break; | ||
139 | case AT91_RSTC_RSTTYP_WATCHDOG: | ||
140 | reason = watchdog; | ||
141 | break; | ||
142 | case AT91_RSTC_RSTTYP_SOFTWARE: | ||
143 | reason = software; | ||
144 | break; | ||
145 | case AT91_RSTC_RSTTYP_USER: | ||
146 | reason = user; | ||
147 | break; | ||
148 | default: | ||
149 | reason = unknown; | ||
150 | break; | ||
151 | } | ||
152 | pr_info("AT91: Starting after %s %s\n", reason, r2); | ||
153 | } | ||
154 | #else | ||
155 | static void __init show_reset_status(void) {} | ||
156 | #endif | ||
157 | |||
158 | |||
86 | static int at91_pm_valid_state(suspend_state_t state) | 159 | static int at91_pm_valid_state(suspend_state_t state) |
87 | { | 160 | { |
88 | switch (state) { | 161 | switch (state) { |
@@ -294,6 +367,7 @@ static int __init at91_pm_init(void) | |||
294 | 367 | ||
295 | suspend_set_ops(&at91_pm_ops); | 368 | suspend_set_ops(&at91_pm_ops); |
296 | 369 | ||
370 | show_reset_status(); | ||
297 | return 0; | 371 | return 0; |
298 | } | 372 | } |
299 | arch_initcall(at91_pm_init); | 373 | arch_initcall(at91_pm_init); |
diff --git a/include/asm-arm/arch-at91/at91_shdwc.h b/include/asm-arm/arch-at91/at91_shdwc.h index 01b433de2272..581fa41d90e8 100644 --- a/include/asm-arm/arch-at91/at91_shdwc.h +++ b/include/asm-arm/arch-at91/at91_shdwc.h | |||
@@ -24,10 +24,12 @@ | |||
24 | #define AT91_SHDW_WKMODE0_LOW 2 | 24 | #define AT91_SHDW_WKMODE0_LOW 2 |
25 | #define AT91_SHDW_WKMODE0_ANYLEVEL 3 | 25 | #define AT91_SHDW_WKMODE0_ANYLEVEL 3 |
26 | #define AT91_SHDW_CPTWK0 (0xf << 4) /* Counter On Wake Up 0 */ | 26 | #define AT91_SHDW_CPTWK0 (0xf << 4) /* Counter On Wake Up 0 */ |
27 | #define AT91_SHDW_CPTWK0_(x) ((x) << 4) | ||
27 | #define AT91_SHDW_RTTWKEN (1 << 16) /* Real Time Timer Wake-up Enable */ | 28 | #define AT91_SHDW_RTTWKEN (1 << 16) /* Real Time Timer Wake-up Enable */ |
28 | 29 | ||
29 | #define AT91_SHDW_SR (AT91_SHDWC + 0x08) /* Shut Down Status Register */ | 30 | #define AT91_SHDW_SR (AT91_SHDWC + 0x08) /* Shut Down Status Register */ |
30 | #define AT91_SHDW_WAKEUP0 (1 << 0) /* Wake-up 0 Status */ | 31 | #define AT91_SHDW_WAKEUP0 (1 << 0) /* Wake-up 0 Status */ |
31 | #define AT91_SHDW_RTTWK (1 << 16) /* Real-time Timer Wake-up */ | 32 | #define AT91_SHDW_RTTWK (1 << 16) /* Real-time Timer Wake-up */ |
33 | #define AT91_SHDW_RTCWK (1 << 17) /* Real-time Clock Wake-up [SAM9RL] */ | ||
32 | 34 | ||
33 | #endif | 35 | #endif |