/* * Arm SCP/MCP Software * Copyright (c) 2020, Arm Limited and Contributors. All rights reserved. * * SPDX-License-Identifier: BSD-3-Clause * * Description: * SCP PIK registers */ #ifndef SCP_PIK_H #define SCP_PIK_H #include "scp_css_mmap.h" #include #include /*! * \brief SCP PIK register definitions */ struct pik_scp_reg { uint8_t RESERVED0[0x10 - 0x0]; FWK_RW uint32_t RESET_SYNDROME; uint8_t RESERVED1[0x20 - 0x14]; FWK_RW uint32_t SURVIVAL_RESET_STATUS; uint8_t RESERVED2[0x34 - 0x24]; FWK_RW uint32_t ADDR_TRANS; FWK_RW uint32_t DBG_ADDR_TRANS; uint8_t RESERVED3[0x40 - 0x3C]; FWK_RW uint32_t WS1_TIMER_MATCH; FWK_RW uint32_t WS1_TIMER_EN; uint8_t RESERVED4[0x200 - 0x48]; FWK_R uint32_t SS_RESET_STATUS; FWK_W uint32_t SS_RESET_SET; FWK_W uint32_t SS_RESET_CLR; uint8_t RESERVED5[0x810 - 0x20C]; FWK_RW uint32_t CORECLK_CTRL; FWK_RW uint32_t CORECLK_DIV1; uint8_t RESERVED6[0x820 - 0x818]; FWK_RW uint32_t ACLK_CTRL; FWK_RW uint32_t ACLK_DIV1; uint8_t RESERVED7[0xA10 - 0x828]; FWK_R uint32_t PLL_STATUS[17]; uint8_t RESERVED8[0xA60 - 0xA54]; FWK_R uint32_t CONS_MMUTCU_INT_STATUS; FWK_R uint32_t CONS_MMUTCU_INT_CLR; FWK_R uint32_t CONS_MMUTBU_INT_STATUS0; FWK_R uint32_t CONS_MMUTBU_INT_CLR0; FWK_R uint32_t CONS_MMUTBU_INT_STATUS1; FWK_R uint32_t CONS_MMUTBU_INT_CLR1; FWK_RW uint32_t CONS_MMUTBU_INT_STATUS2; FWK_RW uint32_t CONS_MMUTBU_INT_CLR2; FWK_RW uint32_t CONS_MMUTBU_INT_STATUS3; FWK_RW uint32_t CONS_MMUTBU_INT_CLR3; FWK_RW uint32_t CONS_MMUTBU_INT_STATUS4; FWK_RW uint32_t CONS_MMUTBU_INT_CLR4; FWK_RW uint32_t CONS_MMUTBU_INT_STATUS5; FWK_RW uint32_t CONS_MMUTBU_INT_CLR5; uint8_t RESERVED9[0xB20 - 0xA98]; FWK_R uint32_t CPU_PPU_INT_STATUS[4]; uint8_t RESERVED10[0xB40 - 0xB30]; FWK_R uint32_t CLUS_PPU_INT_STATUS[4]; uint8_t RESERVED11[0xB80 - 0xB50]; FWK_R uint32_t TIMER_INT_STATUS[8]; FWK_R uint32_t CPU_PLL_LOCK_STATUS[8]; uint8_t RESERVED12[0xBC0 - 0xBA0]; FWK_R uint32_t CPU_PLL_UNLOCK_STATUS[8]; FWK_R uint32_t CONS_CLUS_SCF_INT_STATUSx[4]; uint8_t RESERVED13[0xFC0 - 0xC10]; FWK_R uint32_t POWER_CONTROL_CONFIG; uint8_t RESERVED14[0xFD0 - 0xFC4]; FWK_R uint32_t PID4; FWK_R uint32_t PID5; FWK_R uint32_t PID6; FWK_R uint32_t PID7; FWK_R uint32_t PID0; FWK_R uint32_t PID1; FWK_R uint32_t PID2; FWK_R uint32_t PID3; FWK_R uint32_t ID0; FWK_R uint32_t ID1; FWK_R uint32_t ID2; FWK_R uint32_t ID3; }; #define PLL_STATUS_0_REFCLK UINT32_C(0x00000001) #define PLL_STATUS_0_SYSPLLLOCK UINT32_C(0x00000002) #define PLL_STATUS_0_DDRPLLLOCK UINT32_C(0x00000004) #define PLL_STATUS_0_INTPLLLOCK UINT32_C(0x00000008) #define PLL_STATUS_CPUPLLLOCK(CPU) ((uint32_t)(1 << (CPU % 32))) /* Pointer to SCP PIK */ #define SCP_PIK_PTR ((struct pik_scp_reg *) SCP_PIK_SCP_BASE) #endif /* SCP_PIK_H */