1d6aed566Sopenharmony_ci/* 2d6aed566Sopenharmony_ci * Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved. 3d6aed566Sopenharmony_ci * Copyright (c) 2020-2022 Huawei Device Co., Ltd. All rights reserved. 4d6aed566Sopenharmony_ci * 5d6aed566Sopenharmony_ci * Redistribution and use in source and binary forms, with or without modification, 6d6aed566Sopenharmony_ci * are permitted provided that the following conditions are met: 7d6aed566Sopenharmony_ci * 8d6aed566Sopenharmony_ci * 1. Redistributions of source code must retain the above copyright notice, this list of 9d6aed566Sopenharmony_ci * conditions and the following disclaimer. 10d6aed566Sopenharmony_ci * 11d6aed566Sopenharmony_ci * 2. Redistributions in binary form must reproduce the above copyright notice, this list 12d6aed566Sopenharmony_ci * of conditions and the following disclaimer in the documentation and/or other materials 13d6aed566Sopenharmony_ci * provided with the distribution. 14d6aed566Sopenharmony_ci * 15d6aed566Sopenharmony_ci * 3. Neither the name of the copyright holder nor the names of its contributors may be used 16d6aed566Sopenharmony_ci * to endorse or promote products derived from this software without specific prior written 17d6aed566Sopenharmony_ci * permission. 18d6aed566Sopenharmony_ci * 19d6aed566Sopenharmony_ci * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 20d6aed566Sopenharmony_ci * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 21d6aed566Sopenharmony_ci * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22d6aed566Sopenharmony_ci * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR 23d6aed566Sopenharmony_ci * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 24d6aed566Sopenharmony_ci * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 25d6aed566Sopenharmony_ci * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 26d6aed566Sopenharmony_ci * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 27d6aed566Sopenharmony_ci * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 28d6aed566Sopenharmony_ci * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 29d6aed566Sopenharmony_ci * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 30d6aed566Sopenharmony_ci */ 31d6aed566Sopenharmony_ci 32d6aed566Sopenharmony_ciOUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm") 33d6aed566Sopenharmony_ciOUTPUT_ARCH(arm) 34d6aed566Sopenharmony_ciENTRY(Vector_Table) 35d6aed566Sopenharmony_ci 36d6aed566Sopenharmony_ciSVC_IRQ_STACK_SIZE = 4K; 37d6aed566Sopenharmony_ciFLASH_START = 0x00000000; 38d6aed566Sopenharmony_ciFLASH_SIZE = 3M; 39d6aed566Sopenharmony_ciPS_RAM_START = 0x21000000; 40d6aed566Sopenharmony_ciPS_RAM_SIZE = 16M; 41d6aed566Sopenharmony_ci 42d6aed566Sopenharmony_ciMEMORY 43d6aed566Sopenharmony_ci{ 44d6aed566Sopenharmony_ci flash(rx) : ORIGIN = FLASH_START, LENGTH = FLASH_SIZE 45d6aed566Sopenharmony_ci ram(rwx) : ORIGIN = PS_RAM_START, LENGTH = PS_RAM_SIZE 46d6aed566Sopenharmony_ci} 47d6aed566Sopenharmony_ci 48d6aed566Sopenharmony_ciSECTIONS 49d6aed566Sopenharmony_ci{ 50d6aed566Sopenharmony_ci .vector : { 51d6aed566Sopenharmony_ci KEEP (*(SORT_NONE(.Vector_Table))) 52d6aed566Sopenharmony_ci } > flash 53d6aed566Sopenharmony_ci 54d6aed566Sopenharmony_ci .got : { 55d6aed566Sopenharmony_ci *(.got.plt) 56d6aed566Sopenharmony_ci *(.igot.plt) 57d6aed566Sopenharmony_ci *(.got) 58d6aed566Sopenharmony_ci *(.igot) 59d6aed566Sopenharmony_ci } > flash 60d6aed566Sopenharmony_ci 61d6aed566Sopenharmony_ci .text : { 62d6aed566Sopenharmony_ci . = ALIGN(0x4); 63d6aed566Sopenharmony_ci __text_start = .; 64d6aed566Sopenharmony_ci _stext = .; 65d6aed566Sopenharmony_ci *(.text.*) 66d6aed566Sopenharmony_ci . = ALIGN(0x4); 67d6aed566Sopenharmony_ci _etext = .; 68d6aed566Sopenharmony_ci *(.rodata .rodata.* .gnu.linkonce.r.*) 69d6aed566Sopenharmony_ci *(.rodata1) 70d6aed566Sopenharmony_ci } > ram 71d6aed566Sopenharmony_ci 72d6aed566Sopenharmony_ci .data : { 73d6aed566Sopenharmony_ci __data_start = . ; 74d6aed566Sopenharmony_ci *(.data .data.* .gnu.linkonce.d.*) 75d6aed566Sopenharmony_ci } > ram 76d6aed566Sopenharmony_ci 77d6aed566Sopenharmony_ci .bss : ALIGN(0x4) { 78d6aed566Sopenharmony_ci __bss_start = .; 79d6aed566Sopenharmony_ci *(.dynbss) 80d6aed566Sopenharmony_ci *(.bss .bss.* .gnu.linkonce.b.*) 81d6aed566Sopenharmony_ci *(COMMON) 82d6aed566Sopenharmony_ci . = ALIGN(0x4); 83d6aed566Sopenharmony_ci __bss_end = .; 84d6aed566Sopenharmony_ci } > ram 85d6aed566Sopenharmony_ci 86d6aed566Sopenharmony_ci _sstack = .; 87d6aed566Sopenharmony_ci .stack : ALIGN(0x8) { 88d6aed566Sopenharmony_ci _stack = .; 89d6aed566Sopenharmony_ci __irq_stack_bootom = .; 90d6aed566Sopenharmony_ci . += SVC_IRQ_STACK_SIZE; 91d6aed566Sopenharmony_ci __irq_stack_top = .; 92d6aed566Sopenharmony_ci _estack = .; 93d6aed566Sopenharmony_ci } > ram 94d6aed566Sopenharmony_ci 95d6aed566Sopenharmony_ci .heap (NOLOAD): ALIGN(0x40) { 96d6aed566Sopenharmony_ci __heap_start = .; 97d6aed566Sopenharmony_ci } > ram 98d6aed566Sopenharmony_ci 99d6aed566Sopenharmony_ci __heap_size = PS_RAM_SIZE - (__heap_start - __text_start); 100d6aed566Sopenharmony_ci end = .; 101d6aed566Sopenharmony_ci /DISCARD/ : { *(.note.GNU-stack) *(.gnu_debuglink) *(.gnu.lto_*) } 102d6aed566Sopenharmony_ci} 103