Unverified Commit 83df7ce3 authored by davidcunado-arm's avatar davidcunado-arm Committed by GitHub
Browse files

Merge pull request #1187 from antonio-nino-diaz-arm/an/spm-xlat-dram

SPM: Move S-EL1/S-EL0 xlat tables to TZC DRAM
parents 9f0ee04f 45d640f0
...@@ -168,21 +168,28 @@ typedef struct xlat_ctx xlat_ctx_t; ...@@ -168,21 +168,28 @@ typedef struct xlat_ctx xlat_ctx_t;
_xlat_tables_count, \ _xlat_tables_count, \
_virt_addr_space_size, \ _virt_addr_space_size, \
_phy_addr_space_size, \ _phy_addr_space_size, \
IMAGE_XLAT_DEFAULT_REGIME) IMAGE_XLAT_DEFAULT_REGIME, \
"xlat_table")
/* /*
* Same as REGISTER_XLAT_CONTEXT plus the additional parameter _xlat_regime to * Same as REGISTER_XLAT_CONTEXT plus the additional parameters:
* specify the translation regime managed by this xlat_ctx_t instance. The *
* values are the one from xlat_regime_t enumeration. * _xlat_regime:
* Specify the translation regime managed by this xlat_ctx_t instance. The
* values are the one from xlat_regime_t enumeration.
*
* _section_name:
* Specify the name of the section where the translation tables have to be
* placed by the linker.
*/ */
#define REGISTER_XLAT_CONTEXT2(_ctx_name, _mmap_count, _xlat_tables_count, \ #define REGISTER_XLAT_CONTEXT2(_ctx_name, _mmap_count, _xlat_tables_count, \
_virt_addr_space_size, _phy_addr_space_size, \ _virt_addr_space_size, _phy_addr_space_size, \
_xlat_regime) \ _xlat_regime, _section_name) \
_REGISTER_XLAT_CONTEXT_FULL_SPEC(_ctx_name, _mmap_count, \ _REGISTER_XLAT_CONTEXT_FULL_SPEC(_ctx_name, _mmap_count, \
_xlat_tables_count, \ _xlat_tables_count, \
_virt_addr_space_size, \ _virt_addr_space_size, \
_phy_addr_space_size, \ _phy_addr_space_size, \
_xlat_regime) _xlat_regime, _section_name)
/****************************************************************************** /******************************************************************************
* Generic translation table APIs. * Generic translation table APIs.
......
...@@ -123,7 +123,7 @@ struct xlat_ctx { ...@@ -123,7 +123,7 @@ struct xlat_ctx {
#define _REGISTER_XLAT_CONTEXT_FULL_SPEC(_ctx_name, _mmap_count, _xlat_tables_count, \ #define _REGISTER_XLAT_CONTEXT_FULL_SPEC(_ctx_name, _mmap_count, _xlat_tables_count, \
_virt_addr_space_size, _phy_addr_space_size, \ _virt_addr_space_size, _phy_addr_space_size, \
_xlat_regime) \ _xlat_regime, _section_name) \
CASSERT(CHECK_VIRT_ADDR_SPACE_SIZE(_virt_addr_space_size), \ CASSERT(CHECK_VIRT_ADDR_SPACE_SIZE(_virt_addr_space_size), \
assert_invalid_virtual_addr_space_size_for_##_ctx_name); \ assert_invalid_virtual_addr_space_size_for_##_ctx_name); \
\ \
...@@ -134,7 +134,7 @@ struct xlat_ctx { ...@@ -134,7 +134,7 @@ struct xlat_ctx {
\ \
static uint64_t _ctx_name##_xlat_tables[_xlat_tables_count] \ static uint64_t _ctx_name##_xlat_tables[_xlat_tables_count] \
[XLAT_TABLE_ENTRIES] \ [XLAT_TABLE_ENTRIES] \
__aligned(XLAT_TABLE_SIZE) __section("xlat_table"); \ __aligned(XLAT_TABLE_SIZE) __section(_section_name); \
\ \
static uint64_t _ctx_name##_base_xlat_table \ static uint64_t _ctx_name##_base_xlat_table \
[GET_NUM_BASE_LEVEL_ENTRIES(_virt_addr_space_size)] \ [GET_NUM_BASE_LEVEL_ENTRIES(_virt_addr_space_size)] \
......
...@@ -90,11 +90,7 @@ ...@@ -90,11 +90,7 @@
* PLAT_ARM_MAX_BL31_SIZE is calculated using the current BL31 debug size plus a * PLAT_ARM_MAX_BL31_SIZE is calculated using the current BL31 debug size plus a
* little space for growth. * little space for growth.
*/ */
#if ENABLE_SPM
#define PLAT_ARM_MAX_BL31_SIZE 0x28000
#else
#define PLAT_ARM_MAX_BL31_SIZE 0x1D000 #define PLAT_ARM_MAX_BL31_SIZE 0x1D000
#endif
#ifdef AARCH32 #ifdef AARCH32
/* /*
......
...@@ -98,6 +98,12 @@ ...@@ -98,6 +98,12 @@
/* Total number of memory regions with distinct properties */ /* Total number of memory regions with distinct properties */
#define ARM_SP_IMAGE_NUM_MEM_REGIONS 6 #define ARM_SP_IMAGE_NUM_MEM_REGIONS 6
/*
* Name of the section to put the translation tables used by the S-EL1/S-EL0
* context of a Secure Partition.
*/
#define PLAT_SP_IMAGE_XLAT_SECTION_NAME "arm_el3_tzc_dram"
/* Cookies passed to the Secure Partition at boot. Not used by ARM platforms. */ /* Cookies passed to the Secure Partition at boot. Not used by ARM platforms. */
#define PLAT_SPM_COOKIE_0 ULL(0) #define PLAT_SPM_COOKIE_0 ULL(0)
#define PLAT_SPM_COOKIE_1 ULL(0) #define PLAT_SPM_COOKIE_1 ULL(0)
......
...@@ -21,12 +21,17 @@ ...@@ -21,12 +21,17 @@
#include "spm_private.h" #include "spm_private.h"
#include "spm_shim_private.h" #include "spm_shim_private.h"
/* Place translation tables by default along with the ones used by BL31. */
#ifndef PLAT_SP_IMAGE_XLAT_SECTION_NAME
#define PLAT_SP_IMAGE_XLAT_SECTION_NAME "xlat_table"
#endif
/* Allocate and initialise the translation context for the secure partition. */ /* Allocate and initialise the translation context for the secure partition. */
REGISTER_XLAT_CONTEXT2(secure_partition, REGISTER_XLAT_CONTEXT2(secure_partition,
PLAT_SP_IMAGE_MMAP_REGIONS, PLAT_SP_IMAGE_MMAP_REGIONS,
PLAT_SP_IMAGE_MAX_XLAT_TABLES, PLAT_SP_IMAGE_MAX_XLAT_TABLES,
PLAT_VIRT_ADDR_SPACE_SIZE, PLAT_PHY_ADDR_SPACE_SIZE, PLAT_VIRT_ADDR_SPACE_SIZE, PLAT_PHY_ADDR_SPACE_SIZE,
EL1_EL0_REGIME); EL1_EL0_REGIME, PLAT_SP_IMAGE_XLAT_SECTION_NAME);
/* Export a handle on the secure partition translation context */ /* Export a handle on the secure partition translation context */
xlat_ctx_t *secure_partition_xlat_ctx_handle = &secure_partition_xlat_ctx; xlat_ctx_t *secure_partition_xlat_ctx_handle = &secure_partition_xlat_ctx;
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment