Angel Pons | 1ddb894 | 2020-04-04 18:51:26 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Stefan Reinauer | 043eb0e | 2013-05-10 16:21:58 -0700 | [diff] [blame] | 2 | |
Julius Werner | 1ed0c8c | 2014-10-20 13:16:29 -0700 | [diff] [blame] | 3 | #include <soc/power.h> |
| 4 | #include <soc/wakeup.h> |
Stefan Reinauer | 043eb0e | 2013-05-10 16:21:58 -0700 | [diff] [blame] | 5 | |
| 6 | void wakeup(void) |
| 7 | { |
| 8 | if (wakeup_need_reset()) |
| 9 | power_reset(); |
| 10 | |
| 11 | power_init(); /* Ensure ps_hold_setup() for early wakeup. */ |
| 12 | power_exit_wakeup(); |
Stefan Reinauer | 9125d88 | 2013-09-10 10:58:28 -0700 | [diff] [blame] | 13 | /* Should never return. If we do, reset. */ |
| 14 | power_reset(); |
Stefan Reinauer | 043eb0e | 2013-05-10 16:21:58 -0700 | [diff] [blame] | 15 | } |
| 16 | |
| 17 | int get_wakeup_state(void) |
| 18 | { |
| 19 | uint32_t status = power_read_reset_status(); |
| 20 | |
| 21 | /* DIDLE/LPA can be resumed without clock reset (ex, bootblock), |
| 22 | * and SLEEP requires resetting clock (should be done in ROM stage). |
| 23 | */ |
| 24 | |
| 25 | if (status == S5P_CHECK_DIDLE || status == S5P_CHECK_LPA) |
| 26 | return WAKEUP_DIRECT; |
| 27 | |
| 28 | if (status == S5P_CHECK_SLEEP) |
| 29 | return WAKEUP_NEED_CLOCK_RESET; |
| 30 | |
| 31 | return IS_NOT_WAKEUP; |
| 32 | } |
Hung-Te Lin | 12b121f | 2013-09-24 15:51:05 +0800 | [diff] [blame] | 33 | |
| 34 | void wakeup_enable_uart(void) |
| 35 | { |
| 36 | power_release_uart_retention(); |
| 37 | } |