/* * Copyright (c) 2018-2025, ARM Limited and Contributors. All rights reserved. * Copyright (c) 2022-2025, Renesas Electronics Corporation. All rights reserved. * * SPDX-License-Identifier: BSD-3-Clause */ #ifndef RCAR_PLAT_LD_S #define RCAR_PLAT_LD_S #include #include MEMORY { SRAM (rwx): ORIGIN = DEVICE_SRAM_BASE, LENGTH = DEVICE_SRAM_SIZE SRAM_DATA (rwx): ORIGIN = DEVICE_SRAM_DATA_BASE, LENGTH = DEVICE_SRAM_DATA_SIZE PRAM (r) : ORIGIN = BL31_LIMIT - (DEVICE_SRAM_SIZE + DEVICE_SRAM_DATA_SIZE), LENGTH = DEVICE_SRAM_SIZE + DEVICE_SRAM_DATA_SIZE } SECTIONS { /* SRAM_COPY is in PRAM (RO) */ . = BL31_LIMIT - (DEVICE_SRAM_SIZE + DEVICE_SRAM_DATA_SIZE); __SRAM_COPY_START__ = .; .system_ram : { /* system ram start is in SRAM */ __system_ram_start__ = .; *(.system_ram) *spinlock.o(.text.*) __system_ram_end__ = .; } >SRAM AT>PRAM /* SRAM variable is in PRAM (RW) */ . = BL31_LIMIT - DEVICE_SRAM_DATA_SIZE; .system_ram_data : { __system_ram_data_start__ = .; *(.system_ram_data) __system_ram_data_end__ = .; } >SRAM_DATA AT>PRAM ASSERT(__BL31_END__ <= (BL31_LIMIT - (DEVICE_SRAM_SIZE + DEVICE_SRAM_DATA_SIZE)), "BL31 image too large - writing on top of SRAM!") } #endif /* RCAR_PLAT_LD_S */