mbed-os/targets/TARGET_NUVOTON/TARGET_M2351/device/partition_M2351_mem.h

280 lines
8.7 KiB
C

/*
* Copyright (c) 2018-2019, Nuvoton Technology Corporation
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef __PARTITION_M2351_MEM_H__
#define __PARTITION_M2351_MEM_H__
/* About partition_M2351_mem.h/partition_M2351_mem.icf.h
*
* 1. partition_M2351_mem.h is created for centralizing memory partition configuration. It will be
* included by C/C++ files and linker files (except IAR linker file).
* 2. IAR linker doesn't support preprocessor, so partition_M2351_mem.icf.h, duplicate of partition_M2351_mem.h
* is created for IAR linker file.
* 3. To continue above, we name partition_M2351_mem.icf.h instead of partition_M2351_mem.icf because:
* (1) Mbed OS build tool may mis-regard partition_M2351_mem.icf as the main linker configuration file.
* (2) *.icf files may not be present in search directories for "include" directive. Per observation,
* the search directories are inconsistent among normal example build and test code build. To address
* it, we name partition_M2351_mem.icf.h instead because *.h files are always present in these builds
* (already there or via copy).
*/
/* Default flash/SRAM partition
*
* Default flash partition:
* Secure: 256KiB
* Non-secure: 256KiB
*
* Default SRAM partition:
* Secure: 32KiB
* Non-secure: 64KiB
*/
#if defined(DOMAIN_NS) && DOMAIN_NS
/* Resolve non-secure ROM start */
#ifndef MBED_ROM_START
#ifdef PSA_NON_SECURE_ROM_START
#define MBED_ROM_START (PSA_NON_SECURE_ROM_START)
#else
#define MBED_ROM_START (0x10040000)
#endif
#endif
/* Resolve non-secure ROM size */
#ifndef MBED_ROM_SIZE
#ifdef PSA_NON_SECURE_ROM_SIZE
#define MBED_ROM_SIZE (PSA_NON_SECURE_ROM_SIZE)
#else
#define MBED_ROM_SIZE (0x40000)
#endif
#endif
/* Resolve non-secure RAM start */
#ifndef MBED_RAM_START
#ifdef PSA_NON_SECURE_RAM_START
#define MBED_RAM_START (PSA_NON_SECURE_RAM_START)
#else
#define MBED_RAM_START (0x30008000)
#endif
#endif
/* Resolve non-secure RAM size */
#ifndef MBED_RAM_SIZE
#ifdef PSA_NON_SECURE_RAM_SIZE
#define MBED_RAM_SIZE (PSA_NON_SECURE_RAM_SIZE)
#else
#define MBED_RAM_SIZE (0x10000)
#endif
#endif
#else
/* Resolve secure ROM start */
#ifndef MBED_ROM_START
#ifdef PSA_SECURE_ROM_START
#define MBED_ROM_START (PSA_SECURE_ROM_START)
#else
#define MBED_ROM_START (0x0)
#endif
#endif
/* Resolve secure ROM size */
#ifndef MBED_ROM_SIZE
#ifdef PSA_SECURE_ROM_SIZE
#define MBED_ROM_SIZE (PSA_SECURE_ROM_SIZE)
#else
#define MBED_ROM_SIZE (0x40000)
#endif
#endif
/* Resolve secure RAM start */
#ifndef MBED_RAM_START
#ifdef PSA_SECURE_RAM_START
#define MBED_RAM_START (PSA_SECURE_RAM_START)
#else
#define MBED_RAM_START (0x20000000)
#endif
#endif
/* Resolve secure RAM size */
#ifndef MBED_RAM_SIZE
#ifdef PSA_SECURE_RAM_SIZE
#define MBED_RAM_SIZE (PSA_SECURE_RAM_SIZE)
#else
#define MBED_RAM_SIZE (0x8000)
#endif
#endif
#endif
/* Resolved flash/SRAM partition */
#if defined(DOMAIN_NS) && DOMAIN_NS
/* Resolved secure ROM layout */
#define NU_ROM_START_S 0x0
#define NU_ROM_SIZE_S (0x80000 - MBED_ROM_SIZE)
/* Resolved secure RAM layout */
#define NU_RAM_START_S 0x20000000
#define NU_RAM_SIZE_S (0x18000 - MBED_RAM_SIZE)
/* Resolved non-secure ROM layout */
#define NU_ROM_START_NS MBED_ROM_START
#define NU_ROM_SIZE_NS MBED_ROM_SIZE
/* Resolved non-secure RAM layout */
#define NU_RAM_START_NS MBED_RAM_START
#define NU_RAM_SIZE_NS MBED_RAM_SIZE
#else
/* Resolved secure ROM layout */
#define NU_ROM_START_S MBED_ROM_START
#define NU_ROM_SIZE_S MBED_ROM_SIZE
/* Resolved secure RAM layout */
#define NU_RAM_START_S MBED_RAM_START
#define NU_RAM_SIZE_S MBED_RAM_SIZE
/* Resolved non-secure ROM layout */
#define NU_ROM_START_NS (0x10000000 + MBED_ROM_SIZE)
#define NU_ROM_SIZE_NS (0x80000 - MBED_ROM_SIZE)
/* Resolved non-secure RAM layout */
#define NU_RAM_START_NS (0x30000000 + MBED_RAM_SIZE)
#define NU_RAM_SIZE_NS (0x18000 - MBED_RAM_SIZE)
#endif
/* Mbed build tool passes just APPLICATION_xxx macros to C/C++ files and just
* MBED_APP_xxx macros to linker files even though they mean the same thing.
* Because this file is to include by both C/C++ files and linker files, we add
* these macros according to the others for consistency when they are missing
* in compile or link stage. */
#ifndef APPLICATION_ADDR
#ifdef MBED_APP_START
#define APPLICATION_ADDR MBED_APP_START
#else
#define APPLICATION_ADDR MBED_ROM_START
#endif
#endif
#ifndef APPLICATION_SIZE
#ifdef MBED_APP_SIZE
#define APPLICATION_SIZE MBED_APP_SIZE
#else
#define APPLICATION_SIZE MBED_ROM_SIZE
#endif
#endif
#ifndef APPLICATION_RAM_ADDR
#ifdef MBED_RAM_APP_START
#define APPLICATION_RAM_ADDR MBED_RAM_APP_START
#else
#define APPLICATION_RAM_ADDR MBED_RAM_START
#endif
#endif
#ifndef APPLICATION_RAM_SIZE
#ifdef MBED_RAM_APP_SIZE
#define APPLICATION_RAM_SIZE MBED_RAM_APP_SIZE
#else
#define APPLICATION_RAM_SIZE MBED_RAM_SIZE
#endif
#endif
#ifndef MBED_APP_START
#define MBED_APP_START APPLICATION_ADDR
#endif
#ifndef MBED_APP_SIZE
#define MBED_APP_SIZE APPLICATION_SIZE
#endif
#ifndef MBED_RAM_APP_START
#define MBED_RAM_APP_START APPLICATION_RAM_ADDR
#endif
#ifndef MBED_RAM_APP_SIZE
#define MBED_RAM_APP_SIZE APPLICATION_RAM_SIZE
#endif
#if (APPLICATION_ADDR != MBED_APP_START)
#error("APPLICATION_ADDR and MBED_APP_START are not the same!!!")
#endif
#if (APPLICATION_SIZE != MBED_APP_SIZE)
#error("APPLICATION_SIZE and MBED_APP_SIZE are not the same!!!")
#endif
#if (APPLICATION_RAM_ADDR != MBED_RAM_APP_START)
#error("APPLICATION_RAM_ADDR and MBED_RAM_APP_START are not the same!!!")
#endif
#if (APPLICATION_RAM_SIZE != MBED_RAM_APP_SIZE)
#error("APPLICATION_RAM_SIZE and MBED_RAM_APP_SIZE are not the same!!!")
#endif
/* Determine NSC area
*
* Requirements for NSC area:
* 1. Requested by SAU, NSC area must start at 32 byte-aligned boundary.
* 2. By IDAU, 0~0x4000 is secure. NSC can only locate in 0x4000~0x10000000.
* 3. Greentea flash IAP uses last 2 sectors for its test. Avoid this range.
* 4. Greentea NVSTORE uses last 2 sectors or 4 KiB x 2 for its test. Avoid this range.
* 5. KVStore uses last a few KiB. Avoid this range.
* 6. Due to TFM build process, TFM and its tests must generate the same cmse_lib.o.
* To this end, TZ NSC location must fix at a well-known location and cannot place
* arbitrarily.
*
* Configurable for NSC area:
* We cannot configure NSC location via configuration parameter because the generated
* configuration macros are just passed to C/C++ files but not to linker files. So
* we can only hardcode NSC location here as constants (to be included by linker file).
*
* Locate NSC area at end of secure flash:
* We decide to locate NSC area at end of secure flash. To avoid this area
* accidentally erased by flash IAP operation, flash IAP must configure to exclude
* this area.
*/
/* TZ NSC area defaults to from secure ROM end */
#define NU_TZ_NSC_START (NU_ROM_START_S + NU_ROM_SIZE_S - NU_TZ_NSC_SIZE)
/* TZ NSC area defaults to 4KiB. */
#define NU_TZ_NSC_SIZE 0x1000
/* Configuration of TDB internal storage area
*
* 1. Must match "tdb_internal/mbed_lib.json"
* 2. Can pass to linker files for memory layout check
*
* With this approach, we can pass this configuration from "tdb_internal/mbed_lib.json"
* to linker file for detecting memory layout error before run-time.
*/
#if !defined(DOMAIN_NS) || (DOMAIN_NS == 0)
#if (TFM_LVL > 0)
/* TDB internal storage area defaults to 32KiB at end of flash. */
#define NU_TDB_INTERNAL_STORAGE_START (NU_ROM_START_S + NU_ROM_SIZE_S - NU_TZ_NSC_SIZE - NU_TDB_INTERNAL_STORAGE_SIZE)
#define NU_TDB_INTERNAL_STORAGE_SIZE 0x8000
#endif
#endif
/* Configuration of flash IAP area */
#define NU_FLASHIAP_SECURE_START NU_ROM_START_S
/* Exclude NSC area to avoid accidentally erased */
#define NU_FLASHIAP_SECURE_SIZE (NU_ROM_SIZE_S - NU_TZ_NSC_SIZE)
#define NU_FLASHIAP_NONSECURE_START NU_ROM_START_NS
#define NU_FLASHIAP_NONSECURE_SIZE NU_ROM_SIZE_NS
#endif /* __PARTITION_M2351_MEM_H__ */