2 * Copyright 2019 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 "vega12_inc.h"
29 #include "vega12_ppsmc.h"
30 #include "vega12_baco.h"
32 static const struct soc15_baco_cmd_entry pre_baco_tbl
[] =
34 { CMD_READMODIFYWRITE
, NBIF_HWID
, 0, mmBIF_DOORBELL_CNTL_BASE_IDX
, mmBIF_DOORBELL_CNTL
, BIF_DOORBELL_CNTL__DOORBELL_MONITOR_EN_MASK
, BIF_DOORBELL_CNTL__DOORBELL_MONITOR_EN__SHIFT
, 0, 0 },
35 { CMD_WRITE
, NBIF_HWID
, 0, mmBIF_FB_EN_BASE_IDX
, mmBIF_FB_EN
, 0, 0, 0, 0 },
36 { CMD_READMODIFYWRITE
, NBIF_HWID
, 0, mmRCC_BACO_CNTL_MISC_BASE_IDX
, mmBACO_CNTL
, BACO_CNTL__BACO_DSTATE_BYPASS_MASK
, BACO_CNTL__BACO_DSTATE_BYPASS__SHIFT
, 0, 1 },
37 { CMD_READMODIFYWRITE
, NBIF_HWID
, 0, mmRCC_BACO_CNTL_MISC_BASE_IDX
, mmBACO_CNTL
, BACO_CNTL__BACO_RST_INTR_MASK_MASK
, BACO_CNTL__BACO_RST_INTR_MASK__SHIFT
, 0, 1 }
40 static const struct soc15_baco_cmd_entry enter_baco_tbl
[] =
42 { CMD_WAITFOR
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__SOC_DOMAIN_IDLE_MASK
, THM_BACO_CNTL__SOC_DOMAIN_IDLE__SHIFT
, 0xffffffff, 0x80000000 },
43 { CMD_READMODIFYWRITE
, NBIF_HWID
, 0, mmRCC_BACO_CNTL_MISC_BASE_IDX
, mmBACO_CNTL
, BACO_CNTL__BACO_EN_MASK
, BACO_CNTL__BACO_EN__SHIFT
, 0, 1 },
44 { CMD_READMODIFYWRITE
, NBIF_HWID
, 0, mmRCC_BACO_CNTL_MISC_BASE_IDX
, mmBACO_CNTL
, BACO_CNTL__BACO_BIF_LCLK_SWITCH_MASK
, BACO_CNTL__BACO_BIF_LCLK_SWITCH__SHIFT
, 0, 1 },
45 { CMD_READMODIFYWRITE
, NBIF_HWID
, 0, mmRCC_BACO_CNTL_MISC_BASE_IDX
, mmBACO_CNTL
, BACO_CNTL__BACO_DUMMY_EN_MASK
, BACO_CNTL__BACO_DUMMY_EN__SHIFT
, 0, 1 },
46 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_SOC_VDCI_RESET_MASK
, THM_BACO_CNTL__BACO_SOC_VDCI_RESET__SHIFT
, 0, 1 },
47 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_SMNCLK_MUX_MASK
, THM_BACO_CNTL__BACO_SMNCLK_MUX__SHIFT
, 0, 1 },
48 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_ISO_EN_MASK
, THM_BACO_CNTL__BACO_ISO_EN__SHIFT
, 0, 1 },
49 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_AEB_ISO_EN_MASK
, THM_BACO_CNTL__BACO_AEB_ISO_EN__SHIFT
, 0, 1 },
50 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_ANA_ISO_EN_MASK
, THM_BACO_CNTL__BACO_ANA_ISO_EN__SHIFT
, 0, 1 },
51 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_SOC_REFCLK_OFF_MASK
, THM_BACO_CNTL__BACO_SOC_REFCLK_OFF__SHIFT
, 0, 1 },
52 { CMD_READMODIFYWRITE
, NBIF_HWID
, 0, mmRCC_BACO_CNTL_MISC_BASE_IDX
, mmBACO_CNTL
, BACO_CNTL__BACO_POWER_OFF_MASK
, BACO_CNTL__BACO_POWER_OFF__SHIFT
, 0, 1 },
53 { CMD_DELAY_MS
, 0, 0, 0, 5, 0 },
54 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_RESET_EN_MASK
, THM_BACO_CNTL__BACO_RESET_EN__SHIFT
, 0, 1 },
55 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_PWROKRAW_CNTL_MASK
, THM_BACO_CNTL__BACO_PWROKRAW_CNTL__SHIFT
, 0, 0 },
56 { CMD_WAITFOR
, NBIF_HWID
, 0, mmRCC_BACO_CNTL_MISC_BASE_IDX
, mmBACO_CNTL
, BACO_CNTL__BACO_MODE_MASK
, BACO_CNTL__BACO_MODE__SHIFT
, 0xffffffff, 0x100 }
59 static const struct soc15_baco_cmd_entry exit_baco_tbl
[] =
61 { CMD_READMODIFYWRITE
, NBIF_HWID
, 0, mmRCC_BACO_CNTL_MISC_BASE_IDX
, mmBACO_CNTL
, BACO_CNTL__BACO_POWER_OFF_MASK
, BACO_CNTL__BACO_POWER_OFF__SHIFT
, 0, 0 },
62 { CMD_DELAY_MS
, 0, 0, 0, 0, 0, 0, 10, 0 },
63 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_SOC_REFCLK_OFF_MASK
, THM_BACO_CNTL__BACO_SOC_REFCLK_OFF__SHIFT
, 0, 0 },
64 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_ANA_ISO_EN_MASK
, THM_BACO_CNTL__BACO_ANA_ISO_EN__SHIFT
, 0, 0 },
65 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_AEB_ISO_EN_MASK
, THM_BACO_CNTL__BACO_AEB_ISO_EN__SHIFT
, 0, 0 },
66 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_ISO_EN_MASK
, THM_BACO_CNTL__BACO_ISO_EN__SHIFT
, 0, 0 },
67 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_PWROKRAW_CNTL_MASK
, THM_BACO_CNTL__BACO_PWROKRAW_CNTL__SHIFT
, 0, 1 },
68 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_SMNCLK_MUX_MASK
, THM_BACO_CNTL__BACO_SMNCLK_MUX__SHIFT
, 0, 0 },
69 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_SOC_VDCI_RESET_MASK
, THM_BACO_CNTL__BACO_SOC_VDCI_RESET__SHIFT
, 0, 0 },
70 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_EXIT_MASK
, THM_BACO_CNTL__BACO_EXIT__SHIFT
, 0, 1 },
71 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_RESET_EN_MASK
, THM_BACO_CNTL__BACO_RESET_EN__SHIFT
, 0, 0 },
72 { CMD_WAITFOR
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_EXIT_MASK
, 0, 0xffffffff, 0 },
73 { CMD_READMODIFYWRITE
, THM_HWID
, 0, mmTHM_BACO_CNTL_BASE_IDX
, mmTHM_BACO_CNTL
, THM_BACO_CNTL__BACO_SB_AXI_FENCE_MASK
, THM_BACO_CNTL__BACO_SB_AXI_FENCE__SHIFT
, 0, 0 },
74 { CMD_READMODIFYWRITE
, NBIF_HWID
, 0, mmRCC_BACO_CNTL_MISC_BASE_IDX
, mmBACO_CNTL
, BACO_CNTL__BACO_DUMMY_EN_MASK
, BACO_CNTL__BACO_DUMMY_EN__SHIFT
, 0, 0 },
75 { CMD_READMODIFYWRITE
, NBIF_HWID
, 0, mmRCC_BACO_CNTL_MISC_BASE_IDX
, mmBACO_CNTL
, BACO_CNTL__BACO_BIF_LCLK_SWITCH_MASK
, BACO_CNTL__BACO_BIF_LCLK_SWITCH__SHIFT
, 0, 0 },
76 { CMD_READMODIFYWRITE
, NBIF_HWID
, 0, mmRCC_BACO_CNTL_MISC_BASE_IDX
, mmBACO_CNTL
, BACO_CNTL__BACO_EN_MASK
, BACO_CNTL__BACO_EN__SHIFT
, 0, 0 },
77 { CMD_WAITFOR
, NBIF_HWID
, 0, mmRCC_BACO_CNTL_MISC_BASE_IDX
, mmBACO_CNTL
, BACO_CNTL__BACO_MODE_MASK
, 0, 0xffffffff, 0 }
80 static const struct soc15_baco_cmd_entry clean_baco_tbl
[] =
82 { CMD_WRITE
, NBIF_HWID
, 0, mmBIOS_SCRATCH_6_BASE_IDX
, mmBIOS_SCRATCH_6
, 0, 0, 0, 0 },
83 { CMD_WRITE
, NBIF_HWID
, 0, mmBIOS_SCRATCH_7_BASE_IDX
, mmBIOS_SCRATCH_7
, 0, 0, 0, 0 }
86 int vega12_baco_set_state(struct pp_hwmgr
*hwmgr
, enum BACO_STATE state
)
88 enum BACO_STATE cur_state
;
90 smu9_baco_get_state(hwmgr
, &cur_state
);
92 if (cur_state
== state
)
93 /* aisc already in the target state */
96 if (state
== BACO_STATE_IN
) {
97 if (soc15_baco_program_registers(hwmgr
, pre_baco_tbl
,
98 ARRAY_SIZE(pre_baco_tbl
))) {
99 if (smum_send_msg_to_smc_with_parameter(hwmgr
, PPSMC_MSG_EnterBaco
, 0))
102 if (soc15_baco_program_registers(hwmgr
, enter_baco_tbl
,
103 ARRAY_SIZE(enter_baco_tbl
)))
106 } else if (state
== BACO_STATE_OUT
) {
107 /* HW requires at least 20ms between regulator off and on */
109 /* Execute Hardware BACO exit sequence */
110 if (soc15_baco_program_registers(hwmgr
, exit_baco_tbl
,
111 ARRAY_SIZE(exit_baco_tbl
))) {
112 if (soc15_baco_program_registers(hwmgr
, clean_baco_tbl
,
113 ARRAY_SIZE(clean_baco_tbl
)))