17d116dccSCC Ma /*
27d116dccSCC Ma * Copyright (c) 2015, ARM Limited and Contributors. All rights reserved.
37d116dccSCC Ma *
482cb2c1aSdp-arm * SPDX-License-Identifier: BSD-3-Clause
57d116dccSCC Ma */
6*c3cf06f1SAntonio Nino Diaz #ifndef SPM_H
7*c3cf06f1SAntonio Nino Diaz #define SPM_H
87d116dccSCC Ma
97d116dccSCC Ma #define SPM_POWERON_CONFIG_SET (SPM_BASE + 0x000)
107d116dccSCC Ma #define SPM_POWER_ON_VAL0 (SPM_BASE + 0x010)
117d116dccSCC Ma #define SPM_POWER_ON_VAL1 (SPM_BASE + 0x014)
127d116dccSCC Ma #define SPM_CLK_SETTLE (SPM_BASE + 0x100)
137d116dccSCC Ma #define SPM_CA7_CPU1_PWR_CON (SPM_BASE + 0x218)
147d116dccSCC Ma #define SPM_CA7_CPU2_PWR_CON (SPM_BASE + 0x21c)
157d116dccSCC Ma #define SPM_CA7_CPU3_PWR_CON (SPM_BASE + 0x220)
167d116dccSCC Ma #define SPM_CA7_CPU1_L1_PDN (SPM_BASE + 0x264)
177d116dccSCC Ma #define SPM_CA7_CPU2_L1_PDN (SPM_BASE + 0x26c)
187d116dccSCC Ma #define SPM_CA7_CPU3_L1_PDN (SPM_BASE + 0x274)
197d116dccSCC Ma #define SPM_MD32_SRAM_CON (SPM_BASE + 0x2c8)
207d116dccSCC Ma #define SPM_PCM_CON0 (SPM_BASE + 0x310)
217d116dccSCC Ma #define SPM_PCM_CON1 (SPM_BASE + 0x314)
227d116dccSCC Ma #define SPM_PCM_IM_PTR (SPM_BASE + 0x318)
237d116dccSCC Ma #define SPM_PCM_IM_LEN (SPM_BASE + 0x31c)
247d116dccSCC Ma #define SPM_PCM_REG_DATA_INI (SPM_BASE + 0x320)
257d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR0 (SPM_BASE + 0x340)
267d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR1 (SPM_BASE + 0x344)
277d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR2 (SPM_BASE + 0x348)
287d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR3 (SPM_BASE + 0x34c)
297d116dccSCC Ma #define SPM_PCM_MAS_PAUSE_MASK (SPM_BASE + 0x354)
307d116dccSCC Ma #define SPM_PCM_PWR_IO_EN (SPM_BASE + 0x358)
317d116dccSCC Ma #define SPM_PCM_TIMER_VAL (SPM_BASE + 0x35c)
327d116dccSCC Ma #define SPM_PCM_TIMER_OUT (SPM_BASE + 0x360)
337d116dccSCC Ma #define SPM_PCM_REG0_DATA (SPM_BASE + 0x380)
347d116dccSCC Ma #define SPM_PCM_REG1_DATA (SPM_BASE + 0x384)
357d116dccSCC Ma #define SPM_PCM_REG2_DATA (SPM_BASE + 0x388)
367d116dccSCC Ma #define SPM_PCM_REG3_DATA (SPM_BASE + 0x38c)
377d116dccSCC Ma #define SPM_PCM_REG4_DATA (SPM_BASE + 0x390)
387d116dccSCC Ma #define SPM_PCM_REG5_DATA (SPM_BASE + 0x394)
397d116dccSCC Ma #define SPM_PCM_REG6_DATA (SPM_BASE + 0x398)
407d116dccSCC Ma #define SPM_PCM_REG7_DATA (SPM_BASE + 0x39c)
417d116dccSCC Ma #define SPM_PCM_REG8_DATA (SPM_BASE + 0x3a0)
427d116dccSCC Ma #define SPM_PCM_REG9_DATA (SPM_BASE + 0x3a4)
437d116dccSCC Ma #define SPM_PCM_REG10_DATA (SPM_BASE + 0x3a8)
447d116dccSCC Ma #define SPM_PCM_REG11_DATA (SPM_BASE + 0x3ac)
457d116dccSCC Ma #define SPM_PCM_REG12_DATA (SPM_BASE + 0x3b0)
467d116dccSCC Ma #define SPM_PCM_REG13_DATA (SPM_BASE + 0x3b4)
477d116dccSCC Ma #define SPM_PCM_REG14_DATA (SPM_BASE + 0x3b8)
487d116dccSCC Ma #define SPM_PCM_REG15_DATA (SPM_BASE + 0x3bc)
497d116dccSCC Ma #define SPM_PCM_EVENT_REG_STA (SPM_BASE + 0x3c0)
507d116dccSCC Ma #define SPM_PCM_FSM_STA (SPM_BASE + 0x3c4)
517d116dccSCC Ma #define SPM_PCM_IM_HOST_RW_PTR (SPM_BASE + 0x3c8)
527d116dccSCC Ma #define SPM_PCM_IM_HOST_RW_DAT (SPM_BASE + 0x3cc)
537d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR4 (SPM_BASE + 0x3d0)
547d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR5 (SPM_BASE + 0x3d4)
557d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR6 (SPM_BASE + 0x3d8)
567d116dccSCC Ma #define SPM_PCM_EVENT_VECTOR7 (SPM_BASE + 0x3dc)
577d116dccSCC Ma #define SPM_PCM_SW_INT_SET (SPM_BASE + 0x3e0)
587d116dccSCC Ma #define SPM_PCM_SW_INT_CLEAR (SPM_BASE + 0x3e4)
597d116dccSCC Ma #define SPM_CLK_CON (SPM_BASE + 0x400)
607d116dccSCC Ma #define SPM_SLEEP_PTPOD2_CON (SPM_BASE + 0x408)
617d116dccSCC Ma #define SPM_APMCU_PWRCTL (SPM_BASE + 0x600)
627d116dccSCC Ma #define SPM_AP_DVFS_CON_SET (SPM_BASE + 0x604)
637d116dccSCC Ma #define SPM_AP_STANBY_CON (SPM_BASE + 0x608)
647d116dccSCC Ma #define SPM_PWR_STATUS (SPM_BASE + 0x60c)
657d116dccSCC Ma #define SPM_PWR_STATUS_2ND (SPM_BASE + 0x610)
667d116dccSCC Ma #define SPM_AP_BSI_REQ (SPM_BASE + 0x614)
677d116dccSCC Ma #define SPM_SLEEP_TIMER_STA (SPM_BASE + 0x720)
687d116dccSCC Ma #define SPM_SLEEP_WAKEUP_EVENT_MASK (SPM_BASE + 0x810)
697d116dccSCC Ma #define SPM_SLEEP_CPU_WAKEUP_EVENT (SPM_BASE + 0x814)
707d116dccSCC Ma #define SPM_SLEEP_MD32_WAKEUP_EVENT_MASK (SPM_BASE + 0x818)
717d116dccSCC Ma #define SPM_PCM_WDT_TIMER_VAL (SPM_BASE + 0x824)
727d116dccSCC Ma #define SPM_PCM_WDT_TIMER_OUT (SPM_BASE + 0x828)
737d116dccSCC Ma #define SPM_PCM_MD32_MAILBOX (SPM_BASE + 0x830)
747d116dccSCC Ma #define SPM_PCM_MD32_IRQ (SPM_BASE + 0x834)
757d116dccSCC Ma #define SPM_SLEEP_ISR_MASK (SPM_BASE + 0x900)
767d116dccSCC Ma #define SPM_SLEEP_ISR_STATUS (SPM_BASE + 0x904)
777d116dccSCC Ma #define SPM_SLEEP_ISR_RAW_STA (SPM_BASE + 0x910)
787d116dccSCC Ma #define SPM_SLEEP_MD32_ISR_RAW_STA (SPM_BASE + 0x914)
797d116dccSCC Ma #define SPM_SLEEP_WAKEUP_MISC (SPM_BASE + 0x918)
807d116dccSCC Ma #define SPM_SLEEP_BUS_PROTECT_RDY (SPM_BASE + 0x91c)
817d116dccSCC Ma #define SPM_SLEEP_SUBSYS_IDLE_STA (SPM_BASE + 0x920)
827d116dccSCC Ma #define SPM_PCM_RESERVE (SPM_BASE + 0xb00)
837d116dccSCC Ma #define SPM_PCM_RESERVE2 (SPM_BASE + 0xb04)
847d116dccSCC Ma #define SPM_PCM_FLAGS (SPM_BASE + 0xb08)
857d116dccSCC Ma #define SPM_PCM_SRC_REQ (SPM_BASE + 0xb0c)
867d116dccSCC Ma #define SPM_PCM_DEBUG_CON (SPM_BASE + 0xb20)
877d116dccSCC Ma #define SPM_CA7_CPU0_IRQ_MASK (SPM_BASE + 0xb30)
887d116dccSCC Ma #define SPM_CA7_CPU1_IRQ_MASK (SPM_BASE + 0xb34)
897d116dccSCC Ma #define SPM_CA7_CPU2_IRQ_MASK (SPM_BASE + 0xb38)
907d116dccSCC Ma #define SPM_CA7_CPU3_IRQ_MASK (SPM_BASE + 0xb3c)
917d116dccSCC Ma #define SPM_CA15_CPU0_IRQ_MASK (SPM_BASE + 0xb40)
927d116dccSCC Ma #define SPM_CA15_CPU1_IRQ_MASK (SPM_BASE + 0xb44)
937d116dccSCC Ma #define SPM_CA15_CPU2_IRQ_MASK (SPM_BASE + 0xb48)
947d116dccSCC Ma #define SPM_CA15_CPU3_IRQ_MASK (SPM_BASE + 0xb4c)
957d116dccSCC Ma #define SPM_PCM_PASR_DPD_0 (SPM_BASE + 0xb60)
967d116dccSCC Ma #define SPM_PCM_PASR_DPD_1 (SPM_BASE + 0xb64)
977d116dccSCC Ma #define SPM_PCM_PASR_DPD_2 (SPM_BASE + 0xb68)
987d116dccSCC Ma #define SPM_PCM_PASR_DPD_3 (SPM_BASE + 0xb6c)
997d116dccSCC Ma #define SPM_SLEEP_CA7_WFI0_EN (SPM_BASE + 0xf00)
1007d116dccSCC Ma #define SPM_SLEEP_CA7_WFI1_EN (SPM_BASE + 0xf04)
1017d116dccSCC Ma #define SPM_SLEEP_CA7_WFI2_EN (SPM_BASE + 0xf08)
1027d116dccSCC Ma #define SPM_SLEEP_CA7_WFI3_EN (SPM_BASE + 0xf0c)
1037d116dccSCC Ma #define SPM_SLEEP_CA15_WFI0_EN (SPM_BASE + 0xf10)
1047d116dccSCC Ma #define SPM_SLEEP_CA15_WFI1_EN (SPM_BASE + 0xf14)
1057d116dccSCC Ma #define SPM_SLEEP_CA15_WFI2_EN (SPM_BASE + 0xf18)
1067d116dccSCC Ma #define SPM_SLEEP_CA15_WFI3_EN (SPM_BASE + 0xf1c)
1077d116dccSCC Ma
1083c454d52SJimmy Huang #define AP_PLL_CON3 0x1020900c
1093c454d52SJimmy Huang #define AP_PLL_CON4 0x10209010
1103c454d52SJimmy Huang
1117d116dccSCC Ma #define SPM_PROJECT_CODE 0xb16
1127d116dccSCC Ma
1137d116dccSCC Ma #define SPM_REGWR_EN (1U << 0)
1147d116dccSCC Ma #define SPM_REGWR_CFG_KEY (SPM_PROJECT_CODE << 16)
1157d116dccSCC Ma
1167d116dccSCC Ma #define SPM_CPU_PDN_DIS (1U << 0)
1177d116dccSCC Ma #define SPM_INFRA_PDN_DIS (1U << 1)
1187d116dccSCC Ma #define SPM_DDRPHY_PDN_DIS (1U << 2)
1197d116dccSCC Ma #define SPM_DUALVCORE_PDN_DIS (1U << 3)
1207d116dccSCC Ma #define SPM_PASR_DIS (1U << 4)
1217d116dccSCC Ma #define SPM_DPD_DIS (1U << 5)
1227d116dccSCC Ma #define SPM_SODI_DIS (1U << 6)
1237d116dccSCC Ma #define SPM_MEMPLL_RESET (1U << 7)
1247d116dccSCC Ma #define SPM_MAINPLL_PDN_DIS (1U << 8)
1257d116dccSCC Ma #define SPM_CPU_DVS_DIS (1U << 9)
1267d116dccSCC Ma #define SPM_CPU_DORMANT (1U << 10)
1277d116dccSCC Ma #define SPM_EXT_VSEL_GPIO103 (1U << 11)
1287d116dccSCC Ma #define SPM_DDR_HIGH_SPEED (1U << 12)
1297d116dccSCC Ma #define SPM_OPT (1U << 13)
1307d116dccSCC Ma
1317d116dccSCC Ma #define POWER_ON_VAL1_DEF 0x01011820
1327d116dccSCC Ma #define PCM_FSM_STA_DEF 0x48490
1337d116dccSCC Ma #define PCM_END_FSM_STA_DEF 0x08490
1347d116dccSCC Ma #define PCM_END_FSM_STA_MASK 0x3fff0
1357d116dccSCC Ma #define PCM_HANDSHAKE_SEND1 0xbeefbeef
1367d116dccSCC Ma
1377d116dccSCC Ma #define PCM_WDT_TIMEOUT (30 * 32768)
1387d116dccSCC Ma #define PCM_TIMER_MAX (0xffffffff - PCM_WDT_TIMEOUT)
1397d116dccSCC Ma
1407d116dccSCC Ma #define CON0_PCM_KICK (1U << 0)
1417d116dccSCC Ma #define CON0_IM_KICK (1U << 1)
1427d116dccSCC Ma #define CON0_IM_SLEEP_DVS (1U << 3)
1437d116dccSCC Ma #define CON0_PCM_SW_RESET (1U << 15)
1447d116dccSCC Ma #define CON0_CFG_KEY (SPM_PROJECT_CODE << 16)
1457d116dccSCC Ma
1467d116dccSCC Ma #define CON1_IM_SLAVE (1U << 0)
1477d116dccSCC Ma #define CON1_MIF_APBEN (1U << 3)
1487d116dccSCC Ma #define CON1_PCM_TIMER_EN (1U << 5)
1497d116dccSCC Ma #define CON1_IM_NONRP_EN (1U << 6)
1507d116dccSCC Ma #define CON1_PCM_WDT_EN (1U << 8)
1517d116dccSCC Ma #define CON1_PCM_WDT_WAKE_MODE (1U << 9)
1527d116dccSCC Ma #define CON1_SPM_SRAM_SLP_B (1U << 10)
1537d116dccSCC Ma #define CON1_SPM_SRAM_ISO_B (1U << 11)
1547d116dccSCC Ma #define CON1_EVENT_LOCK_EN (1U << 12)
1557d116dccSCC Ma #define CON1_CFG_KEY (SPM_PROJECT_CODE << 16)
1567d116dccSCC Ma
1577d116dccSCC Ma #define PCM_PWRIO_EN_R0 (1U << 0)
1587d116dccSCC Ma #define PCM_PWRIO_EN_R7 (1U << 7)
1597d116dccSCC Ma #define PCM_RF_SYNC_R0 (1U << 16)
1607d116dccSCC Ma #define PCM_RF_SYNC_R2 (1U << 18)
1617d116dccSCC Ma #define PCM_RF_SYNC_R6 (1U << 22)
1627d116dccSCC Ma #define PCM_RF_SYNC_R7 (1U << 23)
1637d116dccSCC Ma
1647d116dccSCC Ma #define CC_SYSCLK0_EN_0 (1U << 0)
1657d116dccSCC Ma #define CC_SYSCLK0_EN_1 (1U << 1)
1667d116dccSCC Ma #define CC_SYSCLK1_EN_0 (1U << 2)
1677d116dccSCC Ma #define CC_SYSCLK1_EN_1 (1U << 3)
1687d116dccSCC Ma #define CC_SYSSETTLE_SEL (1U << 4)
1697d116dccSCC Ma #define CC_LOCK_INFRA_DCM (1U << 5)
1707d116dccSCC Ma #define CC_SRCLKENA_MASK_0 (1U << 6)
1717d116dccSCC Ma #define CC_CXO32K_RM_EN_MD1 (1U << 9)
1727d116dccSCC Ma #define CC_CXO32K_RM_EN_MD2 (1U << 10)
1737d116dccSCC Ma #define CC_CLKSQ1_SEL (1U << 12)
1747d116dccSCC Ma #define CC_DISABLE_DORM_PWR (1U << 14)
1757d116dccSCC Ma #define CC_MD32_DCM_EN (1U << 18)
1767d116dccSCC Ma
1777d116dccSCC Ma #define WFI_OP_AND 1
1787d116dccSCC Ma #define WFI_OP_OR 0
1797d116dccSCC Ma
1807d116dccSCC Ma #define WAKE_MISC_PCM_TIMER (1U << 19)
1817d116dccSCC Ma #define WAKE_MISC_CPU_WAKE (1U << 20)
1827d116dccSCC Ma
1837d116dccSCC Ma /* define WAKE_SRC_XXX */
1847d116dccSCC Ma #define WAKE_SRC_SPM_MERGE (1 << 0)
1857d116dccSCC Ma #define WAKE_SRC_KP (1 << 2)
1867d116dccSCC Ma #define WAKE_SRC_WDT (1 << 3)
1877d116dccSCC Ma #define WAKE_SRC_GPT (1 << 4)
1887d116dccSCC Ma #define WAKE_SRC_EINT (1 << 6)
1897d116dccSCC Ma #define WAKE_SRC_LOW_BAT (1 << 9)
1907d116dccSCC Ma #define WAKE_SRC_MD32 (1 << 10)
1917d116dccSCC Ma #define WAKE_SRC_USB_CD (1 << 14)
1927d116dccSCC Ma #define WAKE_SRC_USB_PDN (1 << 15)
1937d116dccSCC Ma #define WAKE_SRC_AFE (1 << 20)
1947d116dccSCC Ma #define WAKE_SRC_THERM (1 << 21)
19544c49087SWeiyi Lu #define WAKE_SRC_CIRQ (1 << 22)
1967d116dccSCC Ma #define WAKE_SRC_SYSPWREQ (1 << 24)
1977d116dccSCC Ma #define WAKE_SRC_SEJ (1 << 27)
1987d116dccSCC Ma #define WAKE_SRC_ALL_MD32 (1 << 28)
1997d116dccSCC Ma #define WAKE_SRC_CPU_IRQ (1 << 29)
2007d116dccSCC Ma
2017d116dccSCC Ma enum wake_reason_t {
2027d116dccSCC Ma WR_NONE = 0,
2037d116dccSCC Ma WR_UART_BUSY = 1,
2047d116dccSCC Ma WR_PCM_ASSERT = 2,
2057d116dccSCC Ma WR_PCM_TIMER = 3,
2067d116dccSCC Ma WR_PCM_ABORT = 4,
2077d116dccSCC Ma WR_WAKE_SRC = 5,
2087d116dccSCC Ma WR_UNKNOWN = 6,
2097d116dccSCC Ma };
2107d116dccSCC Ma
2117d116dccSCC Ma struct pwr_ctrl {
2127d116dccSCC Ma unsigned int pcm_flags;
2137d116dccSCC Ma unsigned int pcm_flags_cust;
2147d116dccSCC Ma unsigned int pcm_reserve;
2157d116dccSCC Ma unsigned int timer_val;
2167d116dccSCC Ma unsigned int timer_val_cust;
2177d116dccSCC Ma unsigned int wake_src;
2187d116dccSCC Ma unsigned int wake_src_cust;
2197d116dccSCC Ma unsigned int wake_src_md32;
2207d116dccSCC Ma unsigned short r0_ctrl_en;
2217d116dccSCC Ma unsigned short r7_ctrl_en;
2227d116dccSCC Ma unsigned short infra_dcm_lock;
2237d116dccSCC Ma unsigned short pcm_apsrc_req;
2247d116dccSCC Ma unsigned short mcusys_idle_mask;
2257d116dccSCC Ma unsigned short ca15top_idle_mask;
2267d116dccSCC Ma unsigned short ca7top_idle_mask;
2277d116dccSCC Ma unsigned short wfi_op;
2287d116dccSCC Ma unsigned short ca15_wfi0_en;
2297d116dccSCC Ma unsigned short ca15_wfi1_en;
2307d116dccSCC Ma unsigned short ca15_wfi2_en;
2317d116dccSCC Ma unsigned short ca15_wfi3_en;
2327d116dccSCC Ma unsigned short ca7_wfi0_en;
2337d116dccSCC Ma unsigned short ca7_wfi1_en;
2347d116dccSCC Ma unsigned short ca7_wfi2_en;
2357d116dccSCC Ma unsigned short ca7_wfi3_en;
2367d116dccSCC Ma unsigned short disp_req_mask;
2377d116dccSCC Ma unsigned short mfg_req_mask;
2387d116dccSCC Ma unsigned short md32_req_mask;
2397d116dccSCC Ma unsigned short syspwreq_mask;
2407d116dccSCC Ma unsigned short srclkenai_mask;
2417d116dccSCC Ma };
2427d116dccSCC Ma
2437d116dccSCC Ma struct wake_status {
2447d116dccSCC Ma unsigned int assert_pc;
2457d116dccSCC Ma unsigned int r12;
2467d116dccSCC Ma unsigned int raw_sta;
2477d116dccSCC Ma unsigned int wake_misc;
2487d116dccSCC Ma unsigned int timer_out;
2497d116dccSCC Ma unsigned int r13;
2507d116dccSCC Ma unsigned int idle_sta;
2517d116dccSCC Ma unsigned int debug_flag;
2527d116dccSCC Ma unsigned int event_reg;
2537d116dccSCC Ma unsigned int isr;
2547d116dccSCC Ma };
2557d116dccSCC Ma
2567d116dccSCC Ma struct pcm_desc {
2577d116dccSCC Ma const char *version; /* PCM code version */
2587d116dccSCC Ma const unsigned int *base; /* binary array base */
2597d116dccSCC Ma const unsigned int size; /* binary array size */
2607d116dccSCC Ma const unsigned char sess; /* session number */
2617d116dccSCC Ma const unsigned char replace; /* replace mode */
2627d116dccSCC Ma
2637d116dccSCC Ma unsigned int vec0; /* event vector 0 config */
2647d116dccSCC Ma unsigned int vec1; /* event vector 1 config */
2657d116dccSCC Ma unsigned int vec2; /* event vector 2 config */
2667d116dccSCC Ma unsigned int vec3; /* event vector 3 config */
2677d116dccSCC Ma unsigned int vec4; /* event vector 4 config */
2687d116dccSCC Ma unsigned int vec5; /* event vector 5 config */
2697d116dccSCC Ma unsigned int vec6; /* event vector 6 config */
2707d116dccSCC Ma unsigned int vec7; /* event vector 7 config */
2717d116dccSCC Ma };
2727d116dccSCC Ma
2737d116dccSCC Ma struct spm_lp_scen {
2747d116dccSCC Ma const struct pcm_desc *pcmdesc;
2757d116dccSCC Ma struct pwr_ctrl *pwrctrl;
2767d116dccSCC Ma };
2777d116dccSCC Ma
2787d116dccSCC Ma #define EVENT_VEC(event, resume, imme, pc) \
2797d116dccSCC Ma (((pc) << 16) | \
2807d116dccSCC Ma (!!(imme) << 6) | \
2817d116dccSCC Ma (!!(resume) << 5) | \
2827d116dccSCC Ma ((event) & 0x1f))
2837d116dccSCC Ma
2847d116dccSCC Ma #define spm_read(addr) mmio_read_32(addr)
2857d116dccSCC Ma #define spm_write(addr, val) mmio_write_32(addr, val)
2867d116dccSCC Ma
2877d116dccSCC Ma #define is_cpu_pdn(flags) (!((flags) & SPM_CPU_PDN_DIS))
2887d116dccSCC Ma #define is_infra_pdn(flags) (!((flags) & SPM_INFRA_PDN_DIS))
2897d116dccSCC Ma #define is_ddrphy_pdn(flags) (!((flags) & SPM_DDRPHY_PDN_DIS))
2907d116dccSCC Ma
set_pwrctrl_pcm_flags(struct pwr_ctrl * pwrctrl,unsigned int flags)2917d116dccSCC Ma static inline void set_pwrctrl_pcm_flags(struct pwr_ctrl *pwrctrl,
2927d116dccSCC Ma unsigned int flags)
2937d116dccSCC Ma {
2947d116dccSCC Ma flags &= ~SPM_EXT_VSEL_GPIO103;
2957d116dccSCC Ma
2967d116dccSCC Ma if (pwrctrl->pcm_flags_cust == 0)
2977d116dccSCC Ma pwrctrl->pcm_flags = flags;
2987d116dccSCC Ma else
2997d116dccSCC Ma pwrctrl->pcm_flags = pwrctrl->pcm_flags_cust;
3007d116dccSCC Ma }
3017d116dccSCC Ma
set_pwrctrl_pcm_data(struct pwr_ctrl * pwrctrl,unsigned int data)3027d116dccSCC Ma static inline void set_pwrctrl_pcm_data(struct pwr_ctrl *pwrctrl,
3037d116dccSCC Ma unsigned int data)
3047d116dccSCC Ma {
3057d116dccSCC Ma pwrctrl->pcm_reserve = data;
3067d116dccSCC Ma }
3077d116dccSCC Ma
3087d116dccSCC Ma void spm_reset_and_init_pcm(void);
3097d116dccSCC Ma
3107d116dccSCC Ma void spm_init_pcm_register(void); /* init r0 and r7 */
3117d116dccSCC Ma void spm_set_power_control(const struct pwr_ctrl *pwrctrl);
3127d116dccSCC Ma void spm_set_wakeup_event(const struct pwr_ctrl *pwrctrl);
3137d116dccSCC Ma
3147d116dccSCC Ma void spm_get_wakeup_status(struct wake_status *wakesta);
3157d116dccSCC Ma void spm_set_sysclk_settle(void);
3167d116dccSCC Ma void spm_kick_pcm_to_run(struct pwr_ctrl *pwrctrl);
3177d116dccSCC Ma void spm_clean_after_wakeup(void);
3187d116dccSCC Ma enum wake_reason_t spm_output_wake_reason(struct wake_status *wakesta);
3197d116dccSCC Ma void spm_register_init(void);
3207d116dccSCC Ma void spm_go_to_hotplug(void);
3217d116dccSCC Ma void spm_init_event_vector(const struct pcm_desc *pcmdesc);
3227d116dccSCC Ma void spm_kick_im_to_fetch(const struct pcm_desc *pcmdesc);
3237d116dccSCC Ma int is_mcdi_ready(void);
3247d116dccSCC Ma int is_hotplug_ready(void);
3257d116dccSCC Ma int is_suspend_ready(void);
3267d116dccSCC Ma void set_mcdi_ready(void);
3277d116dccSCC Ma void set_hotplug_ready(void);
3287d116dccSCC Ma void set_suspend_ready(void);
3297d116dccSCC Ma void clear_all_ready(void);
3307d116dccSCC Ma void spm_lock_init(void);
3317d116dccSCC Ma void spm_lock_get(void);
3327d116dccSCC Ma void spm_lock_release(void);
3337d116dccSCC Ma void spm_boot_init(void);
3347d116dccSCC Ma
335*c3cf06f1SAntonio Nino Diaz #endif /* SPM_H */
336