123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- /*
- * Copyright (c) 2016, ARM Limited and Contributors. All rights reserved.
- *
- * SPDX-License-Identifier: BSD-3-Clause
- */
- #ifndef ROCKCHIP_PLAT_LD_S
- #define ROCKCHIP_PLAT_LD_S
- #include <lib/xlat_tables/xlat_tables_defs.h>
- MEMORY {
- SRAM (rwx): ORIGIN = SRAM_BASE, LENGTH = SRAM_SIZE
- PMUSRAM (rwx): ORIGIN = PMUSRAM_BASE, LENGTH = PMUSRAM_RSIZE
- }
- SECTIONS
- {
- . = SRAM_BASE;
- ASSERT(. == ALIGN(PAGE_SIZE),
- "SRAM_BASE address is not aligned on a page boundary.")
- .text_sram : ALIGN(PAGE_SIZE) {
- __bl32_sram_text_start = .;
- *(.sram.text)
- *(.sram.rodata)
- __bl32_sram_text_real_end = .;
- . = ALIGN(PAGE_SIZE);
- __bl32_sram_text_end = .;
- } >SRAM
- ASSERT((__bl32_sram_text_real_end - __bl32_sram_text_start) <=
- SRAM_TEXT_LIMIT, ".text_sram has exceeded its limit")
- .data_sram : ALIGN(PAGE_SIZE) {
- __bl32_sram_data_start = .;
- *(.sram.data)
- __bl32_sram_data_real_end = .;
- . = ALIGN(PAGE_SIZE);
- __bl32_sram_data_end = .;
- } >SRAM
- ASSERT((__bl32_sram_data_real_end - __bl32_sram_data_start) <=
- SRAM_DATA_LIMIT, ".data_sram has exceeded its limit")
- .stack_sram : ALIGN(PAGE_SIZE) {
- __bl32_sram_stack_start = .;
- . += PAGE_SIZE;
- __bl32_sram_stack_end = .;
- } >SRAM
- . = PMUSRAM_BASE;
- /*
- * pmu_cpuson_entrypoint request address
- * align 64K when resume, so put it in the
- * start of pmusram
- */
- .pmusram : {
- ASSERT(. == ALIGN(64 * 1024),
- ".pmusram.entry request 64K aligned.");
- *(.pmusram.entry)
- __bl32_pmusram_text_start = .;
- *(.pmusram.text)
- *(.pmusram.rodata)
- __bl32_pmusram_text_end = .;
- __bl32_pmusram_data_start = .;
- *(.pmusram.data)
- __bl32_pmusram_data_end = .;
- } >PMUSRAM
- }
- #endif /* ROCKCHIP_PLAT_LD_S */
|