xref: /rk3399_ARM-atf/plat/mediatek/drivers/spm/mt8189/mt_spm_internal.c (revision af0370f25a6663a0d737bbfb3985df4232eaaa55)
1*5f748b3cSKun Lu /*
2*5f748b3cSKun Lu  * Copyright (c) 2025, Mediatek Inc. All rights reserved.
3*5f748b3cSKun Lu  *
4*5f748b3cSKun Lu  * SPDX-License-Identifier: BSD-3-Clause
5*5f748b3cSKun Lu  */
6*5f748b3cSKun Lu 
7*5f748b3cSKun Lu #include <assert.h>
8*5f748b3cSKun Lu #include <stddef.h>
9*5f748b3cSKun Lu #include <stdio.h>
10*5f748b3cSKun Lu #include <string.h>
11*5f748b3cSKun Lu 
12*5f748b3cSKun Lu #include <common/debug.h>
13*5f748b3cSKun Lu #include <drivers/delay_timer.h>
14*5f748b3cSKun Lu #include <lib/mmio.h>
15*5f748b3cSKun Lu #include <plat/common/platform.h>
16*5f748b3cSKun Lu 
17*5f748b3cSKun Lu #include <drivers/spm/mt_spm_resource_req.h>
18*5f748b3cSKun Lu #include <mt_plat_spm_setting.h>
19*5f748b3cSKun Lu #include <mt_spm.h>
20*5f748b3cSKun Lu #include <mt_spm_internal.h>
21*5f748b3cSKun Lu #include <mt_spm_reg.h>
22*5f748b3cSKun Lu #include <platform_def.h>
23*5f748b3cSKun Lu #include <pmic_wrap/inc/mt_spm_pmic_wrap.h>
24*5f748b3cSKun Lu 
25*5f748b3cSKun Lu /**************************************
26*5f748b3cSKun Lu  * Define and Declare
27*5f748b3cSKun Lu  **************************************/
28*5f748b3cSKun Lu #define SPM_INIT_DONE_US 20 /* Simulation result */
29*5f748b3cSKun Lu 
30*5f748b3cSKun Lu /**************************************
31*5f748b3cSKun Lu  * Function and API
32*5f748b3cSKun Lu  **************************************/
33*5f748b3cSKun Lu 
__spm_output_wake_reason(const struct wake_status * wakesta)34*5f748b3cSKun Lu wake_reason_t __spm_output_wake_reason(const struct wake_status *wakesta)
35*5f748b3cSKun Lu {
36*5f748b3cSKun Lu 	uint32_t i;
37*5f748b3cSKun Lu 	wake_reason_t wr = WR_UNKNOWN;
38*5f748b3cSKun Lu 
39*5f748b3cSKun Lu 	if (!wakesta)
40*5f748b3cSKun Lu 		return WR_UNKNOWN;
41*5f748b3cSKun Lu 
42*5f748b3cSKun Lu 	if (wakesta->is_abort) {
43*5f748b3cSKun Lu 		INFO("SPM EARLY WAKE r13 = 0x%x, ", wakesta->tr.comm.r13);
44*5f748b3cSKun Lu 		INFO("debug_flag = 0x%x 0x%x sw_flag = 0x%x 0x%x b_sw_flag = 0x%x 0x%x\n",
45*5f748b3cSKun Lu 		     wakesta->tr.comm.debug_flag, wakesta->tr.comm.debug_flag1,
46*5f748b3cSKun Lu 		     wakesta->sw_flag0, wakesta->sw_flag1,
47*5f748b3cSKun Lu 		     wakesta->tr.comm.b_sw_flag0, wakesta->tr.comm.b_sw_flag1);
48*5f748b3cSKun Lu #ifndef MTK_PLAT_SPM_PMIC_WRAP_DUMP_UNSUPPORT
49*5f748b3cSKun Lu 		mt_spm_dump_pmic_warp_reg();
50*5f748b3cSKun Lu #endif
51*5f748b3cSKun Lu 	}
52*5f748b3cSKun Lu 
53*5f748b3cSKun Lu 	if (wakesta->tr.comm.r12 & R12_PCM_TIMER_B) {
54*5f748b3cSKun Lu 		if (wakesta->wake_misc & WAKE_MISC_PCM_TIMER_EVENT)
55*5f748b3cSKun Lu 			wr = WR_PCM_TIMER;
56*5f748b3cSKun Lu 	}
57*5f748b3cSKun Lu 
58*5f748b3cSKun Lu 	if (wakesta->tr.comm.r12 & R12_TWAM_PMSR_DVFSRC) {
59*5f748b3cSKun Lu 		if (wakesta->wake_misc & WAKE_MISC_DVFSRC_IRQ)
60*5f748b3cSKun Lu 			wr = WR_DVFSRC;
61*5f748b3cSKun Lu 
62*5f748b3cSKun Lu 		if (wakesta->wake_misc & WAKE_MISC_TWAM_IRQ_B)
63*5f748b3cSKun Lu 			wr = WR_TWAM;
64*5f748b3cSKun Lu 
65*5f748b3cSKun Lu 		if (wakesta->wake_misc & WAKE_MISC_SPM_ACK_CHK_WAKEUP_0)
66*5f748b3cSKun Lu 			wr = WR_SPM_ACK_CHK;
67*5f748b3cSKun Lu 
68*5f748b3cSKun Lu 		if (wakesta->wake_misc & WAKE_MISC_SPM_ACK_CHK_WAKEUP_1)
69*5f748b3cSKun Lu 			wr = WR_SPM_ACK_CHK;
70*5f748b3cSKun Lu 
71*5f748b3cSKun Lu 		if (wakesta->wake_misc & WAKE_MISC_SPM_ACK_CHK_WAKEUP_2)
72*5f748b3cSKun Lu 			wr = WR_SPM_ACK_CHK;
73*5f748b3cSKun Lu 
74*5f748b3cSKun Lu 		if (wakesta->wake_misc & WAKE_MISC_SPM_ACK_CHK_WAKEUP_3)
75*5f748b3cSKun Lu 			wr = WR_SPM_ACK_CHK;
76*5f748b3cSKun Lu 
77*5f748b3cSKun Lu 		if (wakesta->wake_misc & WAKE_MISC_SPM_ACK_CHK_WAKEUP_ALL)
78*5f748b3cSKun Lu 			wr = WR_SPM_ACK_CHK;
79*5f748b3cSKun Lu 	}
80*5f748b3cSKun Lu 
81*5f748b3cSKun Lu 	for (i = 2; i < 32; i++) {
82*5f748b3cSKun Lu 		if (wakesta->tr.comm.r12 & (1U << i))
83*5f748b3cSKun Lu 			wr = WR_WAKE_SRC;
84*5f748b3cSKun Lu 	}
85*5f748b3cSKun Lu 
86*5f748b3cSKun Lu 	return wr;
87*5f748b3cSKun Lu }
88*5f748b3cSKun Lu 
__spm_set_cpu_status(int cpu)89*5f748b3cSKun Lu void __spm_set_cpu_status(int cpu)
90*5f748b3cSKun Lu {
91*5f748b3cSKun Lu }
92*5f748b3cSKun Lu 
spm_code_swapping(void)93*5f748b3cSKun Lu static void spm_code_swapping(void)
94*5f748b3cSKun Lu {
95*5f748b3cSKun Lu 	uint32_t con1;
96*5f748b3cSKun Lu 	/* int retry = 0, timeout = 5000; */
97*5f748b3cSKun Lu 
98*5f748b3cSKun Lu 	con1 = mmio_read_32(SPM_WAKEUP_EVENT_MASK);
99*5f748b3cSKun Lu 
100*5f748b3cSKun Lu 	mmio_write_32(SPM_WAKEUP_EVENT_MASK, (con1 & ~(0x1)));
101*5f748b3cSKun Lu 	mmio_write_32(SPM_CPU_WAKEUP_EVENT, 1);
102*5f748b3cSKun Lu 	mmio_write_32(SPM_CPU_WAKEUP_EVENT, 0);
103*5f748b3cSKun Lu 	mmio_write_32(SPM_WAKEUP_EVENT_MASK, con1);
104*5f748b3cSKun Lu }
105*5f748b3cSKun Lu 
__spm_reset_and_init_pcm(const struct pcm_desc * pcmdesc)106*5f748b3cSKun Lu void __spm_reset_and_init_pcm(const struct pcm_desc *pcmdesc)
107*5f748b3cSKun Lu {
108*5f748b3cSKun Lu 	unsigned char first_load_fw = true;
109*5f748b3cSKun Lu 
110*5f748b3cSKun Lu 	/* check the SPM FW is run or not */
111*5f748b3cSKun Lu 	if (mmio_read_32(MD32PCM_CFGREG_SW_RSTN) & 0x1)
112*5f748b3cSKun Lu 		first_load_fw = false;
113*5f748b3cSKun Lu 
114*5f748b3cSKun Lu 	if (!first_load_fw) {
115*5f748b3cSKun Lu 		/* SPM code swapping */
116*5f748b3cSKun Lu 		spm_code_swapping();
117*5f748b3cSKun Lu 
118*5f748b3cSKun Lu 		/* Backup PCM r0 -> SPM_POWER_ON_VAL0 before `reset PCM` */
119*5f748b3cSKun Lu 		mmio_write_32(SPM_POWER_ON_VAL0,
120*5f748b3cSKun Lu 			      mmio_read_32(MD32PCM_SCU_CTRL0));
121*5f748b3cSKun Lu 	}
122*5f748b3cSKun Lu 
123*5f748b3cSKun Lu 	/* disable r0 and r7 to control power */
124*5f748b3cSKun Lu 	mmio_write_32(PCM_PWR_IO_EN, 0);
125*5f748b3cSKun Lu 
126*5f748b3cSKun Lu 	/* disable pcm timer after leaving FW */
127*5f748b3cSKun Lu 	mmio_clrsetbits_32(PCM_CON1, SPM_REGWR_CFG_KEY, REG_PCM_TIMER_EN_LSB);
128*5f748b3cSKun Lu 
129*5f748b3cSKun Lu 	/* reset PCM */
130*5f748b3cSKun Lu 	mmio_write_32(PCM_CON0,
131*5f748b3cSKun Lu 		      SPM_REGWR_CFG_KEY | PCM_CK_EN_LSB | PCM_SW_RESET_LSB);
132*5f748b3cSKun Lu 	mmio_write_32(PCM_CON0, SPM_REGWR_CFG_KEY | PCM_CK_EN_LSB);
133*5f748b3cSKun Lu 
134*5f748b3cSKun Lu 	/* init PCM_CON1 (disable PCM timer but keep PCM WDT setting) */
135*5f748b3cSKun Lu 	mmio_clrsetbits_32(PCM_CON1, REG_PCM_WDT_WAKE_LSB,
136*5f748b3cSKun Lu 			   SPM_REGWR_CFG_KEY | REG_SPM_APB_INTERNAL_EN_LSB |
137*5f748b3cSKun Lu 				   REG_SSPM_APB_P2P_EN_LSB);
138*5f748b3cSKun Lu }
139*5f748b3cSKun Lu 
__spm_kick_im_to_fetch(const struct pcm_desc * pcmdesc)140*5f748b3cSKun Lu void __spm_kick_im_to_fetch(const struct pcm_desc *pcmdesc)
141*5f748b3cSKun Lu {
142*5f748b3cSKun Lu 	uint32_t pmem_words;
143*5f748b3cSKun Lu 	uint32_t total_words;
144*5f748b3cSKun Lu 	uint32_t pmem_start;
145*5f748b3cSKun Lu 	uint32_t dmem_start;
146*5f748b3cSKun Lu 	uint32_t ptr;
147*5f748b3cSKun Lu 
148*5f748b3cSKun Lu 	/* tell IM where is PCM code (use slave mode if code existed) */
149*5f748b3cSKun Lu 	ptr = pcmdesc->base_dma + 0x40000000;
150*5f748b3cSKun Lu 	pmem_words = pcmdesc->pmem_words;
151*5f748b3cSKun Lu 	total_words = pcmdesc->total_words;
152*5f748b3cSKun Lu 	pmem_start = pcmdesc->pmem_start;
153*5f748b3cSKun Lu 	dmem_start = pcmdesc->dmem_start;
154*5f748b3cSKun Lu 
155*5f748b3cSKun Lu 	if (mmio_read_32(MD32PCM_DMA0_SRC) != ptr ||
156*5f748b3cSKun Lu 	    mmio_read_32(MD32PCM_DMA0_DST) != pmem_start ||
157*5f748b3cSKun Lu 	    mmio_read_32(MD32PCM_DMA0_WPPT) != pmem_words ||
158*5f748b3cSKun Lu 	    mmio_read_32(MD32PCM_DMA0_WPTO) != dmem_start ||
159*5f748b3cSKun Lu 	    mmio_read_32(MD32PCM_DMA0_COUNT) != total_words ||
160*5f748b3cSKun Lu 	    mmio_read_32(MD32PCM_DMA0_CON) != 0x0003820E) {
161*5f748b3cSKun Lu 		mmio_write_32(MD32PCM_DMA0_SRC, ptr);
162*5f748b3cSKun Lu 		mmio_write_32(MD32PCM_DMA0_DST, pmem_start);
163*5f748b3cSKun Lu 		mmio_write_32(MD32PCM_DMA0_WPPT, pmem_words);
164*5f748b3cSKun Lu 		mmio_write_32(MD32PCM_DMA0_WPTO, dmem_start);
165*5f748b3cSKun Lu 		mmio_write_32(MD32PCM_DMA0_COUNT, total_words);
166*5f748b3cSKun Lu 		mmio_write_32(MD32PCM_DMA0_CON, 0x0003820E);
167*5f748b3cSKun Lu 		mmio_write_32(MD32PCM_DMA0_START, 0x00008000);
168*5f748b3cSKun Lu 	}
169*5f748b3cSKun Lu 
170*5f748b3cSKun Lu 	/* kick IM to fetch (only toggle IM_KICK) */
171*5f748b3cSKun Lu 	mmio_setbits_32(PCM_CON0, SPM_REGWR_CFG_KEY | PCM_CK_EN_LSB);
172*5f748b3cSKun Lu }
173*5f748b3cSKun Lu 
__spm_init_pcm_register(void)174*5f748b3cSKun Lu void __spm_init_pcm_register(void)
175*5f748b3cSKun Lu {
176*5f748b3cSKun Lu 	/* disable r0 and r7 to control power */
177*5f748b3cSKun Lu 	mmio_write_32(PCM_PWR_IO_EN, 0);
178*5f748b3cSKun Lu }
179*5f748b3cSKun Lu 
__spm_set_power_control(const struct pwr_ctrl * pwrctrl,uint32_t resource_usage)180*5f748b3cSKun Lu void __spm_set_power_control(const struct pwr_ctrl *pwrctrl,
181*5f748b3cSKun Lu 			     uint32_t resource_usage)
182*5f748b3cSKun Lu {
183*5f748b3cSKun Lu 	/* Auto-gen Start */
184*5f748b3cSKun Lu 
185*5f748b3cSKun Lu 	/* SPM_SRC_REQ */
186*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_REQ,
187*5f748b3cSKun Lu 		((pwrctrl->reg_spm_adsp_mailbox_req & 0x1) << 0) |
188*5f748b3cSKun Lu 		(((pwrctrl->reg_spm_apsrc_req |
189*5f748b3cSKun Lu 		  !!(resource_usage & MT_SPM_DRAM_S0)) & 0x1) << 1) |
190*5f748b3cSKun Lu 		(((pwrctrl->reg_spm_ddren_req |
191*5f748b3cSKun Lu 		  !!(resource_usage & MT_SPM_DRAM_S1)) & 0x1) << 2) |
192*5f748b3cSKun Lu 		((pwrctrl->reg_spm_dvfs_req & 0x1) << 3) |
193*5f748b3cSKun Lu 		(((pwrctrl->reg_spm_emi_req |
194*5f748b3cSKun Lu 		  !!(resource_usage & MT_SPM_EMI)) & 0x1) << 4) |
195*5f748b3cSKun Lu 		(((pwrctrl->reg_spm_f26m_req |
196*5f748b3cSKun Lu 		  !!(resource_usage & (MT_SPM_26M | MT_SPM_XO_FPM))) & 0x1) << 5) |
197*5f748b3cSKun Lu 		(((pwrctrl->reg_spm_infra_req |
198*5f748b3cSKun Lu 		  !!(resource_usage & MT_SPM_INFRA)) & 0x1) << 6) |
199*5f748b3cSKun Lu 		(((pwrctrl->reg_spm_pmic_req |
200*5f748b3cSKun Lu 		  !!(resource_usage & MT_SPM_PMIC)) & 0x1) << 7) |
201*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_spm_scp_mailbox_req & 0x1) << 8) |
202*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_spm_sspm_mailbox_req & 0x1) << 9) |
203*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_spm_sw_mailbox_req & 0x1) << 10) |
204*5f748b3cSKun Lu 		((((uint32_t)pwrctrl->reg_spm_vcore_req |
205*5f748b3cSKun Lu 		  !!(resource_usage & MT_SPM_VCORE)) & 0x1) << 11) |
206*5f748b3cSKun Lu 		((((uint32_t)pwrctrl->reg_spm_vrf18_req |
207*5f748b3cSKun Lu 		  !!(resource_usage & MT_SPM_SYSPLL)) & 0x1) << 12) |
208*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->adsp_mailbox_state & 0x1) << 16) |
209*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->apsrc_state & 0x1) << 17) |
210*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->ddren_state & 0x1) << 18) |
211*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->dvfs_state & 0x1) << 19) |
212*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->emi_state & 0x1) << 20) |
213*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->f26m_state & 0x1) << 21) |
214*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->infra_state & 0x1) << 22) |
215*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->pmic_state & 0x1) << 23) |
216*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->scp_mailbox_state & 0x1) << 24) |
217*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->sspm_mailbox_state & 0x1) << 25) |
218*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->sw_mailbox_state & 0x1) << 26) |
219*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->vcore_state & 0x1) << 27) |
220*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->vrf18_state & 0x1) << 28));
221*5f748b3cSKun Lu 
222*5f748b3cSKun Lu 	/* SPM_SRC_MASK_0 */
223*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_0,
224*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_apu_apsrc_req_mask_b & 0x1) << 0) |
225*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_apu_ddren_req_mask_b & 0x1) << 1) |
226*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_apu_emi_req_mask_b & 0x1) << 2) |
227*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_apu_infra_req_mask_b & 0x1) << 3) |
228*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_apu_pmic_req_mask_b & 0x1) << 4) |
229*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_apu_srcclkena_mask_b & 0x1) << 5) |
230*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_apu_vrf18_req_mask_b & 0x1) << 6) |
231*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_audio_dsp_apsrc_req_mask_b & 0x1) << 7) |
232*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_audio_dsp_ddren_req_mask_b & 0x1) << 8) |
233*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_audio_dsp_emi_req_mask_b & 0x1) << 9) |
234*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_audio_dsp_infra_req_mask_b & 0x1) << 10) |
235*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_audio_dsp_pmic_req_mask_b & 0x1) << 11) |
236*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_audio_dsp_srcclkena_mask_b & 0x1) << 12) |
237*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_audio_dsp_vcore_req_mask_b & 0x1) << 13) |
238*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_audio_dsp_vrf18_req_mask_b & 0x1) << 14) |
239*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cam_apsrc_req_mask_b & 0x1) << 15) |
240*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cam_ddren_req_mask_b & 0x1) << 16) |
241*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cam_emi_req_mask_b & 0x1) << 17) |
242*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cam_infra_req_mask_b & 0x1) << 18) |
243*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cam_pmic_req_mask_b & 0x1) << 19) |
244*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cam_srcclkena_mask_b & 0x1) << 20) |
245*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cam_vrf18_req_mask_b & 0x1) << 21) |
246*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mdp_emi_req_mask_b & 0x1) << 22));
247*5f748b3cSKun Lu 
248*5f748b3cSKun Lu 	/* SPM_SRC_MASK_1 */
249*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_1,
250*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccif_apsrc_req_mask_b & 0xfff) << 0) |
251*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccif_emi_req_mask_b & 0xfff) << 12));
252*5f748b3cSKun Lu 
253*5f748b3cSKun Lu 	/* SPM_SRC_MASK_2 */
254*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_2,
255*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccif_infra_req_mask_b & 0xfff) << 0) |
256*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccif_pmic_req_mask_b & 0xfff) << 12));
257*5f748b3cSKun Lu 
258*5f748b3cSKun Lu 	/* SPM_SRC_MASK_3 */
259*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_3,
260*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccif_srcclkena_mask_b & 0xfff) << 0) |
261*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccif_vrf18_req_mask_b & 0xfff) << 12) |
262*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccu_apsrc_req_mask_b & 0x1) << 24) |
263*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccu_ddren_req_mask_b & 0x1) << 25) |
264*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccu_emi_req_mask_b & 0x1) << 26) |
265*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccu_infra_req_mask_b & 0x1) << 27) |
266*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccu_pmic_req_mask_b & 0x1) << 28) |
267*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccu_srcclkena_mask_b & 0x1) << 29) |
268*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ccu_vrf18_req_mask_b & 0x1) << 30) |
269*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cg_check_apsrc_req_mask_b & 0x1) << 31));
270*5f748b3cSKun Lu 
271*5f748b3cSKun Lu 	/* SPM_SRC_MASK_4 */
272*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_4,
273*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cg_check_ddren_req_mask_b & 0x1) << 0) |
274*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cg_check_emi_req_mask_b & 0x1) << 1) |
275*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cg_check_infra_req_mask_b & 0x1) << 2) |
276*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cg_check_pmic_req_mask_b & 0x1) << 3) |
277*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cg_check_srcclkena_mask_b & 0x1) << 4) |
278*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cg_check_vcore_req_mask_b & 0x1) << 5) |
279*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cg_check_vrf18_req_mask_b & 0x1) << 6) |
280*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_conn_apsrc_req_mask_b & 0x1) << 7) |
281*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_conn_ddren_req_mask_b & 0x1) << 8) |
282*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_conn_emi_req_mask_b & 0x1) << 9) |
283*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_conn_infra_req_mask_b & 0x1) << 10) |
284*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_conn_pmic_req_mask_b & 0x1) << 11) |
285*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_conn_srcclkena_mask_b & 0x1) << 12) |
286*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_conn_srcclkenb_mask_b & 0x1) << 13) |
287*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_conn_vcore_req_mask_b & 0x1) << 14) |
288*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_conn_vrf18_req_mask_b & 0x1) << 15) |
289*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cpueb_apsrc_req_mask_b & 0x1) << 16) |
290*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cpueb_ddren_req_mask_b & 0x1) << 17) |
291*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cpueb_emi_req_mask_b & 0x1) << 18) |
292*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cpueb_infra_req_mask_b & 0x1) << 19) |
293*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cpueb_pmic_req_mask_b & 0x1) << 20) |
294*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cpueb_srcclkena_mask_b & 0x1) << 21) |
295*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_cpueb_vrf18_req_mask_b & 0x1) << 22) |
296*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp0_apsrc_req_mask_b & 0x1) << 23) |
297*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp0_ddren_req_mask_b & 0x1) << 24) |
298*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp0_emi_req_mask_b & 0x1) << 25) |
299*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp0_infra_req_mask_b & 0x1) << 26) |
300*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp0_pmic_req_mask_b & 0x1) << 27) |
301*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp0_srcclkena_mask_b & 0x1) << 28) |
302*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp0_vrf18_req_mask_b & 0x1) << 29) |
303*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp1_apsrc_req_mask_b & 0x1) << 30) |
304*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp1_ddren_req_mask_b & 0x1) << 31));
305*5f748b3cSKun Lu 
306*5f748b3cSKun Lu 	/* SPM_SRC_MASK_5 */
307*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_5,
308*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp1_emi_req_mask_b & 0x1) << 0) |
309*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp1_infra_req_mask_b & 0x1) << 1) |
310*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp1_pmic_req_mask_b & 0x1) << 2) |
311*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp1_srcclkena_mask_b & 0x1) << 3) |
312*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_disp1_vrf18_req_mask_b & 0x1) << 4) |
313*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpm_apsrc_req_mask_b & 0xf) << 5) |
314*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpm_ddren_req_mask_b & 0xf) << 9) |
315*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpm_emi_req_mask_b & 0xf) << 13) |
316*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpm_infra_req_mask_b & 0xf) << 17) |
317*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpm_pmic_req_mask_b & 0xf) << 21) |
318*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpm_srcclkena_mask_b & 0xf) << 25));
319*5f748b3cSKun Lu 
320*5f748b3cSKun Lu 	/* SPM_SRC_MASK_6 */
321*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_6,
322*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpm_vcore_req_mask_b & 0xf) << 0) |
323*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpm_vrf18_req_mask_b & 0xf) << 4) |
324*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpmaif_apsrc_req_mask_b & 0x1) << 8) |
325*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpmaif_ddren_req_mask_b & 0x1) << 9) |
326*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpmaif_emi_req_mask_b & 0x1) << 10) |
327*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpmaif_infra_req_mask_b & 0x1) << 11) |
328*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpmaif_pmic_req_mask_b & 0x1) << 12) |
329*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpmaif_srcclkena_mask_b & 0x1) << 13) |
330*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dpmaif_vrf18_req_mask_b & 0x1) << 14) |
331*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_dvfsrc_level_req_mask_b & 0x1) << 15) |
332*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_emisys_apsrc_req_mask_b & 0x1) << 16) |
333*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_emisys_ddren_req_mask_b & 0x1) << 17) |
334*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_emisys_emi_req_mask_b & 0x1) << 18) |
335*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_d_apsrc_req_mask_b & 0x1) << 19) |
336*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_d_ddren_req_mask_b & 0x1) << 20) |
337*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_d_emi_req_mask_b & 0x1) << 21) |
338*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_d_infra_req_mask_b & 0x1) << 22) |
339*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_d_pmic_req_mask_b & 0x1) << 23) |
340*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_d_srcclkena_mask_b & 0x1) << 24) |
341*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_d_vrf18_req_mask_b & 0x1) << 25) |
342*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_m_apsrc_req_mask_b & 0x1) << 26) |
343*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_m_ddren_req_mask_b & 0x1) << 27) |
344*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_m_emi_req_mask_b & 0x1) << 28) |
345*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_m_infra_req_mask_b & 0x1) << 29) |
346*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_m_pmic_req_mask_b & 0x1) << 30) |
347*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_m_srcclkena_mask_b & 0x1) << 31));
348*5f748b3cSKun Lu 
349*5f748b3cSKun Lu 	/* SPM_SRC_MASK_7 */
350*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_7,
351*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gce_m_vrf18_req_mask_b & 0x1) << 0) |
352*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gpueb_apsrc_req_mask_b & 0x1) << 1) |
353*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gpueb_ddren_req_mask_b & 0x1) << 2) |
354*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gpueb_emi_req_mask_b & 0x1) << 3) |
355*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gpueb_infra_req_mask_b & 0x1) << 4) |
356*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gpueb_pmic_req_mask_b & 0x1) << 5) |
357*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gpueb_srcclkena_mask_b & 0x1) << 6) |
358*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_gpueb_vrf18_req_mask_b & 0x1) << 7) |
359*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_hwccf_apsrc_req_mask_b & 0x1) << 8) |
360*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_hwccf_ddren_req_mask_b & 0x1) << 9) |
361*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_hwccf_emi_req_mask_b & 0x1) << 10) |
362*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_hwccf_infra_req_mask_b & 0x1) << 11) |
363*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_hwccf_pmic_req_mask_b & 0x1) << 12) |
364*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_hwccf_srcclkena_mask_b & 0x1) << 13) |
365*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_hwccf_vcore_req_mask_b & 0x1) << 14) |
366*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_hwccf_vrf18_req_mask_b & 0x1) << 15) |
367*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_img_apsrc_req_mask_b & 0x1) << 16) |
368*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_img_ddren_req_mask_b & 0x1) << 17) |
369*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_img_emi_req_mask_b & 0x1) << 18) |
370*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_img_infra_req_mask_b & 0x1) << 19) |
371*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_img_pmic_req_mask_b & 0x1) << 20) |
372*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_img_srcclkena_mask_b & 0x1) << 21) |
373*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_img_vrf18_req_mask_b & 0x1) << 22) |
374*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_infrasys_apsrc_req_mask_b & 0x1) << 23) |
375*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_infrasys_ddren_req_mask_b & 0x1) << 24) |
376*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_infrasys_emi_req_mask_b & 0x1) << 25) |
377*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ipic_infra_req_mask_b & 0x1) << 26) |
378*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ipic_vrf18_req_mask_b & 0x1) << 27) |
379*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mcu_apsrc_req_mask_b & 0x1) << 28) |
380*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mcu_ddren_req_mask_b & 0x1) << 29) |
381*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mcu_emi_req_mask_b & 0x1) << 30));
382*5f748b3cSKun Lu 
383*5f748b3cSKun Lu 	/* SPM_SRC_MASK_8 */
384*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_8,
385*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mcusys_apsrc_req_mask_b & 0xff) << 0) |
386*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mcusys_ddren_req_mask_b & 0xff) << 8) |
387*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mcusys_emi_req_mask_b & 0xff) << 16) |
388*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mcusys_infra_req_mask_b & 0xff) << 24));
389*5f748b3cSKun Lu 
390*5f748b3cSKun Lu 	/* SPM_SRC_MASK_9 */
391*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_9,
392*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mcusys_pmic_req_mask_b & 0xff) << 0) |
393*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mcusys_srcclkena_mask_b & 0xff) << 8) |
394*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mcusys_vrf18_req_mask_b & 0xff) << 16) |
395*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_md_apsrc_req_mask_b & 0x1) << 24) |
396*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_md_ddren_req_mask_b & 0x1) << 25) |
397*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_md_emi_req_mask_b & 0x1) << 26) |
398*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_md_infra_req_mask_b & 0x1) << 27) |
399*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_md_pmic_req_mask_b & 0x1) << 28) |
400*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_md_srcclkena_mask_b & 0x1) << 29) |
401*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_md_srcclkena1_mask_b & 0x1) << 30) |
402*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_md_vcore_req_mask_b & 0x1) << 31));
403*5f748b3cSKun Lu 
404*5f748b3cSKun Lu 	/* SPM_SRC_MASK_10 */
405*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_10,
406*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_md_vrf18_req_mask_b & 0x1) << 0) |
407*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mdp_apsrc_req_mask_b & 0x1) << 1) |
408*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mdp_ddren_req_mask_b & 0x1) << 2) |
409*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mm_proc_apsrc_req_mask_b & 0x1) << 3) |
410*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mm_proc_ddren_req_mask_b & 0x1) << 4) |
411*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mm_proc_emi_req_mask_b & 0x1) << 5) |
412*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mm_proc_infra_req_mask_b & 0x1) << 6) |
413*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mm_proc_pmic_req_mask_b & 0x1) << 7) |
414*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mm_proc_srcclkena_mask_b & 0x1) << 8) |
415*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mm_proc_vrf18_req_mask_b & 0x1) << 9) |
416*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mmsys_apsrc_req_mask_b & 0x1) << 10) |
417*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mmsys_ddren_req_mask_b & 0x1) << 11) |
418*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_mmsys_vrf18_req_mask_b & 0x1) << 12) |
419*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_pcie0_apsrc_req_mask_b & 0x1) << 13) |
420*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_pcie0_ddren_req_mask_b & 0x1) << 14) |
421*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_pcie0_infra_req_mask_b & 0x1) << 15) |
422*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_pcie0_srcclkena_mask_b & 0x1) << 16) |
423*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_pcie0_vrf18_req_mask_b & 0x1) << 17) |
424*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_pcie1_apsrc_req_mask_b & 0x1) << 18) |
425*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_pcie1_ddren_req_mask_b & 0x1) << 19) |
426*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_pcie1_infra_req_mask_b & 0x1) << 20) |
427*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_pcie1_srcclkena_mask_b & 0x1) << 21) |
428*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_pcie1_vrf18_req_mask_b & 0x1) << 22) |
429*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_perisys_apsrc_req_mask_b & 0x1) << 23) |
430*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_perisys_ddren_req_mask_b & 0x1) << 24) |
431*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_perisys_emi_req_mask_b & 0x1) << 25) |
432*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_perisys_infra_req_mask_b & 0x1) << 26) |
433*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_perisys_pmic_req_mask_b & 0x1) << 27) |
434*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_perisys_srcclkena_mask_b & 0x1) << 28) |
435*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_perisys_vcore_req_mask_b & 0x1) << 29) |
436*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_perisys_vrf18_req_mask_b & 0x1) << 30) |
437*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_scp_apsrc_req_mask_b & 0x1) << 31));
438*5f748b3cSKun Lu 
439*5f748b3cSKun Lu 	/* SPM_SRC_MASK_11 */
440*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_11,
441*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_scp_ddren_req_mask_b & 0x1) << 0) |
442*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_scp_emi_req_mask_b & 0x1) << 1) |
443*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_scp_infra_req_mask_b & 0x1) << 2) |
444*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_scp_pmic_req_mask_b & 0x1) << 3) |
445*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_scp_srcclkena_mask_b & 0x1) << 4) |
446*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_scp_vcore_req_mask_b & 0x1) << 5) |
447*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_scp_vrf18_req_mask_b & 0x1) << 6) |
448*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_srcclkeni_infra_req_mask_b & 0x3) << 7) |
449*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_srcclkeni_pmic_req_mask_b & 0x3) << 9) |
450*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_srcclkeni_srcclkena_mask_b & 0x3) << 11) |
451*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_sspm_apsrc_req_mask_b & 0x1) << 13) |
452*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_sspm_ddren_req_mask_b & 0x1) << 14) |
453*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_sspm_emi_req_mask_b & 0x1) << 15) |
454*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_sspm_infra_req_mask_b & 0x1) << 16) |
455*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_sspm_pmic_req_mask_b & 0x1) << 17) |
456*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_sspm_srcclkena_mask_b & 0x1) << 18) |
457*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_sspm_vrf18_req_mask_b & 0x1) << 19) |
458*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ssr_apsrc_req_mask_b & 0x1) << 20) |
459*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ssr_ddren_req_mask_b & 0x1) << 21) |
460*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ssr_emi_req_mask_b & 0x1) << 22) |
461*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ssr_infra_req_mask_b & 0x1) << 23) |
462*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ssr_pmic_req_mask_b & 0x1) << 24) |
463*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ssr_srcclkena_mask_b & 0x1) << 25) |
464*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ssr_vrf18_req_mask_b & 0x1) << 26) |
465*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ufs_apsrc_req_mask_b & 0x1) << 27) |
466*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ufs_ddren_req_mask_b & 0x1) << 28) |
467*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ufs_emi_req_mask_b & 0x1) << 29) |
468*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ufs_infra_req_mask_b & 0x1) << 30) |
469*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ufs_pmic_req_mask_b & 0x1) << 31));
470*5f748b3cSKun Lu 
471*5f748b3cSKun Lu 	/* SPM_SRC_MASK_12 */
472*5f748b3cSKun Lu 	mmio_write_32(SPM_SRC_MASK_12,
473*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ufs_srcclkena_mask_b & 0x1) << 0) |
474*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ufs_vrf18_req_mask_b & 0x1) << 1) |
475*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_vdec_apsrc_req_mask_b & 0x1) << 2) |
476*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_vdec_ddren_req_mask_b & 0x1) << 3) |
477*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_vdec_emi_req_mask_b & 0x1) << 4) |
478*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_vdec_infra_req_mask_b & 0x1) << 5) |
479*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_vdec_pmic_req_mask_b & 0x1) << 6) |
480*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_vdec_srcclkena_mask_b & 0x1) << 7) |
481*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_vdec_vrf18_req_mask_b & 0x1) << 8) |
482*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_venc_apsrc_req_mask_b & 0x1) << 9) |
483*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_venc_ddren_req_mask_b & 0x1) << 10) |
484*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_venc_emi_req_mask_b & 0x1) << 11) |
485*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_venc_infra_req_mask_b & 0x1) << 12) |
486*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_venc_pmic_req_mask_b & 0x1) << 13) |
487*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_venc_srcclkena_mask_b & 0x1) << 14) |
488*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_venc_vrf18_req_mask_b & 0x1) << 15) |
489*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ipe_apsrc_req_mask_b & 0x1) << 16) |
490*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ipe_ddren_req_mask_b & 0x1) << 17) |
491*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ipe_emi_req_mask_b & 0x1) << 18) |
492*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ipe_infra_req_mask_b & 0x1) << 19) |
493*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ipe_pmic_req_mask_b & 0x1) << 20) |
494*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ipe_srcclkena_mask_b & 0x1) << 21) |
495*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ipe_vrf18_req_mask_b & 0x1) << 22) |
496*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ufs_vcore_req_mask_b & 0x1) << 23));
497*5f748b3cSKun Lu 
498*5f748b3cSKun Lu 	/* SPM_EVENT_CON_MISC */
499*5f748b3cSKun Lu 	mmio_write_32(SPM_EVENT_CON_MISC,
500*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_srcclken_fast_resp & 0x1) << 0) |
501*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_csyspwrup_ack_mask & 0x1) << 1));
502*5f748b3cSKun Lu 
503*5f748b3cSKun Lu 	/* SPM_WAKEUP_EVENT_MASK */
504*5f748b3cSKun Lu 	mmio_write_32(SPM_WAKEUP_EVENT_MASK,
505*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_wakeup_event_mask & 0xffffffff) << 0));
506*5f748b3cSKun Lu 
507*5f748b3cSKun Lu 	/* SPM_WAKEUP_EVENT_EXT_MASK */
508*5f748b3cSKun Lu 	mmio_write_32(SPM_WAKEUP_EVENT_EXT_MASK,
509*5f748b3cSKun Lu 		(((uint32_t)pwrctrl->reg_ext_wakeup_event_mask & 0xffffffff) << 0));
510*5f748b3cSKun Lu 	/* Auto-gen End */
511*5f748b3cSKun Lu }
512*5f748b3cSKun Lu 
513*5f748b3cSKun Lu #define CHECK_ONE (0xffffffff)
514*5f748b3cSKun Lu #define CHECK_ZERO (0x0)
__spm_check_ack(uint32_t reg,uint32_t mask,uint32_t check_en)515*5f748b3cSKun Lu static int32_t __spm_check_ack(uint32_t reg, uint32_t mask, uint32_t check_en)
516*5f748b3cSKun Lu {
517*5f748b3cSKun Lu 	uint32_t val;
518*5f748b3cSKun Lu 
519*5f748b3cSKun Lu 	val = mmio_read_32(reg);
520*5f748b3cSKun Lu 	if ((val & mask) == (mask & check_en))
521*5f748b3cSKun Lu 		return 0;
522*5f748b3cSKun Lu 	return -1;
523*5f748b3cSKun Lu }
524*5f748b3cSKun Lu 
__spm_wait_spm_request_ack(uint32_t spm_resource_req,uint32_t timeout_us)525*5f748b3cSKun Lu int32_t __spm_wait_spm_request_ack(uint32_t spm_resource_req,
526*5f748b3cSKun Lu 				   uint32_t timeout_us)
527*5f748b3cSKun Lu {
528*5f748b3cSKun Lu 	uint32_t spm_ctrl0_mask, spm_ctrl1_mask;
529*5f748b3cSKun Lu 	int32_t ret, retry;
530*5f748b3cSKun Lu 
531*5f748b3cSKun Lu 	if (spm_resource_req == 0)
532*5f748b3cSKun Lu 		return 0;
533*5f748b3cSKun Lu 
534*5f748b3cSKun Lu 	spm_ctrl0_mask = 0;
535*5f748b3cSKun Lu 	spm_ctrl1_mask = 0;
536*5f748b3cSKun Lu 
537*5f748b3cSKun Lu 	if (spm_resource_req & (MT_SPM_XO_FPM | MT_SPM_26M))
538*5f748b3cSKun Lu 		spm_ctrl0_mask |= CTRL0_SC_MD26M_CK_OFF;
539*5f748b3cSKun Lu 
540*5f748b3cSKun Lu 	if (spm_resource_req & MT_SPM_VCORE)
541*5f748b3cSKun Lu 		spm_ctrl1_mask |= CTRL1_SPM_VCORE_INTERNAL_ACK;
542*5f748b3cSKun Lu 	if (spm_resource_req & MT_SPM_PMIC)
543*5f748b3cSKun Lu 		spm_ctrl1_mask |= CTRL1_SPM_PMIC_INTERNAL_ACK;
544*5f748b3cSKun Lu 	if (spm_resource_req & MT_SPM_INFRA)
545*5f748b3cSKun Lu 		spm_ctrl1_mask |= CTRL1_SPM_INFRA_INTERNAL_ACK;
546*5f748b3cSKun Lu 	if (spm_resource_req & MT_SPM_SYSPLL)
547*5f748b3cSKun Lu 		spm_ctrl1_mask |= CTRL1_SPM_VRF18_INTERNAL_ACK;
548*5f748b3cSKun Lu 	if (spm_resource_req & MT_SPM_EMI)
549*5f748b3cSKun Lu 		spm_ctrl1_mask |= CTRL1_SPM_EMI_INTERNAL_ACK;
550*5f748b3cSKun Lu 	if (spm_resource_req & MT_SPM_DRAM_S0)
551*5f748b3cSKun Lu 		spm_ctrl1_mask |= CTRL1_SPM_APSRC_INTERNAL_ACK;
552*5f748b3cSKun Lu 	if (spm_resource_req & MT_SPM_DRAM_S1)
553*5f748b3cSKun Lu 		spm_ctrl1_mask |= CTRL1_SPM_DDREN_INTERNAL_ACK;
554*5f748b3cSKun Lu 
555*5f748b3cSKun Lu 	retry = -1;
556*5f748b3cSKun Lu 	ret = 0;
557*5f748b3cSKun Lu 
558*5f748b3cSKun Lu 	while (retry++ < timeout_us) {
559*5f748b3cSKun Lu 		udelay(1);
560*5f748b3cSKun Lu 		if (spm_ctrl0_mask != 0) {
561*5f748b3cSKun Lu 			ret = __spm_check_ack(MD32PCM_SCU_CTRL0, spm_ctrl0_mask,
562*5f748b3cSKun Lu 					      CHECK_ZERO);
563*5f748b3cSKun Lu 			if (ret)
564*5f748b3cSKun Lu 				continue;
565*5f748b3cSKun Lu 		}
566*5f748b3cSKun Lu 		if (spm_ctrl1_mask != 0) {
567*5f748b3cSKun Lu 			ret = __spm_check_ack(MD32PCM_SCU_CTRL1, spm_ctrl1_mask,
568*5f748b3cSKun Lu 					      CHECK_ONE);
569*5f748b3cSKun Lu 			if (ret)
570*5f748b3cSKun Lu 				continue;
571*5f748b3cSKun Lu 		}
572*5f748b3cSKun Lu 		break;
573*5f748b3cSKun Lu 	}
574*5f748b3cSKun Lu 
575*5f748b3cSKun Lu 	return ret;
576*5f748b3cSKun Lu }
577*5f748b3cSKun Lu 
__spm_set_wakeup_event(const struct pwr_ctrl * pwrctrl)578*5f748b3cSKun Lu void __spm_set_wakeup_event(const struct pwr_ctrl *pwrctrl)
579*5f748b3cSKun Lu {
580*5f748b3cSKun Lu 	uint32_t val, mask, isr;
581*5f748b3cSKun Lu 
582*5f748b3cSKun Lu 	/* toggle event counter clear */
583*5f748b3cSKun Lu 	mmio_write_32(SPM_EVENT_COUNTER_CLEAR, REG_SPM_EVENT_COUNTER_CLR_LSB);
584*5f748b3cSKun Lu 	/* toggle for reset SYS TIMER start point */
585*5f748b3cSKun Lu 	mmio_write_32(SYS_TIMER_CON,
586*5f748b3cSKun Lu 		      mmio_read_32(SYS_TIMER_CON) | SYS_TIMER_START_EN_LSB);
587*5f748b3cSKun Lu 
588*5f748b3cSKun Lu 	if (pwrctrl->timer_val_cust == 0)
589*5f748b3cSKun Lu 		val = pwrctrl->timer_val ? pwrctrl->timer_val :
590*5f748b3cSKun Lu 					   PCM_TIMER_SUSPEND;
591*5f748b3cSKun Lu 	else
592*5f748b3cSKun Lu 		val = pwrctrl->timer_val_cust;
593*5f748b3cSKun Lu 
594*5f748b3cSKun Lu 	mmio_write_32(PCM_TIMER_VAL, val);
595*5f748b3cSKun Lu 	mmio_write_32(PCM_CON1, mmio_read_32(PCM_CON1) | SPM_REGWR_CFG_KEY |
596*5f748b3cSKun Lu 					REG_PCM_TIMER_EN_LSB);
597*5f748b3cSKun Lu 
598*5f748b3cSKun Lu 	/* unmask AP wakeup source */
599*5f748b3cSKun Lu 	if (pwrctrl->wake_src_cust == 0)
600*5f748b3cSKun Lu 		mask = pwrctrl->wake_src;
601*5f748b3cSKun Lu 	else
602*5f748b3cSKun Lu 		mask = pwrctrl->wake_src_cust;
603*5f748b3cSKun Lu 
604*5f748b3cSKun Lu 	if (pwrctrl->reg_csyspwrup_ack_mask)
605*5f748b3cSKun Lu 		mask &= ~R12_CSYSPWREQ_B;
606*5f748b3cSKun Lu 	mmio_write_32(SPM_WAKEUP_EVENT_MASK, ~mask);
607*5f748b3cSKun Lu 
608*5f748b3cSKun Lu 	/* unmask SPM ISR (keep TWAM setting) */
609*5f748b3cSKun Lu 	isr = mmio_read_32(SPM_IRQ_MASK);
610*5f748b3cSKun Lu 	mmio_write_32(SPM_IRQ_MASK, isr | ISRM_RET_IRQ_AUX);
611*5f748b3cSKun Lu 
612*5f748b3cSKun Lu 	/* toggle event counter clear */
613*5f748b3cSKun Lu 	mmio_write_32(SPM_EVENT_COUNTER_CLEAR, 0);
614*5f748b3cSKun Lu 	/* toggle for reset SYS TIMER start point */
615*5f748b3cSKun Lu 	mmio_write_32(SYS_TIMER_CON,
616*5f748b3cSKun Lu 		      mmio_read_32(SYS_TIMER_CON) & ~SYS_TIMER_START_EN_LSB);
617*5f748b3cSKun Lu }
618*5f748b3cSKun Lu 
__spm_set_fw_resume_option(struct pwr_ctrl * pwrctrl)619*5f748b3cSKun Lu void __spm_set_fw_resume_option(struct pwr_ctrl *pwrctrl)
620*5f748b3cSKun Lu {
621*5f748b3cSKun Lu #if SPM_FW_NO_RESUME
622*5f748b3cSKun Lu 	/* do Nothing */
623*5f748b3cSKun Lu #else
624*5f748b3cSKun Lu 	pwrctrl->pcm_flags1 |= SPM_FLAG1_DISABLE_NO_RESUME;
625*5f748b3cSKun Lu #endif
626*5f748b3cSKun Lu }
627*5f748b3cSKun Lu 
__spm_set_pcm_flags(struct pwr_ctrl * pwrctrl)628*5f748b3cSKun Lu void __spm_set_pcm_flags(struct pwr_ctrl *pwrctrl)
629*5f748b3cSKun Lu {
630*5f748b3cSKun Lu 	/* set PCM flags and data */
631*5f748b3cSKun Lu 	uint32_t pcm_flags =
632*5f748b3cSKun Lu 		(pwrctrl->pcm_flags & ~pwrctrl->pcm_flags_cust_clr) |
633*5f748b3cSKun Lu 		pwrctrl->pcm_flags_cust_set;
634*5f748b3cSKun Lu 	uint32_t pcm_flags1 =
635*5f748b3cSKun Lu 		(pwrctrl->pcm_flags1 & ~pwrctrl->pcm_flags1_cust_clr) |
636*5f748b3cSKun Lu 		pwrctrl->pcm_flags1_cust_set;
637*5f748b3cSKun Lu 
638*5f748b3cSKun Lu 	mmio_write_32(SPM_SW_FLAG_0, pcm_flags);
639*5f748b3cSKun Lu 
640*5f748b3cSKun Lu 	mmio_write_32(SPM_SW_FLAG_1, pcm_flags1);
641*5f748b3cSKun Lu 
642*5f748b3cSKun Lu 	mmio_write_32(PCM_WDT_LATCH_SPARE_7, pcm_flags);
643*5f748b3cSKun Lu 
644*5f748b3cSKun Lu 	mmio_write_32(PCM_WDT_LATCH_SPARE_5, pcm_flags1);
645*5f748b3cSKun Lu }
646*5f748b3cSKun Lu 
__spm_kick_pcm_to_run(struct pwr_ctrl * pwrctrl)647*5f748b3cSKun Lu void __spm_kick_pcm_to_run(struct pwr_ctrl *pwrctrl)
648*5f748b3cSKun Lu {
649*5f748b3cSKun Lu 	uint32_t con0;
650*5f748b3cSKun Lu 
651*5f748b3cSKun Lu 	/* Waiting for loading SPMFW done*/
652*5f748b3cSKun Lu 	while (mmio_read_32(MD32PCM_DMA0_RLCT) != 0x0)
653*5f748b3cSKun Lu 		;
654*5f748b3cSKun Lu 
655*5f748b3cSKun Lu 	__spm_set_pcm_flags(pwrctrl);
656*5f748b3cSKun Lu 
657*5f748b3cSKun Lu 	/* kick PCM to run (only toggle PCM_KICK) */
658*5f748b3cSKun Lu 	con0 = mmio_read_32(PCM_CON0);
659*5f748b3cSKun Lu 	mmio_write_32(PCM_CON0, con0 | SPM_REGWR_CFG_KEY | PCM_CK_EN_LSB);
660*5f748b3cSKun Lu 	/* reset md32pcm */
661*5f748b3cSKun Lu 	con0 = mmio_read_32(MD32PCM_CFGREG_SW_RSTN);
662*5f748b3cSKun Lu 	mmio_write_32(MD32PCM_CFGREG_SW_RSTN, con0 | 0x1);
663*5f748b3cSKun Lu 
664*5f748b3cSKun Lu 	/* Waiting for SPM init done and entering WFI*/
665*5f748b3cSKun Lu 	udelay(SPM_INIT_DONE_US);
666*5f748b3cSKun Lu }
667*5f748b3cSKun Lu 
__spm_get_wakeup_status(struct wake_status * wakesta,unsigned int ext_status)668*5f748b3cSKun Lu void __spm_get_wakeup_status(struct wake_status *wakesta,
669*5f748b3cSKun Lu 			     unsigned int ext_status)
670*5f748b3cSKun Lu {
671*5f748b3cSKun Lu 	/* get wakeup event */
672*5f748b3cSKun Lu 	wakesta->tr.comm.r12 = mmio_read_32(SPM_BK_WAKE_EVENT); /* backup of PCM_REG12_DATA */
673*5f748b3cSKun Lu 	wakesta->r12_ext = mmio_read_32(SPM_WAKEUP_EXT_STA);
674*5f748b3cSKun Lu 	wakesta->tr.comm.raw_sta = mmio_read_32(SPM_WAKEUP_STA);
675*5f748b3cSKun Lu 	wakesta->raw_ext_sta = mmio_read_32(SPM_WAKEUP_EXT_STA);
676*5f748b3cSKun Lu 	wakesta->md32pcm_wakeup_sta = mmio_read_32(MD32PCM_WAKEUP_STA);
677*5f748b3cSKun Lu 	wakesta->md32pcm_event_sta = mmio_read_32(MD32PCM_EVENT_STA);
678*5f748b3cSKun Lu 	wakesta->wake_misc = mmio_read_32(SPM_BK_WAKE_MISC);   /* backup of SPM_WAKEUP_MISC */
679*5f748b3cSKun Lu 
680*5f748b3cSKun Lu 	/* get sleep time */
681*5f748b3cSKun Lu 	wakesta->tr.comm.timer_out = mmio_read_32(SPM_BK_PCM_TIMER);   /* backup of PCM_TIMER_OUT */
682*5f748b3cSKun Lu 
683*5f748b3cSKun Lu 	/* get other SYS and co-clock status */
684*5f748b3cSKun Lu 	wakesta->tr.comm.r13 = mmio_read_32(MD32PCM_SCU_STA0);
685*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta0 = mmio_read_32(SPM_REQ_STA_0);
686*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta1 = mmio_read_32(SPM_REQ_STA_1);
687*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta2 = mmio_read_32(SPM_REQ_STA_2);
688*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta3 = mmio_read_32(SPM_REQ_STA_3);
689*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta4 = mmio_read_32(SPM_REQ_STA_4);
690*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta5 = mmio_read_32(SPM_REQ_STA_5);
691*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta6 = mmio_read_32(SPM_REQ_STA_6);
692*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta7 = mmio_read_32(SPM_REQ_STA_7);
693*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta8 = mmio_read_32(SPM_REQ_STA_8);
694*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta9 = mmio_read_32(SPM_REQ_STA_9);
695*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta10 = mmio_read_32(SPM_REQ_STA_10);
696*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta11 = mmio_read_32(SPM_REQ_STA_11);
697*5f748b3cSKun Lu 	wakesta->tr.comm.req_sta12 = mmio_read_32(SPM_REQ_STA_12);
698*5f748b3cSKun Lu 
699*5f748b3cSKun Lu 	/* get debug flag for PCM execution check */
700*5f748b3cSKun Lu 	wakesta->tr.comm.debug_flag = mmio_read_32(PCM_WDT_LATCH_SPARE_0);
701*5f748b3cSKun Lu 	wakesta->tr.comm.debug_flag1 = mmio_read_32(PCM_WDT_LATCH_SPARE_1);
702*5f748b3cSKun Lu 
703*5f748b3cSKun Lu 	/* get backup SW flag status */
704*5f748b3cSKun Lu 	wakesta->tr.comm.b_sw_flag0 = mmio_read_32(PCM_WDT_LATCH_SPARE_7);
705*5f748b3cSKun Lu 	wakesta->tr.comm.b_sw_flag1 = mmio_read_32(PCM_WDT_LATCH_SPARE_5);
706*5f748b3cSKun Lu 
707*5f748b3cSKun Lu 	/* get ISR status */
708*5f748b3cSKun Lu 	wakesta->isr = mmio_read_32(SPM_IRQ_STA);
709*5f748b3cSKun Lu 
710*5f748b3cSKun Lu 	/* get SW flag status */
711*5f748b3cSKun Lu 	wakesta->sw_flag0 = mmio_read_32(SPM_SW_FLAG_0);
712*5f748b3cSKun Lu 	wakesta->sw_flag1 = mmio_read_32(SPM_SW_FLAG_1);
713*5f748b3cSKun Lu 
714*5f748b3cSKun Lu 	/* check abort */
715*5f748b3cSKun Lu 	wakesta->is_abort = wakesta->tr.comm.debug_flag1 & DEBUG_ABORT_MASK_1;
716*5f748b3cSKun Lu }
717*5f748b3cSKun Lu 
__spm_clean_after_wakeup(void)718*5f748b3cSKun Lu void __spm_clean_after_wakeup(void)
719*5f748b3cSKun Lu {
720*5f748b3cSKun Lu 	/*
721*5f748b3cSKun Lu 	 * Copy SPM_WAKEUP_STA to SPM_BK_WAKE_EVENT
722*5f748b3cSKun Lu 	 * before clear SPM_WAKEUP_STA
723*5f748b3cSKun Lu 	 *
724*5f748b3cSKun Lu 	 * CPU dormant driver @kernel will copy  edge-trig IRQ pending
725*5f748b3cSKun Lu 	 * (recorded @SPM_BK_WAKE_EVENT) to GIC
726*5f748b3cSKun Lu 	 */
727*5f748b3cSKun Lu 	mmio_write_32(SPM_BK_WAKE_EVENT, mmio_read_32(SPM_WAKEUP_STA) |
728*5f748b3cSKun Lu 			      mmio_read_32(SPM_BK_WAKE_EVENT));
729*5f748b3cSKun Lu 
730*5f748b3cSKun Lu 	/*
731*5f748b3cSKun Lu 	 * [Vcorefs] can not switch back to POWER_ON_VAL0 here,
732*5f748b3cSKun Lu 	 * the FW stays in VCORE DVFS which use r0 to Ctrl MEM
733*5f748b3cSKun Lu 	 */
734*5f748b3cSKun Lu 	/* disable r0 and r7 to control power */
735*5f748b3cSKun Lu 	/* mmio_write_32(PCM_PWR_IO_EN, 0); */
736*5f748b3cSKun Lu 
737*5f748b3cSKun Lu 	/* clean CPU wakeup event */
738*5f748b3cSKun Lu 	mmio_write_32(SPM_CPU_WAKEUP_EVENT, 0);
739*5f748b3cSKun Lu 
740*5f748b3cSKun Lu 	/*
741*5f748b3cSKun Lu 	 * [Vcorefs] not disable pcm timer here, due to the
742*5f748b3cSKun Lu 	 * following vcore dvfs will use it for latency check
743*5f748b3cSKun Lu 	 */
744*5f748b3cSKun Lu 	/* clean PCM timer event */
745*5f748b3cSKun Lu 	/*
746*5f748b3cSKun Lu 	 * mmio_write_32(PCM_CON1, SPM_REGWR_CFG_KEY |
747*5f748b3cSKun Lu 	 *			(mmio_read_32(PCM_CON1) & ~PCM_TIMER_EN_LSB));
748*5f748b3cSKun Lu 	 */
749*5f748b3cSKun Lu 
750*5f748b3cSKun Lu 	/* clean wakeup event raw status (for edge trigger event) */
751*5f748b3cSKun Lu 	mmio_write_32(SPM_WAKEUP_EVENT_MASK,
752*5f748b3cSKun Lu 		      0xefffffff); /* bit[28] for cpu wake up event */
753*5f748b3cSKun Lu 
754*5f748b3cSKun Lu 	/* clean ISR status (except TWAM) */
755*5f748b3cSKun Lu 	mmio_write_32(SPM_IRQ_MASK,
756*5f748b3cSKun Lu 		      mmio_read_32(SPM_IRQ_MASK) | ISRM_ALL_EXC_TWAM);
757*5f748b3cSKun Lu 	mmio_write_32(SPM_IRQ_STA, ISRC_ALL_EXC_TWAM);
758*5f748b3cSKun Lu 	mmio_write_32(SPM_SWINT_CLR, PCM_SW_INT_ALL);
759*5f748b3cSKun Lu }
760*5f748b3cSKun Lu 
__spm_set_pcm_wdt(int en)761*5f748b3cSKun Lu void __spm_set_pcm_wdt(int en)
762*5f748b3cSKun Lu {
763*5f748b3cSKun Lu 	/* enable PCM WDT (normal mode) to start count if needed */
764*5f748b3cSKun Lu 	if (en) {
765*5f748b3cSKun Lu 		uint32_t con1;
766*5f748b3cSKun Lu 
767*5f748b3cSKun Lu 		con1 = mmio_read_32(PCM_CON1) & ~(REG_PCM_WDT_WAKE_LSB);
768*5f748b3cSKun Lu 		mmio_write_32(PCM_CON1, SPM_REGWR_CFG_KEY | con1);
769*5f748b3cSKun Lu 
770*5f748b3cSKun Lu 		if (mmio_read_32(PCM_TIMER_VAL) > PCM_TIMER_MAX)
771*5f748b3cSKun Lu 			mmio_write_32(PCM_TIMER_VAL, PCM_TIMER_MAX);
772*5f748b3cSKun Lu 		mmio_write_32(PCM_WDT_VAL,
773*5f748b3cSKun Lu 			      mmio_read_32(PCM_TIMER_VAL) + PCM_WDT_TIMEOUT);
774*5f748b3cSKun Lu 		mmio_write_32(PCM_CON1,
775*5f748b3cSKun Lu 			      con1 | SPM_REGWR_CFG_KEY | REG_PCM_WDT_EN_LSB);
776*5f748b3cSKun Lu 	} else {
777*5f748b3cSKun Lu 		mmio_write_32(PCM_CON1,
778*5f748b3cSKun Lu 			      SPM_REGWR_CFG_KEY | (mmio_read_32(PCM_CON1) &
779*5f748b3cSKun Lu 						   ~REG_PCM_WDT_EN_LSB));
780*5f748b3cSKun Lu 	}
781*5f748b3cSKun Lu }
782*5f748b3cSKun Lu 
__spm_get_pcm_timer_val(void)783*5f748b3cSKun Lu uint32_t __spm_get_pcm_timer_val(void)
784*5f748b3cSKun Lu {
785*5f748b3cSKun Lu 	/* PCM_TIMER_VAL / 32768 = PCM_TIMER_VAL >> 15 (unit : sec) */
786*5f748b3cSKun Lu 	return mmio_read_32(PCM_TIMER_VAL) >> 15;
787*5f748b3cSKun Lu }
788*5f748b3cSKun Lu 
__spm_send_cpu_wakeup_event(void)789*5f748b3cSKun Lu void __spm_send_cpu_wakeup_event(void)
790*5f748b3cSKun Lu {
791*5f748b3cSKun Lu 	mmio_write_32(SPM_CPU_WAKEUP_EVENT, 1);
792*5f748b3cSKun Lu 	/* SPM will clear SPM_CPU_WAKEUP_EVENT */
793*5f748b3cSKun Lu }
794*5f748b3cSKun Lu 
__spm_ext_int_wakeup_req_clr(void)795*5f748b3cSKun Lu void __spm_ext_int_wakeup_req_clr(void)
796*5f748b3cSKun Lu {
797*5f748b3cSKun Lu 	uint32_t cpu = plat_my_core_pos();
798*5f748b3cSKun Lu 	unsigned int reg;
799*5f748b3cSKun Lu 
800*5f748b3cSKun Lu 	mmio_write_32(EXT_INT_WAKEUP_REQ_CLR, (1U << cpu));
801*5f748b3cSKun Lu 
802*5f748b3cSKun Lu 	/* Clear spm2mcupm wakeup interrupt status */
803*5f748b3cSKun Lu 	reg = mmio_read_32(SPM2MCUPM_CON);
804*5f748b3cSKun Lu 	reg &= ~SPM2MCUPM_SW_INT_LSB;
805*5f748b3cSKun Lu 	mmio_write_32(SPM2MCUPM_CON, reg);
806*5f748b3cSKun Lu }
807*5f748b3cSKun Lu 
__spm_clean_before_wfi(void)808*5f748b3cSKun Lu void __spm_clean_before_wfi(void)
809*5f748b3cSKun Lu {
810*5f748b3cSKun Lu }
811*5f748b3cSKun Lu 
__spm_hw_s1_state_monitor(int en,unsigned int * status)812*5f748b3cSKun Lu void __spm_hw_s1_state_monitor(int en, unsigned int *status)
813*5f748b3cSKun Lu {
814*5f748b3cSKun Lu 	unsigned int reg;
815*5f748b3cSKun Lu 
816*5f748b3cSKun Lu 	if (en) {
817*5f748b3cSKun Lu 		reg = mmio_read_32(SPM_ACK_CHK_CON_3);
818*5f748b3cSKun Lu 		reg &= ~SPM_ACK_CHK_3_CON_CLR_ALL;
819*5f748b3cSKun Lu 		mmio_write_32(SPM_ACK_CHK_CON_3, reg);
820*5f748b3cSKun Lu 		reg |= SPM_ACK_CHK_3_CON_EN;
821*5f748b3cSKun Lu 		mmio_write_32(SPM_ACK_CHK_CON_3, reg);
822*5f748b3cSKun Lu 	} else {
823*5f748b3cSKun Lu 		reg = mmio_read_32(SPM_ACK_CHK_CON_3);
824*5f748b3cSKun Lu 
825*5f748b3cSKun Lu 		if (reg & SPM_ACK_CHK_3_CON_RESULT) {
826*5f748b3cSKun Lu 			if (status)
827*5f748b3cSKun Lu 				*status |= SPM_INTERNAL_STATUS_HW_S1;
828*5f748b3cSKun Lu 		}
829*5f748b3cSKun Lu 
830*5f748b3cSKun Lu 		reg |= (SPM_ACK_CHK_3_CON_HW_MODE_TRIG |
831*5f748b3cSKun Lu 			SPM_ACK_CHK_3_CON_CLR_ALL);
832*5f748b3cSKun Lu 		reg &= ~(SPM_ACK_CHK_3_CON_EN);
833*5f748b3cSKun Lu 		mmio_write_32(SPM_ACK_CHK_CON_3, reg);
834*5f748b3cSKun Lu 	}
835*5f748b3cSKun Lu }
836