xref: /rk3399_ARM-atf/plat/mediatek/mt8173/drivers/spm/spm.h (revision 7d116dccab2249a692181ba9521a52277e86591c)
1*7d116dccSCC Ma /*
2*7d116dccSCC Ma  * Copyright (c) 2015, ARM Limited and Contributors. All rights reserved.
3*7d116dccSCC Ma  *
4*7d116dccSCC Ma  * Redistribution and use in source and binary forms, with or without
5*7d116dccSCC Ma  * modification, are permitted provided that the following conditions are met:
6*7d116dccSCC Ma  *
7*7d116dccSCC Ma  * Redistributions of source code must retain the above copyright notice, this
8*7d116dccSCC Ma  * list of conditions and the following disclaimer.
9*7d116dccSCC Ma  *
10*7d116dccSCC Ma  * Redistributions in binary form must reproduce the above copyright notice,
11*7d116dccSCC Ma  * this list of conditions and the following disclaimer in the documentation
12*7d116dccSCC Ma  * and/or other materials provided with the distribution.
13*7d116dccSCC Ma  *
14*7d116dccSCC Ma  * Neither the name of ARM nor the names of its contributors may be used
15*7d116dccSCC Ma  * to endorse or promote products derived from this software without specific
16*7d116dccSCC Ma  * prior written permission.
17*7d116dccSCC Ma  *
18*7d116dccSCC Ma  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19*7d116dccSCC Ma  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20*7d116dccSCC Ma  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21*7d116dccSCC Ma  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
22*7d116dccSCC Ma  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23*7d116dccSCC Ma  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24*7d116dccSCC Ma  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25*7d116dccSCC Ma  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26*7d116dccSCC Ma  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27*7d116dccSCC Ma  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28*7d116dccSCC Ma  * POSSIBILITY OF SUCH DAMAGE.
29*7d116dccSCC Ma  */
30*7d116dccSCC Ma #ifndef __SPM_H__
31*7d116dccSCC Ma #define __SPM_H__
32*7d116dccSCC Ma 
33*7d116dccSCC Ma #define SPM_POWERON_CONFIG_SET			(SPM_BASE + 0x000)
34*7d116dccSCC Ma #define SPM_POWER_ON_VAL0			(SPM_BASE + 0x010)
35*7d116dccSCC Ma #define SPM_POWER_ON_VAL1			(SPM_BASE + 0x014)
36*7d116dccSCC Ma #define SPM_CLK_SETTLE				(SPM_BASE + 0x100)
37*7d116dccSCC Ma #define SPM_CA7_CPU1_PWR_CON			(SPM_BASE + 0x218)
38*7d116dccSCC Ma #define SPM_CA7_CPU2_PWR_CON			(SPM_BASE + 0x21c)
39*7d116dccSCC Ma #define SPM_CA7_CPU3_PWR_CON			(SPM_BASE + 0x220)
40*7d116dccSCC Ma #define SPM_CA7_CPU1_L1_PDN			(SPM_BASE + 0x264)
41*7d116dccSCC Ma #define SPM_CA7_CPU2_L1_PDN			(SPM_BASE + 0x26c)
42*7d116dccSCC Ma #define SPM_CA7_CPU3_L1_PDN			(SPM_BASE + 0x274)
43*7d116dccSCC Ma #define SPM_MD32_SRAM_CON			(SPM_BASE + 0x2c8)
44*7d116dccSCC Ma #define SPM_PCM_CON0				(SPM_BASE + 0x310)
45*7d116dccSCC Ma #define SPM_PCM_CON1				(SPM_BASE + 0x314)
46*7d116dccSCC Ma #define SPM_PCM_IM_PTR				(SPM_BASE + 0x318)
47*7d116dccSCC Ma #define SPM_PCM_IM_LEN				(SPM_BASE + 0x31c)
48*7d116dccSCC Ma #define SPM_PCM_REG_DATA_INI			(SPM_BASE + 0x320)
49*7d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR0			(SPM_BASE + 0x340)
50*7d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR1			(SPM_BASE + 0x344)
51*7d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR2			(SPM_BASE + 0x348)
52*7d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR3			(SPM_BASE + 0x34c)
53*7d116dccSCC Ma #define SPM_PCM_MAS_PAUSE_MASK			(SPM_BASE + 0x354)
54*7d116dccSCC Ma #define SPM_PCM_PWR_IO_EN			(SPM_BASE + 0x358)
55*7d116dccSCC Ma #define SPM_PCM_TIMER_VAL			(SPM_BASE + 0x35c)
56*7d116dccSCC Ma #define SPM_PCM_TIMER_OUT			(SPM_BASE + 0x360)
57*7d116dccSCC Ma #define SPM_PCM_REG0_DATA			(SPM_BASE + 0x380)
58*7d116dccSCC Ma #define SPM_PCM_REG1_DATA			(SPM_BASE + 0x384)
59*7d116dccSCC Ma #define SPM_PCM_REG2_DATA			(SPM_BASE + 0x388)
60*7d116dccSCC Ma #define SPM_PCM_REG3_DATA			(SPM_BASE + 0x38c)
61*7d116dccSCC Ma #define SPM_PCM_REG4_DATA			(SPM_BASE + 0x390)
62*7d116dccSCC Ma #define SPM_PCM_REG5_DATA			(SPM_BASE + 0x394)
63*7d116dccSCC Ma #define SPM_PCM_REG6_DATA			(SPM_BASE + 0x398)
64*7d116dccSCC Ma #define SPM_PCM_REG7_DATA			(SPM_BASE + 0x39c)
65*7d116dccSCC Ma #define SPM_PCM_REG8_DATA			(SPM_BASE + 0x3a0)
66*7d116dccSCC Ma #define SPM_PCM_REG9_DATA			(SPM_BASE + 0x3a4)
67*7d116dccSCC Ma #define SPM_PCM_REG10_DATA			(SPM_BASE + 0x3a8)
68*7d116dccSCC Ma #define SPM_PCM_REG11_DATA			(SPM_BASE + 0x3ac)
69*7d116dccSCC Ma #define SPM_PCM_REG12_DATA			(SPM_BASE + 0x3b0)
70*7d116dccSCC Ma #define SPM_PCM_REG13_DATA			(SPM_BASE + 0x3b4)
71*7d116dccSCC Ma #define SPM_PCM_REG14_DATA			(SPM_BASE + 0x3b8)
72*7d116dccSCC Ma #define SPM_PCM_REG15_DATA			(SPM_BASE + 0x3bc)
73*7d116dccSCC Ma #define SPM_PCM_EVENT_REG_STA			(SPM_BASE + 0x3c0)
74*7d116dccSCC Ma #define SPM_PCM_FSM_STA				(SPM_BASE + 0x3c4)
75*7d116dccSCC Ma #define SPM_PCM_IM_HOST_RW_PTR			(SPM_BASE + 0x3c8)
76*7d116dccSCC Ma #define SPM_PCM_IM_HOST_RW_DAT			(SPM_BASE + 0x3cc)
77*7d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR4			(SPM_BASE + 0x3d0)
78*7d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR5			(SPM_BASE + 0x3d4)
79*7d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR6			(SPM_BASE + 0x3d8)
80*7d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR7			(SPM_BASE + 0x3dc)
81*7d116dccSCC Ma #define SPM_PCM_SW_INT_SET			(SPM_BASE + 0x3e0)
82*7d116dccSCC Ma #define SPM_PCM_SW_INT_CLEAR			(SPM_BASE + 0x3e4)
83*7d116dccSCC Ma #define SPM_CLK_CON				(SPM_BASE + 0x400)
84*7d116dccSCC Ma #define SPM_SLEEP_PTPOD2_CON			(SPM_BASE + 0x408)
85*7d116dccSCC Ma #define SPM_APMCU_PWRCTL			(SPM_BASE + 0x600)
86*7d116dccSCC Ma #define SPM_AP_DVFS_CON_SET			(SPM_BASE + 0x604)
87*7d116dccSCC Ma #define SPM_AP_STANBY_CON			(SPM_BASE + 0x608)
88*7d116dccSCC Ma #define SPM_PWR_STATUS				(SPM_BASE + 0x60c)
89*7d116dccSCC Ma #define SPM_PWR_STATUS_2ND			(SPM_BASE + 0x610)
90*7d116dccSCC Ma #define SPM_AP_BSI_REQ				(SPM_BASE + 0x614)
91*7d116dccSCC Ma #define SPM_SLEEP_TIMER_STA			(SPM_BASE + 0x720)
92*7d116dccSCC Ma #define SPM_SLEEP_WAKEUP_EVENT_MASK		(SPM_BASE + 0x810)
93*7d116dccSCC Ma #define SPM_SLEEP_CPU_WAKEUP_EVENT		(SPM_BASE + 0x814)
94*7d116dccSCC Ma #define SPM_SLEEP_MD32_WAKEUP_EVENT_MASK	(SPM_BASE + 0x818)
95*7d116dccSCC Ma #define SPM_PCM_WDT_TIMER_VAL			(SPM_BASE + 0x824)
96*7d116dccSCC Ma #define SPM_PCM_WDT_TIMER_OUT			(SPM_BASE + 0x828)
97*7d116dccSCC Ma #define SPM_PCM_MD32_MAILBOX			(SPM_BASE + 0x830)
98*7d116dccSCC Ma #define SPM_PCM_MD32_IRQ			(SPM_BASE + 0x834)
99*7d116dccSCC Ma #define SPM_SLEEP_ISR_MASK			(SPM_BASE + 0x900)
100*7d116dccSCC Ma #define SPM_SLEEP_ISR_STATUS			(SPM_BASE + 0x904)
101*7d116dccSCC Ma #define SPM_SLEEP_ISR_RAW_STA			(SPM_BASE + 0x910)
102*7d116dccSCC Ma #define SPM_SLEEP_MD32_ISR_RAW_STA		(SPM_BASE + 0x914)
103*7d116dccSCC Ma #define SPM_SLEEP_WAKEUP_MISC			(SPM_BASE + 0x918)
104*7d116dccSCC Ma #define SPM_SLEEP_BUS_PROTECT_RDY		(SPM_BASE + 0x91c)
105*7d116dccSCC Ma #define SPM_SLEEP_SUBSYS_IDLE_STA		(SPM_BASE + 0x920)
106*7d116dccSCC Ma #define SPM_PCM_RESERVE				(SPM_BASE + 0xb00)
107*7d116dccSCC Ma #define SPM_PCM_RESERVE2			(SPM_BASE + 0xb04)
108*7d116dccSCC Ma #define SPM_PCM_FLAGS				(SPM_BASE + 0xb08)
109*7d116dccSCC Ma #define SPM_PCM_SRC_REQ				(SPM_BASE + 0xb0c)
110*7d116dccSCC Ma #define SPM_PCM_DEBUG_CON			(SPM_BASE + 0xb20)
111*7d116dccSCC Ma #define SPM_CA7_CPU0_IRQ_MASK			(SPM_BASE + 0xb30)
112*7d116dccSCC Ma #define SPM_CA7_CPU1_IRQ_MASK			(SPM_BASE + 0xb34)
113*7d116dccSCC Ma #define SPM_CA7_CPU2_IRQ_MASK			(SPM_BASE + 0xb38)
114*7d116dccSCC Ma #define SPM_CA7_CPU3_IRQ_MASK			(SPM_BASE + 0xb3c)
115*7d116dccSCC Ma #define SPM_CA15_CPU0_IRQ_MASK			(SPM_BASE + 0xb40)
116*7d116dccSCC Ma #define SPM_CA15_CPU1_IRQ_MASK			(SPM_BASE + 0xb44)
117*7d116dccSCC Ma #define SPM_CA15_CPU2_IRQ_MASK			(SPM_BASE + 0xb48)
118*7d116dccSCC Ma #define SPM_CA15_CPU3_IRQ_MASK			(SPM_BASE + 0xb4c)
119*7d116dccSCC Ma #define SPM_PCM_PASR_DPD_0			(SPM_BASE + 0xb60)
120*7d116dccSCC Ma #define SPM_PCM_PASR_DPD_1			(SPM_BASE + 0xb64)
121*7d116dccSCC Ma #define SPM_PCM_PASR_DPD_2			(SPM_BASE + 0xb68)
122*7d116dccSCC Ma #define SPM_PCM_PASR_DPD_3			(SPM_BASE + 0xb6c)
123*7d116dccSCC Ma #define SPM_SLEEP_CA7_WFI0_EN			(SPM_BASE + 0xf00)
124*7d116dccSCC Ma #define SPM_SLEEP_CA7_WFI1_EN			(SPM_BASE + 0xf04)
125*7d116dccSCC Ma #define SPM_SLEEP_CA7_WFI2_EN			(SPM_BASE + 0xf08)
126*7d116dccSCC Ma #define SPM_SLEEP_CA7_WFI3_EN			(SPM_BASE + 0xf0c)
127*7d116dccSCC Ma #define SPM_SLEEP_CA15_WFI0_EN			(SPM_BASE + 0xf10)
128*7d116dccSCC Ma #define SPM_SLEEP_CA15_WFI1_EN			(SPM_BASE + 0xf14)
129*7d116dccSCC Ma #define SPM_SLEEP_CA15_WFI2_EN			(SPM_BASE + 0xf18)
130*7d116dccSCC Ma #define SPM_SLEEP_CA15_WFI3_EN			(SPM_BASE + 0xf1c)
131*7d116dccSCC Ma 
132*7d116dccSCC Ma #define SPM_PROJECT_CODE	0xb16
133*7d116dccSCC Ma 
134*7d116dccSCC Ma #define SPM_REGWR_EN		(1U << 0)
135*7d116dccSCC Ma #define SPM_REGWR_CFG_KEY	(SPM_PROJECT_CODE << 16)
136*7d116dccSCC Ma 
137*7d116dccSCC Ma #define SPM_CPU_PDN_DIS		(1U << 0)
138*7d116dccSCC Ma #define SPM_INFRA_PDN_DIS	(1U << 1)
139*7d116dccSCC Ma #define SPM_DDRPHY_PDN_DIS	(1U << 2)
140*7d116dccSCC Ma #define SPM_DUALVCORE_PDN_DIS	(1U << 3)
141*7d116dccSCC Ma #define SPM_PASR_DIS		(1U << 4)
142*7d116dccSCC Ma #define SPM_DPD_DIS		(1U << 5)
143*7d116dccSCC Ma #define SPM_SODI_DIS		(1U << 6)
144*7d116dccSCC Ma #define SPM_MEMPLL_RESET	(1U << 7)
145*7d116dccSCC Ma #define SPM_MAINPLL_PDN_DIS	(1U << 8)
146*7d116dccSCC Ma #define SPM_CPU_DVS_DIS		(1U << 9)
147*7d116dccSCC Ma #define SPM_CPU_DORMANT		(1U << 10)
148*7d116dccSCC Ma #define SPM_EXT_VSEL_GPIO103	(1U << 11)
149*7d116dccSCC Ma #define SPM_DDR_HIGH_SPEED	(1U << 12)
150*7d116dccSCC Ma #define SPM_OPT			(1U << 13)
151*7d116dccSCC Ma 
152*7d116dccSCC Ma #define POWER_ON_VAL1_DEF	0x01011820
153*7d116dccSCC Ma #define PCM_FSM_STA_DEF		0x48490
154*7d116dccSCC Ma #define PCM_END_FSM_STA_DEF	0x08490
155*7d116dccSCC Ma #define PCM_END_FSM_STA_MASK	0x3fff0
156*7d116dccSCC Ma #define PCM_HANDSHAKE_SEND1	0xbeefbeef
157*7d116dccSCC Ma 
158*7d116dccSCC Ma #define PCM_WDT_TIMEOUT		(30 * 32768)
159*7d116dccSCC Ma #define PCM_TIMER_MAX		(0xffffffff - PCM_WDT_TIMEOUT)
160*7d116dccSCC Ma 
161*7d116dccSCC Ma #define CON0_PCM_KICK		(1U << 0)
162*7d116dccSCC Ma #define CON0_IM_KICK		(1U << 1)
163*7d116dccSCC Ma #define CON0_IM_SLEEP_DVS	(1U << 3)
164*7d116dccSCC Ma #define CON0_PCM_SW_RESET	(1U << 15)
165*7d116dccSCC Ma #define CON0_CFG_KEY		(SPM_PROJECT_CODE << 16)
166*7d116dccSCC Ma 
167*7d116dccSCC Ma #define CON1_IM_SLAVE		(1U << 0)
168*7d116dccSCC Ma #define CON1_MIF_APBEN		(1U << 3)
169*7d116dccSCC Ma #define CON1_PCM_TIMER_EN	(1U << 5)
170*7d116dccSCC Ma #define CON1_IM_NONRP_EN	(1U << 6)
171*7d116dccSCC Ma #define CON1_PCM_WDT_EN		(1U << 8)
172*7d116dccSCC Ma #define CON1_PCM_WDT_WAKE_MODE	(1U << 9)
173*7d116dccSCC Ma #define CON1_SPM_SRAM_SLP_B	(1U << 10)
174*7d116dccSCC Ma #define CON1_SPM_SRAM_ISO_B	(1U << 11)
175*7d116dccSCC Ma #define CON1_EVENT_LOCK_EN	(1U << 12)
176*7d116dccSCC Ma #define CON1_CFG_KEY		(SPM_PROJECT_CODE << 16)
177*7d116dccSCC Ma 
178*7d116dccSCC Ma #define PCM_PWRIO_EN_R0		(1U << 0)
179*7d116dccSCC Ma #define PCM_PWRIO_EN_R7		(1U << 7)
180*7d116dccSCC Ma #define PCM_RF_SYNC_R0		(1U << 16)
181*7d116dccSCC Ma #define PCM_RF_SYNC_R2		(1U << 18)
182*7d116dccSCC Ma #define PCM_RF_SYNC_R6		(1U << 22)
183*7d116dccSCC Ma #define PCM_RF_SYNC_R7		(1U << 23)
184*7d116dccSCC Ma 
185*7d116dccSCC Ma #define CC_SYSCLK0_EN_0		(1U << 0)
186*7d116dccSCC Ma #define CC_SYSCLK0_EN_1		(1U << 1)
187*7d116dccSCC Ma #define CC_SYSCLK1_EN_0		(1U << 2)
188*7d116dccSCC Ma #define CC_SYSCLK1_EN_1		(1U << 3)
189*7d116dccSCC Ma #define CC_SYSSETTLE_SEL	(1U << 4)
190*7d116dccSCC Ma #define CC_LOCK_INFRA_DCM	(1U << 5)
191*7d116dccSCC Ma #define CC_SRCLKENA_MASK_0	(1U << 6)
192*7d116dccSCC Ma #define CC_CXO32K_RM_EN_MD1	(1U << 9)
193*7d116dccSCC Ma #define CC_CXO32K_RM_EN_MD2	(1U << 10)
194*7d116dccSCC Ma #define CC_CLKSQ1_SEL		(1U << 12)
195*7d116dccSCC Ma #define CC_DISABLE_DORM_PWR	(1U << 14)
196*7d116dccSCC Ma #define CC_MD32_DCM_EN		(1U << 18)
197*7d116dccSCC Ma 
198*7d116dccSCC Ma #define WFI_OP_AND		1
199*7d116dccSCC Ma #define WFI_OP_OR		0
200*7d116dccSCC Ma 
201*7d116dccSCC Ma #define WAKE_MISC_PCM_TIMER	(1U << 19)
202*7d116dccSCC Ma #define WAKE_MISC_CPU_WAKE	(1U << 20)
203*7d116dccSCC Ma 
204*7d116dccSCC Ma /* define WAKE_SRC_XXX */
205*7d116dccSCC Ma #define WAKE_SRC_SPM_MERGE	(1 << 0)
206*7d116dccSCC Ma #define WAKE_SRC_KP		(1 << 2)
207*7d116dccSCC Ma #define WAKE_SRC_WDT		(1 << 3)
208*7d116dccSCC Ma #define WAKE_SRC_GPT		(1 << 4)
209*7d116dccSCC Ma #define WAKE_SRC_EINT		(1 << 6)
210*7d116dccSCC Ma #define WAKE_SRC_LOW_BAT	(1 << 9)
211*7d116dccSCC Ma #define WAKE_SRC_MD32		(1 << 10)
212*7d116dccSCC Ma #define WAKE_SRC_USB_CD		(1 << 14)
213*7d116dccSCC Ma #define WAKE_SRC_USB_PDN	(1 << 15)
214*7d116dccSCC Ma #define WAKE_SRC_AFE		(1 << 20)
215*7d116dccSCC Ma #define WAKE_SRC_THERM		(1 << 21)
216*7d116dccSCC Ma #define WAKE_SRC_SYSPWREQ	(1 << 24)
217*7d116dccSCC Ma #define WAKE_SRC_SEJ		(1 << 27)
218*7d116dccSCC Ma #define WAKE_SRC_ALL_MD32	(1 << 28)
219*7d116dccSCC Ma #define WAKE_SRC_CPU_IRQ	(1 << 29)
220*7d116dccSCC Ma 
221*7d116dccSCC Ma enum wake_reason_t {
222*7d116dccSCC Ma 	WR_NONE = 0,
223*7d116dccSCC Ma 	WR_UART_BUSY = 1,
224*7d116dccSCC Ma 	WR_PCM_ASSERT = 2,
225*7d116dccSCC Ma 	WR_PCM_TIMER = 3,
226*7d116dccSCC Ma 	WR_PCM_ABORT = 4,
227*7d116dccSCC Ma 	WR_WAKE_SRC = 5,
228*7d116dccSCC Ma 	WR_UNKNOWN = 6,
229*7d116dccSCC Ma };
230*7d116dccSCC Ma 
231*7d116dccSCC Ma struct pwr_ctrl {
232*7d116dccSCC Ma 	unsigned int pcm_flags;
233*7d116dccSCC Ma 	unsigned int pcm_flags_cust;
234*7d116dccSCC Ma 	unsigned int pcm_reserve;
235*7d116dccSCC Ma 	unsigned int timer_val;
236*7d116dccSCC Ma 	unsigned int timer_val_cust;
237*7d116dccSCC Ma 	unsigned int wake_src;
238*7d116dccSCC Ma 	unsigned int wake_src_cust;
239*7d116dccSCC Ma 	unsigned int wake_src_md32;
240*7d116dccSCC Ma 	unsigned short r0_ctrl_en;
241*7d116dccSCC Ma 	unsigned short r7_ctrl_en;
242*7d116dccSCC Ma 	unsigned short infra_dcm_lock;
243*7d116dccSCC Ma 	unsigned short pcm_apsrc_req;
244*7d116dccSCC Ma 	unsigned short mcusys_idle_mask;
245*7d116dccSCC Ma 	unsigned short ca15top_idle_mask;
246*7d116dccSCC Ma 	unsigned short ca7top_idle_mask;
247*7d116dccSCC Ma 	unsigned short wfi_op;
248*7d116dccSCC Ma 	unsigned short ca15_wfi0_en;
249*7d116dccSCC Ma 	unsigned short ca15_wfi1_en;
250*7d116dccSCC Ma 	unsigned short ca15_wfi2_en;
251*7d116dccSCC Ma 	unsigned short ca15_wfi3_en;
252*7d116dccSCC Ma 	unsigned short ca7_wfi0_en;
253*7d116dccSCC Ma 	unsigned short ca7_wfi1_en;
254*7d116dccSCC Ma 	unsigned short ca7_wfi2_en;
255*7d116dccSCC Ma 	unsigned short ca7_wfi3_en;
256*7d116dccSCC Ma 	unsigned short disp_req_mask;
257*7d116dccSCC Ma 	unsigned short mfg_req_mask;
258*7d116dccSCC Ma 	unsigned short md32_req_mask;
259*7d116dccSCC Ma 	unsigned short syspwreq_mask;
260*7d116dccSCC Ma 	unsigned short srclkenai_mask;
261*7d116dccSCC Ma };
262*7d116dccSCC Ma 
263*7d116dccSCC Ma struct wake_status {
264*7d116dccSCC Ma 	unsigned int assert_pc;
265*7d116dccSCC Ma 	unsigned int r12;
266*7d116dccSCC Ma 	unsigned int raw_sta;
267*7d116dccSCC Ma 	unsigned int wake_misc;
268*7d116dccSCC Ma 	unsigned int timer_out;
269*7d116dccSCC Ma 	unsigned int r13;
270*7d116dccSCC Ma 	unsigned int idle_sta;
271*7d116dccSCC Ma 	unsigned int debug_flag;
272*7d116dccSCC Ma 	unsigned int event_reg;
273*7d116dccSCC Ma 	unsigned int isr;
274*7d116dccSCC Ma };
275*7d116dccSCC Ma 
276*7d116dccSCC Ma struct pcm_desc {
277*7d116dccSCC Ma 	const char *version;		/* PCM code version */
278*7d116dccSCC Ma 	const unsigned int *base;	/* binary array base */
279*7d116dccSCC Ma 	const unsigned int size;	/* binary array size */
280*7d116dccSCC Ma 	const unsigned char sess;	/* session number */
281*7d116dccSCC Ma 	const unsigned char replace;	/* replace mode */
282*7d116dccSCC Ma 
283*7d116dccSCC Ma 	unsigned int vec0;		/* event vector 0 config */
284*7d116dccSCC Ma 	unsigned int vec1;		/* event vector 1 config */
285*7d116dccSCC Ma 	unsigned int vec2;		/* event vector 2 config */
286*7d116dccSCC Ma 	unsigned int vec3;		/* event vector 3 config */
287*7d116dccSCC Ma 	unsigned int vec4;		/* event vector 4 config */
288*7d116dccSCC Ma 	unsigned int vec5;		/* event vector 5 config */
289*7d116dccSCC Ma 	unsigned int vec6;		/* event vector 6 config */
290*7d116dccSCC Ma 	unsigned int vec7;		/* event vector 7 config */
291*7d116dccSCC Ma };
292*7d116dccSCC Ma 
293*7d116dccSCC Ma struct spm_lp_scen {
294*7d116dccSCC Ma 	const struct pcm_desc *pcmdesc;
295*7d116dccSCC Ma 	struct pwr_ctrl *pwrctrl;
296*7d116dccSCC Ma };
297*7d116dccSCC Ma 
298*7d116dccSCC Ma #define EVENT_VEC(event, resume, imme, pc)	\
299*7d116dccSCC Ma 	(((pc) << 16) |				\
300*7d116dccSCC Ma 	 (!!(imme) << 6) |			\
301*7d116dccSCC Ma 	 (!!(resume) << 5) |			\
302*7d116dccSCC Ma 	 ((event) & 0x1f))
303*7d116dccSCC Ma 
304*7d116dccSCC Ma #define spm_read(addr)		mmio_read_32(addr)
305*7d116dccSCC Ma #define spm_write(addr, val)	mmio_write_32(addr, val)
306*7d116dccSCC Ma 
307*7d116dccSCC Ma #define is_cpu_pdn(flags)	(!((flags) & SPM_CPU_PDN_DIS))
308*7d116dccSCC Ma #define is_infra_pdn(flags)	(!((flags) & SPM_INFRA_PDN_DIS))
309*7d116dccSCC Ma #define is_ddrphy_pdn(flags)	(!((flags) & SPM_DDRPHY_PDN_DIS))
310*7d116dccSCC Ma 
311*7d116dccSCC Ma static inline void set_pwrctrl_pcm_flags(struct pwr_ctrl *pwrctrl,
312*7d116dccSCC Ma 					 unsigned int flags)
313*7d116dccSCC Ma {
314*7d116dccSCC Ma 	flags &= ~SPM_EXT_VSEL_GPIO103;
315*7d116dccSCC Ma 
316*7d116dccSCC Ma 	if (pwrctrl->pcm_flags_cust == 0)
317*7d116dccSCC Ma 		pwrctrl->pcm_flags = flags;
318*7d116dccSCC Ma 	else
319*7d116dccSCC Ma 		pwrctrl->pcm_flags = pwrctrl->pcm_flags_cust;
320*7d116dccSCC Ma }
321*7d116dccSCC Ma 
322*7d116dccSCC Ma static inline void set_pwrctrl_pcm_data(struct pwr_ctrl *pwrctrl,
323*7d116dccSCC Ma 					unsigned int data)
324*7d116dccSCC Ma {
325*7d116dccSCC Ma 	pwrctrl->pcm_reserve = data;
326*7d116dccSCC Ma }
327*7d116dccSCC Ma 
328*7d116dccSCC Ma void spm_reset_and_init_pcm(void);
329*7d116dccSCC Ma 
330*7d116dccSCC Ma void spm_init_pcm_register(void);	/* init r0 and r7 */
331*7d116dccSCC Ma void spm_set_power_control(const struct pwr_ctrl *pwrctrl);
332*7d116dccSCC Ma void spm_set_wakeup_event(const struct pwr_ctrl *pwrctrl);
333*7d116dccSCC Ma 
334*7d116dccSCC Ma void spm_get_wakeup_status(struct wake_status *wakesta);
335*7d116dccSCC Ma void spm_set_sysclk_settle(void);
336*7d116dccSCC Ma void spm_kick_pcm_to_run(struct pwr_ctrl *pwrctrl);
337*7d116dccSCC Ma void spm_clean_after_wakeup(void);
338*7d116dccSCC Ma enum wake_reason_t spm_output_wake_reason(struct wake_status *wakesta);
339*7d116dccSCC Ma void spm_register_init(void);
340*7d116dccSCC Ma void spm_go_to_hotplug(void);
341*7d116dccSCC Ma void spm_init_event_vector(const struct pcm_desc *pcmdesc);
342*7d116dccSCC Ma void spm_kick_im_to_fetch(const struct pcm_desc *pcmdesc);
343*7d116dccSCC Ma void spm_set_sysclk_settle(void);
344*7d116dccSCC Ma int is_mcdi_ready(void);
345*7d116dccSCC Ma int is_hotplug_ready(void);
346*7d116dccSCC Ma int is_suspend_ready(void);
347*7d116dccSCC Ma void set_mcdi_ready(void);
348*7d116dccSCC Ma void set_hotplug_ready(void);
349*7d116dccSCC Ma void set_suspend_ready(void);
350*7d116dccSCC Ma void clear_all_ready(void);
351*7d116dccSCC Ma void spm_lock_init(void);
352*7d116dccSCC Ma void spm_lock_get(void);
353*7d116dccSCC Ma void spm_lock_release(void);
354*7d116dccSCC Ma void spm_boot_init(void);
355*7d116dccSCC Ma 
356*7d116dccSCC Ma #endif /* __SPM_H__ */
357