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