2021-12-22 22:18:43 +08:00
/*
2024-04-26 16:37:32 +04:00
* SPDX-FileCopyrightText: 2021-2024 Espressif Systems (Shanghai) CO LTD
2021-12-22 22:18:43 +08:00
*
* SPDX-License-Identifier: Apache-2.0
*/
2016-08-17 23:08:22 +08:00
/*
Linker file used to link the bootloader.
*/
2017-06-16 16:30:21 +10:00
/* Simplified memory map for the bootloader
The main purpose is to make sure the bootloader can load into main memory
without overwriting itself.
*/
2018-04-19 09:42:26 +05:00
2016-08-17 23:08:22 +08:00
MEMORY
{
2018-04-19 09:42:26 +05:00
/* IRAM POOL1, used for APP CPU cache. Bootloader runs from here during the final stage of loading the app because APP CPU is still held in reset, the main app enables APP CPU cache */
iram_loader_seg (RWX) : org = 0x40078000, len = 0x8000 /* 32KB, APP CPU cache */
2018-07-04 12:33:11 +08:00
/* 63kB, IRAM. We skip the first 1k to prevent the entry point being
placed into the same range as exception vectors in the app.
This leads to idf_monitor decoding ROM bootloader "entry 0x40080xxx"
message as one of the exception vectors, which looks scary to users.
*/
iram_seg (RWX) : org = 0x40080400, len = 0xfc00
2017-06-16 16:30:21 +10:00
/* 64k at the end of DRAM, after ROM bootloader stack */
2022-11-24 14:05:40 +08:00
dram_seg (RW) : org = 0x3FFF0000, len = 0x6000
2016-08-17 23:08:22 +08:00
}
/* Default entry point: */
ENTRY(call_start_cpu0);
SECTIONS
{
2018-04-19 09:42:26 +05:00
.iram_loader.text :
{
. = ALIGN (16);
2018-08-24 17:56:38 +05:30
_loader_text_start = ABSOLUTE(.);
2018-04-19 09:42:26 +05:00
*(.stub .gnu.warning .gnu.linkonce.literal.* .gnu.linkonce.t.*.literal .gnu.linkonce.t.*)
*(.iram1 .iram1.*) /* catch stray IRAM_ATTR */
*liblog.a:(.literal .text .literal.* .text.*)
2022-11-23 15:00:11 +03:00
/* we use either libgcc or compiler-rt, so put similar entries for them here */
2018-04-19 09:42:26 +05:00
*libgcc.a:(.literal .text .literal.* .text.*)
2022-11-23 15:00:11 +03:00
*libclang_rt.builtins.a:(.literal .text .literal.* .text.*)
2020-07-08 10:42:50 +02:00
*libbootloader_support.a:bootloader_clock_loader.*(.literal .text .literal.* .text.*)
*libbootloader_support.a:bootloader_common_loader.*(.literal .text .literal.* .text.*)
2018-08-16 15:01:43 +10:00
*libbootloader_support.a:bootloader_flash.*(.literal .text .literal.* .text.*)
*libbootloader_support.a:bootloader_random.*(.literal .text .literal.* .text.*)
2020-05-21 17:09:27 +10:00
*libbootloader_support.a:bootloader_random*.*(.literal.bootloader_random_disable .text.bootloader_random_disable)
2020-12-04 00:12:54 +08:00
*libesp_common.a:fpga_overrides.*(.literal.bootloader_fill_random .text.bootloader_fill_random)
2021-12-22 22:18:43 +08:00
*libbootloader_support.a:bootloader_efuse.*(.literal .text .literal.* .text.*)
2018-08-16 15:01:43 +10:00
*libbootloader_support.a:bootloader_utility.*(.literal .text .literal.* .text.*)
*libbootloader_support.a:bootloader_sha.*(.literal .text .literal.* .text.*)
2020-04-30 15:30:15 +02:00
*libbootloader_support.a:bootloader_console_loader.*(.literal .text .literal.* .text.*)
2020-07-08 10:42:50 +02:00
*libbootloader_support.a:bootloader_panic.*(.literal .text .literal.* .text.*)
2021-08-27 09:37:52 +05:30
*libbootloader_support.a:bootloader_soc.*(.literal .text .literal.* .text.*)
2018-08-16 15:01:43 +10:00
*libbootloader_support.a:esp_image_format.*(.literal .text .literal.* .text.*)
*libbootloader_support.a:flash_encrypt.*(.literal .text .literal.* .text.*)
2021-06-17 07:21:36 +08:00
*libbootloader_support.a:flash_encryption_secure_features.*(.literal .text .literal.* .text.*)
2018-08-16 15:01:43 +10:00
*libbootloader_support.a:flash_partitions.*(.literal .text .literal.* .text.*)
*libbootloader_support.a:secure_boot.*(.literal .text .literal.* .text.*)
2021-06-17 07:21:36 +08:00
*libbootloader_support.a:secure_boot_secure_features.*(.literal .text .literal.* .text.*)
2021-03-05 22:22:29 +08:00
*libbootloader_support.a:secure_boot_signatures_bootloader.*(.literal .text .literal.* .text.*)
2018-08-16 15:01:43 +10:00
*libmicro-ecc.a:*.*(.literal .text .literal.* .text.*)
*libspi_flash.a:*.*(.literal .text .literal.* .text.*)
2020-09-03 17:49:24 +02:00
*libhal.a:wdt_hal_iram.*(.literal .text .literal.* .text.*)
2022-02-11 15:30:54 +08:00
*libhal.a:mmu_hal.*(.literal .text .literal.* .text.*)
2021-12-22 22:18:43 +08:00
*libhal.a:efuse_hal.*(.literal .text .literal.* .text.*)
2020-09-25 15:23:52 +08:00
*libesp_hw_support.a:rtc_clk.*(.literal .text .literal.* .text.*)
*libesp_hw_support.a:rtc_time.*(.literal .text .literal.* .text.*)
2018-11-19 11:36:19 +08:00
*libefuse.a:*.*(.literal .text .literal.* .text.*)
2021-09-28 19:35:36 +08:00
*libesp_rom.a:*.*(.literal .text .literal.* .text.*)
2018-04-19 09:42:26 +05:00
*(.fini.literal)
*(.fini)
*(.gnu.version)
2018-08-24 17:56:38 +05:30
_loader_text_end = ABSOLUTE(.);
2018-04-19 09:42:26 +05:00
} > iram_loader_seg
2018-07-13 15:21:07 +10:00
2018-04-19 09:42:26 +05:00
.iram.text :
2016-08-17 23:08:22 +08:00
{
. = ALIGN (16);
*(.entry.text)
*(.init.literal)
*(.init)
} > iram_seg
/* Shared RAM */
.dram0.bss (NOLOAD) :
{
. = ALIGN (8);
2020-02-16 16:51:42 +11:00
_dram_start = ABSOLUTE(.);
2016-08-17 23:08:22 +08:00
_bss_start = ABSOLUTE(.);
*(.dynsbss)
*(.sbss)
*(.sbss.*)
*(.gnu.linkonce.sb.*)
*(.scommon)
*(.sbss2)
*(.sbss2.*)
*(.gnu.linkonce.sb2.*)
*(.dynbss)
2017-07-17 14:37:06 +10:00
*(.bss)
2016-08-17 23:08:22 +08:00
*(.bss.*)
*(.gnu.linkonce.b.*)
*(COMMON)
. = ALIGN (8);
_bss_end = ABSOLUTE(.);
} >dram_seg
2022-12-14 01:16:56 +08:00
.dram0.bootdesc : ALIGN(0x10)
2016-08-17 23:08:22 +08:00
{
_data_start = ABSOLUTE(.);
2022-12-14 01:16:56 +08:00
*(.data_bootloader_desc .data_bootloader_desc.*) /* Should be the first. Bootloader version info. DO NOT PUT ANYTHING BEFORE IT! */
} > dram_seg
.dram0.data : ALIGN(0x10)
{
2024-04-26 16:37:32 +04:00
*(.dram1 .dram1.*) /* catch stray DRAM_ATTR */
2017-07-17 14:37:06 +10:00
*(.data)
*(.data.*)
*(.gnu.linkonce.d.*)
*(.data1)
*(.sdata)
*(.sdata.*)
*(.gnu.linkonce.s.*)
*(.gnu.linkonce.s2.*)
*(.jcr)
2016-08-17 23:08:22 +08:00
_data_end = ABSOLUTE(.);
} >dram_seg
.dram0.rodata :
{
_rodata_start = ABSOLUTE(.);
*(.rodata)
*(.rodata.*)
*(.gnu.linkonce.r.*)
*(.rodata1)
2022-06-17 13:54:09 +04:00
*(.sdata2 .sdata2.*)
2016-08-17 23:08:22 +08:00
__XT_EXCEPTION_TABLE_ = ABSOLUTE(.);
*(.xt_except_table)
*(.gcc_except_table)
*(.gnu.linkonce.e.*)
*(.gnu.version_r)
2024-04-26 16:37:32 +04:00
*(.eh_frame_hdr)
2016-08-17 23:08:22 +08:00
*(.eh_frame)
. = (. + 3) & ~ 3;
/* C++ constructor and destructor tables, properly ordered: */
__init_array_start = ABSOLUTE(.);
2018-08-16 15:01:43 +10:00
KEEP (*crtbegin.*(.ctors))
KEEP (*(EXCLUDE_FILE (*crtend.*) .ctors))
2016-08-17 23:08:22 +08:00
KEEP (*(SORT(.ctors.*)))
KEEP (*(.ctors))
__init_array_end = ABSOLUTE(.);
2018-08-16 15:01:43 +10:00
KEEP (*crtbegin.*(.dtors))
KEEP (*(EXCLUDE_FILE (*crtend.*) .dtors))
2016-08-17 23:08:22 +08:00
KEEP (*(SORT(.dtors.*)))
KEEP (*(.dtors))
/* C++ exception handlers table: */
__XT_EXCEPTION_DESCS_ = ABSOLUTE(.);
*(.xt_except_desc)
*(.gnu.linkonce.h.*)
__XT_EXCEPTION_DESCS_END__ = ABSOLUTE(.);
*(.xt_except_desc_end)
*(.dynamic)
*(.gnu.version_d)
_rodata_end = ABSOLUTE(.);
/* Literals are also RO data. */
_lit4_start = ABSOLUTE(.);
*(*.lit4)
*(.lit4.*)
*(.gnu.linkonce.lit4.*)
_lit4_end = ABSOLUTE(.);
. = ALIGN(4);
2020-02-16 16:51:42 +11:00
_dram_end = ABSOLUTE(.);
2016-08-17 23:08:22 +08:00
} >dram_seg
2017-06-16 16:30:21 +10:00
.iram.text :
2016-08-17 23:08:22 +08:00
{
_stext = .;
_text_start = ABSOLUTE(.);
*(.literal .text .literal.* .text.* .stub .gnu.warning .gnu.linkonce.literal.* .gnu.linkonce.t.*.literal .gnu.linkonce.t.*)
2018-04-19 09:42:26 +05:00
*(.iram .iram.*) /* catch stray IRAM_ATTR */
2016-08-17 23:08:22 +08:00
*(.fini.literal)
*(.fini)
*(.gnu.version)
2021-03-29 12:18:25 +08:00
/** CPU will try to prefetch up to 16 bytes of
* of instructions. This means that any configuration (e.g. MMU, PMS) must allow
* safe access to up to 16 bytes after the last real instruction, add
* dummy bytes to ensure this
*/
. += 16;
2016-08-17 23:08:22 +08:00
_text_end = ABSOLUTE(.);
_etext = .;
2017-06-16 16:30:21 +10:00
} > iram_seg
2016-08-17 23:08:22 +08:00
2022-02-24 15:24:11 +08:00
/** This section will be used by the debugger and disassembler to get more information
* about raw data present in the code.
* Indeed, it may be required to add some padding at some points in the code
* in order to align a branch/jump destination on a particular bound.
* Padding these instructions will generate null bytes that shall be
* interpreted as data, and not code by the debugger or disassembler.
* This section will only be present in the ELF file, not in the final binary
* For more details, check GCC-212
*/
.xt.prop 0 :
{
2024-04-26 16:37:32 +04:00
KEEP (*(.xt.prop .xt.prop.* .gnu.linkonce.prop.*))
2022-02-24 15:24:11 +08:00
}
.xt.lit 0 :
{
2024-04-26 16:37:32 +04:00
KEEP (*(.xt.lit .xt.lit.* .gnu.linkonce.p.*))
2022-02-24 15:24:11 +08:00
}
2024-04-26 16:37:32 +04:00
.xtensa.info 0: { *(.xtensa.info) }
/* DWARF 1 */
.debug 0 : { *(.debug) }
.line 0 : { *(.line) }
/* GNU DWARF 1 extensions */
.debug_srcinfo 0 : { *(.debug_srcinfo) }
.debug_sfnames 0 : { *(.debug_sfnames) }
/* DWARF 1.1 and DWARF 2 */
.debug_aranges 0 : { *(.debug_aranges) }
.debug_pubnames 0 : { *(.debug_pubnames) }
/* DWARF 2 */
.debug_info 0 : { *(.debug_info .gnu.linkonce.wi.*) }
.debug_abbrev 0 : { *(.debug_abbrev) }
.debug_line 0 : { *(.debug_line) }
.debug_frame 0 : { *(.debug_frame) }
.debug_str 0 : { *(.debug_str) }
.debug_loc 0 : { *(.debug_loc) }
.debug_macinfo 0 : { *(.debug_macinfo) }
.debug_pubtypes 0 : { *(.debug_pubtypes) }
/* DWARF 3 */
.debug_ranges 0 : { *(.debug_ranges) }
/* SGI/MIPS DWARF 2 extensions */
.debug_weaknames 0 : { *(.debug_weaknames) }
.debug_funcnames 0 : { *(.debug_funcnames) }
.debug_typenames 0 : { *(.debug_typenames) }
.debug_varnames 0 : { *(.debug_varnames) }
/* GNU DWARF 2 extensions */
.debug_gnu_pubnames 0 : { *(.debug_gnu_pubnames) }
.debug_gnu_pubtypes 0 : { *(.debug_gnu_pubtypes) }
/* DWARF 4 */
.debug_types 0 : { *(.debug_types) }
/* DWARF 5 */
.debug_addr 0 : { *(.debug_addr) }
.debug_line_str 0 : { *(.debug_line_str) }
.debug_loclists 0 : { *(.debug_loclists) }
.debug_macro 0 : { *(.debug_macro) }
.debug_names 0 : { *(.debug_names) }
.debug_rnglists 0 : { *(.debug_rnglists) }
.debug_str_offsets 0 : { *(.debug_str_offsets) }
.comment 0 : { *(.comment) }
.note.GNU-stack 0: { *(.note.GNU-stack) }
2016-08-17 23:08:22 +08:00
}