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