2 * Copyright 2018 Advanced Micro Devices, Inc.
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
11 * The above copyright notice and this permission notice shall be included in
12 * all copies or substantial portions of the Software.
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
17 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20 * OTHER DEALINGS IN THE SOFTWARE.
25 #include "soc15_hw_ip.h"
26 #include "vega10_ip_offset.h"
27 #include "soc15_common.h"
28 #include "vega10_inc.h"
29 #include "vega10_ppsmc.h"
30 #include "vega10_baco.h"
34 static const struct soc15_baco_cmd_entry pre_baco_tbl
[] =
36 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBIF_DOORBELL_CNTL
), BIF_DOORBELL_CNTL__DOORBELL_MONITOR_EN_MASK
, BIF_DOORBELL_CNTL__DOORBELL_MONITOR_EN__SHIFT
, 0, 1},
37 {CMD_WRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBIF_FB_EN
), 0, 0, 0, 0},
38 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBACO_CNTL
), BACO_CNTL__BACO_DSTATE_BYPASS_MASK
, BACO_CNTL__BACO_DSTATE_BYPASS__SHIFT
, 0, 1},
39 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBACO_CNTL
), BACO_CNTL__BACO_RST_INTR_MASK_MASK
, BACO_CNTL__BACO_RST_INTR_MASK__SHIFT
, 0, 1}
42 static const struct soc15_baco_cmd_entry enter_baco_tbl
[] =
44 {CMD_WAITFOR
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__SOC_DOMAIN_IDLE_MASK
, THM_BACO_CNTL__SOC_DOMAIN_IDLE__SHIFT
, 0xffffffff, 0x80000000},
45 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBACO_CNTL
), BACO_CNTL__BACO_EN_MASK
, BACO_CNTL__BACO_EN__SHIFT
, 0, 1},
46 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBACO_CNTL
), BACO_CNTL__BACO_BIF_LCLK_SWITCH_MASK
, BACO_CNTL__BACO_BIF_LCLK_SWITCH__SHIFT
, 0, 1},
47 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBACO_CNTL
), BACO_CNTL__BACO_DUMMY_EN_MASK
, BACO_CNTL__BACO_DUMMY_EN__SHIFT
, 0, 1},
48 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_SOC_VDCI_RESET_MASK
, THM_BACO_CNTL__BACO_SOC_VDCI_RESET__SHIFT
, 0, 1},
49 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_SMNCLK_MUX_MASK
, THM_BACO_CNTL__BACO_SMNCLK_MUX__SHIFT
,0, 1},
50 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_ISO_EN_MASK
, THM_BACO_CNTL__BACO_ISO_EN__SHIFT
, 0, 1},
51 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_AEB_ISO_EN_MASK
, THM_BACO_CNTL__BACO_AEB_ISO_EN__SHIFT
,0, 1},
52 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_ANA_ISO_EN_MASK
, THM_BACO_CNTL__BACO_ANA_ISO_EN__SHIFT
, 0, 1},
53 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_SOC_REFCLK_OFF_MASK
, THM_BACO_CNTL__BACO_SOC_REFCLK_OFF__SHIFT
, 0, 1},
54 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBACO_CNTL
), BACO_CNTL__BACO_POWER_OFF_MASK
, BACO_CNTL__BACO_POWER_OFF__SHIFT
, 0, 1},
55 {CMD_DELAY_MS
, 0, 0, 0, 0, 0, 0, 5, 0},
56 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_RESET_EN_MASK
, THM_BACO_CNTL__BACO_RESET_EN__SHIFT
, 0, 1},
57 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_PWROKRAW_CNTL_MASK
, THM_BACO_CNTL__BACO_PWROKRAW_CNTL__SHIFT
, 0, 0},
58 {CMD_WAITFOR
, SOC15_REG_ENTRY(NBIF
, 0, mmBACO_CNTL
), BACO_CNTL__BACO_MODE_MASK
, BACO_CNTL__BACO_MODE__SHIFT
, 0xffffffff, 0x100}
61 static const struct soc15_baco_cmd_entry exit_baco_tbl
[] =
63 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBACO_CNTL
), BACO_CNTL__BACO_POWER_OFF_MASK
, BACO_CNTL__BACO_POWER_OFF__SHIFT
, 0, 0},
64 {CMD_DELAY_MS
, 0, 0, 0, 0, 0, 0, 10,0},
65 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_SOC_REFCLK_OFF_MASK
, THM_BACO_CNTL__BACO_SOC_REFCLK_OFF__SHIFT
, 0,0},
66 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_ANA_ISO_EN_MASK
, THM_BACO_CNTL__BACO_ANA_ISO_EN__SHIFT
, 0, 0},
67 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_AEB_ISO_EN_MASK
, THM_BACO_CNTL__BACO_AEB_ISO_EN__SHIFT
,0, 0},
68 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_ISO_EN_MASK
, THM_BACO_CNTL__BACO_ISO_EN__SHIFT
, 0, 0},
69 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_PWROKRAW_CNTL_MASK
, THM_BACO_CNTL__BACO_PWROKRAW_CNTL__SHIFT
, 0, 1},
70 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_SMNCLK_MUX_MASK
, THM_BACO_CNTL__BACO_SMNCLK_MUX__SHIFT
, 0, 0},
71 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_SOC_VDCI_RESET_MASK
, THM_BACO_CNTL__BACO_SOC_VDCI_RESET__SHIFT
, 0, 0},
72 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_EXIT_MASK
, THM_BACO_CNTL__BACO_EXIT__SHIFT
, 0, 1},
73 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_RESET_EN_MASK
, THM_BACO_CNTL__BACO_RESET_EN__SHIFT
, 0, 0},
74 {CMD_WAITFOR
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_EXIT_MASK
, 0, 0xffffffff, 0},
75 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(THM
, 0, mmTHM_BACO_CNTL
), THM_BACO_CNTL__BACO_SB_AXI_FENCE_MASK
, THM_BACO_CNTL__BACO_SB_AXI_FENCE__SHIFT
, 0, 0},
76 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBACO_CNTL
), BACO_CNTL__BACO_DUMMY_EN_MASK
, BACO_CNTL__BACO_DUMMY_EN__SHIFT
, 0, 0},
77 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBACO_CNTL
), BACO_CNTL__BACO_BIF_LCLK_SWITCH_MASK
,BACO_CNTL__BACO_BIF_LCLK_SWITCH__SHIFT
, 0, 0},
78 {CMD_READMODIFYWRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBACO_CNTL
), BACO_CNTL__BACO_EN_MASK
, BACO_CNTL__BACO_EN__SHIFT
, 0,0},
79 {CMD_WAITFOR
, SOC15_REG_ENTRY(NBIF
, 0, mmBACO_CNTL
), BACO_CNTL__BACO_MODE_MASK
, 0, 0xffffffff, 0}
82 static const struct soc15_baco_cmd_entry clean_baco_tbl
[] =
84 {CMD_WRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBIOS_SCRATCH_6
), 0, 0, 0, 0},
85 {CMD_WRITE
, SOC15_REG_ENTRY(NBIF
, 0, mmBIOS_SCRATCH_7
), 0, 0, 0, 0},
88 int vega10_baco_set_state(struct pp_hwmgr
*hwmgr
, enum BACO_STATE state
)
90 enum BACO_STATE cur_state
;
92 smu9_baco_get_state(hwmgr
, &cur_state
);
94 if (cur_state
== state
)
95 /* aisc already in the target state */
98 if (state
== BACO_STATE_IN
) {
99 if (soc15_baco_program_registers(hwmgr
, pre_baco_tbl
,
100 ARRAY_SIZE(pre_baco_tbl
))) {
101 if (smum_send_msg_to_smc(hwmgr
, PPSMC_MSG_EnterBaco
))
104 if (soc15_baco_program_registers(hwmgr
, enter_baco_tbl
,
105 ARRAY_SIZE(enter_baco_tbl
)))
108 } else if (state
== BACO_STATE_OUT
) {
109 /* HW requires at least 20ms between regulator off and on */
111 /* Execute Hardware BACO exit sequence */
112 if (soc15_baco_program_registers(hwmgr
, exit_baco_tbl
,
113 ARRAY_SIZE(exit_baco_tbl
))) {
114 if (soc15_baco_program_registers(hwmgr
, clean_baco_tbl
,
115 ARRAY_SIZE(clean_baco_tbl
)))