1c8284409SSoren Brinkmann /* 2c8284409SSoren Brinkmann * Copyright (c) 2014-2016, ARM Limited and Contributors. All rights reserved. 3c8284409SSoren Brinkmann * 4c8284409SSoren Brinkmann * Redistribution and use in source and binary forms, with or without 5c8284409SSoren Brinkmann * modification, are permitted provided that the following conditions are met: 6c8284409SSoren Brinkmann * 7c8284409SSoren Brinkmann * Redistributions of source code must retain the above copyright notice, this 8c8284409SSoren Brinkmann * list of conditions and the following disclaimer. 9c8284409SSoren Brinkmann * 10c8284409SSoren Brinkmann * Redistributions in binary form must reproduce the above copyright notice, 11c8284409SSoren Brinkmann * this list of conditions and the following disclaimer in the documentation 12c8284409SSoren Brinkmann * and/or other materials provided with the distribution. 13c8284409SSoren Brinkmann * 14c8284409SSoren Brinkmann * Neither the name of ARM nor the names of its contributors may be used 15c8284409SSoren Brinkmann * to endorse or promote products derived from this software without specific 16c8284409SSoren Brinkmann * prior written permission. 17c8284409SSoren Brinkmann * 18c8284409SSoren Brinkmann * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 19c8284409SSoren Brinkmann * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 20c8284409SSoren Brinkmann * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 21c8284409SSoren Brinkmann * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 22c8284409SSoren Brinkmann * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 23c8284409SSoren Brinkmann * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 24c8284409SSoren Brinkmann * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 25c8284409SSoren Brinkmann * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 26c8284409SSoren Brinkmann * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 27c8284409SSoren Brinkmann * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 28c8284409SSoren Brinkmann * POSSIBILITY OF SUCH DAMAGE. 29c8284409SSoren Brinkmann */ 30c8284409SSoren Brinkmann 31c8284409SSoren Brinkmann #ifndef __PLATFORM_DEF_H__ 32c8284409SSoren Brinkmann #define __PLATFORM_DEF_H__ 33c8284409SSoren Brinkmann 34c8284409SSoren Brinkmann #include <arch.h> 35c8284409SSoren Brinkmann #include "../zynqmp_def.h" 36c8284409SSoren Brinkmann 37c8284409SSoren Brinkmann /******************************************************************************* 38c8284409SSoren Brinkmann * Generic platform constants 39c8284409SSoren Brinkmann ******************************************************************************/ 40c8284409SSoren Brinkmann 41c8284409SSoren Brinkmann /* Size of cacheable stacks */ 42c8284409SSoren Brinkmann #define PLATFORM_STACK_SIZE 0x440 43c8284409SSoren Brinkmann 44c8284409SSoren Brinkmann #define PLATFORM_CORE_COUNT 4 45c8284409SSoren Brinkmann #define PLAT_NUM_POWER_DOMAINS 5 46c8284409SSoren Brinkmann #define PLAT_MAX_PWR_LVL 1 47c8284409SSoren Brinkmann #define PLAT_MAX_RET_STATE 1 48c8284409SSoren Brinkmann #define PLAT_MAX_OFF_STATE 2 49c8284409SSoren Brinkmann 50c8284409SSoren Brinkmann /******************************************************************************* 51c8284409SSoren Brinkmann * BL31 specific defines. 52c8284409SSoren Brinkmann ******************************************************************************/ 53c8284409SSoren Brinkmann /* 54c8284409SSoren Brinkmann * Put BL31 at the top of the Trusted SRAM (just below the shared memory, if 55c8284409SSoren Brinkmann * present). BL31_BASE is calculated using the current BL31 debug size plus a 56c8284409SSoren Brinkmann * little space for growth. 57c8284409SSoren Brinkmann */ 58*01555332SSoren Brinkmann #ifndef ZYNQMP_ATF_MEM_BASE 59*01555332SSoren Brinkmann # define BL31_BASE 0xfffe5000 60*01555332SSoren Brinkmann # define BL31_PROGBITS_LIMIT 0xffffa000 61*01555332SSoren Brinkmann # define BL31_LIMIT 0xffffffff 62c8284409SSoren Brinkmann #else 63*01555332SSoren Brinkmann # define BL31_BASE (ZYNQMP_ATF_MEM_BASE) 64*01555332SSoren Brinkmann # define BL31_LIMIT (ZYNQMP_ATF_MEM_BASE + ZYNQMP_ATF_MEM_SIZE - 1) 65*01555332SSoren Brinkmann # ifdef ZYNQMP_ATF_MEM_PROGBITS_SIZE 66*01555332SSoren Brinkmann # define BL31_PROGBITS_LIMIT (ZYNQMP_ATF_MEM_BASE + ZYNQMP_ATF_MEM_PROGBITS_SIZE - 1) 67*01555332SSoren Brinkmann # endif 68c8284409SSoren Brinkmann #endif 69c8284409SSoren Brinkmann 70c8284409SSoren Brinkmann /******************************************************************************* 71c8284409SSoren Brinkmann * BL32 specific defines. 72c8284409SSoren Brinkmann ******************************************************************************/ 73*01555332SSoren Brinkmann #ifndef ZYNQMP_BL32_MEM_BASE 74*01555332SSoren Brinkmann # define BL32_BASE 0x60000000 75*01555332SSoren Brinkmann # define BL32_LIMIT 0x7fffffff 76c8284409SSoren Brinkmann #else 77*01555332SSoren Brinkmann # define BL32_BASE (ZYNQMP_BL32_MEM_BASE) 78*01555332SSoren Brinkmann # define BL32_LIMIT (ZYNQMP_BL32_MEM_BASE + ZYNQMP_BL32_MEM_SIZE - 1) 79c8284409SSoren Brinkmann #endif 80c8284409SSoren Brinkmann 81*01555332SSoren Brinkmann /******************************************************************************* 82*01555332SSoren Brinkmann * BL33 specific defines. 83*01555332SSoren Brinkmann ******************************************************************************/ 84*01555332SSoren Brinkmann #ifndef PRELOADED_BL33_BASE 85*01555332SSoren Brinkmann # define PLAT_ARM_NS_IMAGE_OFFSET 0x8000000 86*01555332SSoren Brinkmann #else 87*01555332SSoren Brinkmann # define PLAT_ARM_NS_IMAGE_OFFSET PRELOADED_BL33_BASE 88*01555332SSoren Brinkmann #endif 89*01555332SSoren Brinkmann 90*01555332SSoren Brinkmann /******************************************************************************* 91*01555332SSoren Brinkmann * TSP specific defines. 92*01555332SSoren Brinkmann ******************************************************************************/ 93*01555332SSoren Brinkmann #define TSP_SEC_MEM_BASE BL32_BASE 94*01555332SSoren Brinkmann #define TSP_SEC_MEM_SIZE (BL32_LIMIT - BL32_BASE + 1) 95*01555332SSoren Brinkmann 96*01555332SSoren Brinkmann /* ID of the secure physical generic timer interrupt used by the TSP */ 97c8284409SSoren Brinkmann #define TSP_IRQ_SEC_PHY_TIMER ARM_IRQ_SEC_PHY_TIMER 98c8284409SSoren Brinkmann 99c8284409SSoren Brinkmann /******************************************************************************* 100c8284409SSoren Brinkmann * Platform specific page table and MMU setup constants 101c8284409SSoren Brinkmann ******************************************************************************/ 102c8284409SSoren Brinkmann #define ADDR_SPACE_SIZE (1ull << 32) 103c8284409SSoren Brinkmann #define MAX_XLAT_TABLES 5 104c8284409SSoren Brinkmann #define MAX_MMAP_REGIONS 7 105c8284409SSoren Brinkmann 106c8284409SSoren Brinkmann #define CACHE_WRITEBACK_SHIFT 6 107c8284409SSoren Brinkmann #define CACHE_WRITEBACK_GRANULE (1 << CACHE_WRITEBACK_SHIFT) 108c8284409SSoren Brinkmann 109c8284409SSoren Brinkmann #define PLAT_ARM_GICD_BASE BASE_GICD_BASE 110c8284409SSoren Brinkmann #define PLAT_ARM_GICC_BASE BASE_GICC_BASE 111c8284409SSoren Brinkmann /* 112c8284409SSoren Brinkmann * Define a list of Group 1 Secure and Group 0 interrupts as per GICv3 113c8284409SSoren Brinkmann * terminology. On a GICv2 system or mode, the lists will be merged and treated 114c8284409SSoren Brinkmann * as Group 0 interrupts. 115c8284409SSoren Brinkmann */ 116c8284409SSoren Brinkmann #define PLAT_ARM_G1S_IRQS ARM_IRQ_SEC_PHY_TIMER, \ 117c8284409SSoren Brinkmann IRQ_SEC_IPI_APU, \ 118c8284409SSoren Brinkmann ARM_IRQ_SEC_SGI_0, \ 119c8284409SSoren Brinkmann ARM_IRQ_SEC_SGI_1, \ 120c8284409SSoren Brinkmann ARM_IRQ_SEC_SGI_2, \ 121c8284409SSoren Brinkmann ARM_IRQ_SEC_SGI_3, \ 122c8284409SSoren Brinkmann ARM_IRQ_SEC_SGI_4, \ 123c8284409SSoren Brinkmann ARM_IRQ_SEC_SGI_5, \ 124c8284409SSoren Brinkmann ARM_IRQ_SEC_SGI_6, \ 125c8284409SSoren Brinkmann ARM_IRQ_SEC_SGI_7 126c8284409SSoren Brinkmann 127c8284409SSoren Brinkmann #define PLAT_ARM_G0_IRQS 128c8284409SSoren Brinkmann 129c8284409SSoren Brinkmann #endif /* __PLATFORM_DEF_H__ */ 130