blob: 88805132a6a88195a9479daa6693247688536003 [file] [log] [blame]
Angel Pons1ddb8942020-04-04 18:51:26 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -08002
Stefan Reinauer08dc3572013-05-14 16:57:50 -07003/* Power setup code for EXYNOS5 */
4
Kyösti Mälkki13f66502019-03-03 08:01:05 +02005#include <device/mmio.h>
Patrick Georgi546953c2014-11-29 10:38:17 +01006#include <halt.h>
Stefan Reinauer747d0f82015-12-14 17:09:49 -08007#include <reset.h>
Julius Werner1ed0c8c2014-10-20 13:16:29 -07008#include <soc/dmc.h>
9#include <soc/power.h>
10#include <soc/setup.h>
David Hendricks27094b02013-01-09 17:42:02 -080011
Edward O'Callaghan5b63dc12014-12-23 23:31:30 +110012/* Set the PS-Hold drive value */
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080013static void ps_hold_setup(void)
14{
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080015 /* Set PS-Hold high */
Julius Werner55009af2019-12-02 22:03:27 -080016 setbits32(&exynos_power->ps_hold_ctrl,
Julius Wernerfa938c72013-08-29 14:17:36 -070017 POWER_PS_HOLD_CONTROL_DATA_HIGH);
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080018}
19
20void power_reset(void)
21{
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080022 /* Clear inform1 so there's no change we think we've got a wake reset */
Julius Wernerfa938c72013-08-29 14:17:36 -070023 exynos_power->inform1 = 0;
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080024
Julius Werner55009af2019-12-02 22:03:27 -080025 setbits32(&exynos_power->sw_reset, 1);
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080026}
27
Nico Huber8ba70232018-10-06 19:16:40 +020028void do_board_reset(void)
Stefan Reinauer747d0f82015-12-14 17:09:49 -080029{
30 power_reset();
31}
32
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080033/* This function never returns */
34void power_shutdown(void)
35{
Julius Werner55009af2019-12-02 22:03:27 -080036 clrbits32(&exynos_power->ps_hold_ctrl,
Julius Wernerfa938c72013-08-29 14:17:36 -070037 POWER_PS_HOLD_CONTROL_DATA_HIGH);
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080038
Patrick Georgi546953c2014-11-29 10:38:17 +010039 halt();
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080040}
41
42void power_enable_dp_phy(void)
43{
Julius Werner55009af2019-12-02 22:03:27 -080044 setbits32(&exynos_power->dptx_phy_control, EXYNOS_DP_PHY_ENABLE);
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080045}
46
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080047void power_enable_hw_thermal_trip(void)
48{
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080049 /* Enable HW thermal trip */
Julius Werner55009af2019-12-02 22:03:27 -080050 setbits32(&exynos_power->ps_hold_ctrl, POWER_ENABLE_HW_TRIP);
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080051}
52
53uint32_t power_read_reset_status(void)
54{
Julius Wernerfa938c72013-08-29 14:17:36 -070055 return exynos_power->inform1;
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080056}
57
58void power_exit_wakeup(void)
59{
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080060 typedef void (*resume_func)(void);
61
Julius Wernerfa938c72013-08-29 14:17:36 -070062 ((resume_func)exynos_power->inform0)();
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080063}
64
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080065int power_init(void)
66{
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080067 ps_hold_setup();
David Hendricksdb9eaf42013-04-05 15:38:12 -070068 return 0;
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080069}
70
71void power_enable_xclkout(void)
72{
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080073 /* use xxti for xclk out */
Julius Werner55009af2019-12-02 22:03:27 -080074 clrsetbits32(&exynos_power->pmu_debug, PMU_DEBUG_CLKOUT_SEL_MASK,
Edward O'Callaghanf679cfe2014-12-23 23:48:01 +110075 PMU_DEBUG_XXTI);
Stefan Reinauer9fe20cb2012-12-07 17:18:43 -080076}
Hung-Te Lin12b121f2013-09-24 15:51:05 +080077
78void power_release_uart_retention(void)
79{
Julius Werner2f37bd62015-02-19 14:51:15 -080080 write32(&exynos_power->padret_uart_opt, 1 << 28);
Hung-Te Lin12b121f2013-09-24 15:51:05 +080081}