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