When converting ELF to a flashable image, the esptool can only process up to 16 ELF sections. Zephyr has been happily grouping similar objects into linker sections which can easily go over esptool's limit. This patch consolidates the kernel, net, log, and shell objects into their own sections. Also remove the app_noinit section as no one is emitting anything into that section, and it's not being used by other arch/SoC/boards in Zephyr. Fixes #20980 Signed-off-by: Daniel Leung <daniel.leung@intel.com>
326 lines
8 KiB
Text
326 lines
8 KiB
Text
/*
|
|
* Copyright (c) 2016 Cadence Design Systems, Inc.
|
|
* Copyright (c) 2017 Intel Corporation
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
/**
|
|
* @file
|
|
* @brief Linker command/script file
|
|
*
|
|
* Linker script for the Xtensa platform.
|
|
*/
|
|
|
|
#include <devicetree.h>
|
|
#include <autoconf.h>
|
|
#include <linker/sections.h>
|
|
#include <linker/linker-defs.h>
|
|
#include <linker/linker-tool.h>
|
|
|
|
#define RAMABLE_REGION dram0_0_seg :dram0_0_phdr
|
|
#define ROMABLE_REGION iram0_0_seg :iram0_0_phdr
|
|
|
|
PROVIDE ( __stack = 0x3ffe3f20 );
|
|
|
|
PROVIDE ( esp32_rom_uart_tx_one_char = 0x40009200 );
|
|
PROVIDE ( esp32_rom_uart_rx_one_char = 0x400092d0 );
|
|
PROVIDE ( esp32_rom_uart_attach = 0x40008fd0 );
|
|
PROVIDE ( esp32_rom_uart_tx_wait_idle = 0x40009278 );
|
|
PROVIDE ( esp32_rom_intr_matrix_set = 0x4000681c );
|
|
PROVIDE ( esp32_rom_gpio_matrix_in = 0x40009edc );
|
|
PROVIDE ( esp32_rom_gpio_matrix_out = 0x40009f0c );
|
|
PROVIDE ( esp32_rom_Cache_Flush = 0x40009a14 );
|
|
PROVIDE ( esp32_rom_Cache_Read_Enable = 0x40009a84 );
|
|
PROVIDE ( esp32_rom_ets_set_appcpu_boot_addr = 0x4000689c );
|
|
PROVIDE ( esp32_rom_i2c_readReg = 0x40004148 );
|
|
PROVIDE ( esp32_rom_i2c_writeReg = 0x400041a4 );
|
|
|
|
MEMORY
|
|
{
|
|
iram0_0_seg(RX): org = 0x40080000, len = 0x20000
|
|
iram0_2_seg(RX): org = 0x400D0018, len = 0x330000
|
|
dram0_0_seg(RW): org = 0x3FFB0000, len = 0x50000
|
|
drom0_0_seg(R): org = 0x3F400010, len = 0x800000
|
|
rtc_iram_seg(RWX): org = 0x400C0000, len = 0x2000
|
|
rtc_slow_seg(RW): org = 0x50000000, len = 0x1000
|
|
#ifdef CONFIG_GEN_ISR_TABLES
|
|
IDT_LIST(RW): org = 0x3ebfe010, len = 0x2000
|
|
#endif
|
|
}
|
|
|
|
PHDRS
|
|
{
|
|
iram0_0_phdr PT_LOAD;
|
|
dram0_0_phdr PT_LOAD;
|
|
}
|
|
|
|
/* Default entry point: */
|
|
PROVIDE ( _ResetVector = 0x40000400 );
|
|
ENTRY(CONFIG_KERNEL_ENTRY)
|
|
|
|
_rom_store_table = 0;
|
|
|
|
PROVIDE(_memmap_vecbase_reset = 0x40000450);
|
|
PROVIDE(_memmap_reset_vector = 0x40000400);
|
|
|
|
SECTIONS
|
|
{
|
|
|
|
#include <linker/rel-sections.ld>
|
|
|
|
/* RTC fast memory holds RTC wake stub code,
|
|
including from any source file named rtc_wake_stub*.c
|
|
*/
|
|
.rtc.text :
|
|
{
|
|
. = ALIGN(4);
|
|
*(.rtc.literal .rtc.text)
|
|
*rtc_wake_stub*.o(.literal .text .literal.* .text.*)
|
|
} >rtc_iram_seg
|
|
|
|
/* RTC slow memory holds RTC wake stub
|
|
data/rodata, including from any source file
|
|
named rtc_wake_stub*.c
|
|
*/
|
|
.rtc.data :
|
|
{
|
|
_rtc_data_start = ABSOLUTE(.);
|
|
*(.rtc.data)
|
|
*(.rtc.rodata)
|
|
*rtc_wake_stub*.o(.data .rodata .data.* .rodata.* .bss .bss.*)
|
|
_rtc_data_end = ABSOLUTE(.);
|
|
} > rtc_slow_seg
|
|
|
|
/* RTC bss, from any source file named rtc_wake_stub*.c */
|
|
.rtc.bss (NOLOAD) :
|
|
{
|
|
_rtc_bss_start = ABSOLUTE(.);
|
|
*rtc_wake_stub*.o(.bss .bss.*)
|
|
*rtc_wake_stub*.o(COMMON)
|
|
_rtc_bss_end = ABSOLUTE(.);
|
|
} > rtc_slow_seg
|
|
|
|
/* Send .iram0 code to iram */
|
|
.iram0.vectors : ALIGN(4)
|
|
{
|
|
/* Vectors go to IRAM */
|
|
_init_start = ABSOLUTE(.);
|
|
/* Vectors according to builds/RF-2015.2-win32/esp108_v1_2_s5_512int_2/config.html */
|
|
. = 0x0;
|
|
KEEP(*(.WindowVectors.text));
|
|
. = 0x180;
|
|
KEEP(*(.Level2InterruptVector.text));
|
|
. = 0x1c0;
|
|
KEEP(*(.Level3InterruptVector.text));
|
|
. = 0x200;
|
|
KEEP(*(.Level4InterruptVector.text));
|
|
. = 0x240;
|
|
KEEP(*(.Level5InterruptVector.text));
|
|
. = 0x280;
|
|
KEEP(*(.DebugExceptionVector.text));
|
|
. = 0x2c0;
|
|
KEEP(*(.NMIExceptionVector.text));
|
|
. = 0x300;
|
|
KEEP(*(.KernelExceptionVector.text));
|
|
. = 0x340;
|
|
KEEP(*(.UserExceptionVector.text));
|
|
. = 0x3C0;
|
|
KEEP(*(.DoubleExceptionVector.text));
|
|
. = 0x400;
|
|
*(.*Vector.literal)
|
|
|
|
*(.UserEnter.literal);
|
|
*(.UserEnter.text);
|
|
. = ALIGN (16);
|
|
*(.entry.text)
|
|
*(.init.literal)
|
|
*(.init)
|
|
_init_end = ABSOLUTE(.);
|
|
|
|
/* This goes here, not at top of linker script, so addr2line finds it last,
|
|
and uses it in preference to the first symbol in IRAM */
|
|
_iram_start = ABSOLUTE(0);
|
|
} GROUP_LINK_IN(ROMABLE_REGION)
|
|
|
|
SECTION_DATA_PROLOGUE(k_objects,, ALIGN(4))
|
|
{
|
|
Z_LINK_ITERABLE(k_timer);
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(k_mem_slab);
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(k_mem_pool);
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(k_heap);
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(k_mutex);
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(k_stack);
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(k_msgq);
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(k_mbox);
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(k_pipe);
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(k_sem);
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(k_queue);
|
|
} GROUP_DATA_LINK_IN(RAMABLE_REGION, ROMABLE_REGION)
|
|
|
|
SECTION_DATA_PROLOGUE(net,, ALIGN(4))
|
|
{
|
|
_net_buf_pool_list = .;
|
|
KEEP(*(SORT_BY_NAME("._net_buf_pool.static.*")))
|
|
|
|
#if defined(CONFIG_NETWORKING)
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(net_if);
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(net_if_dev);
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(net_l2);
|
|
#endif
|
|
|
|
} GROUP_DATA_LINK_IN(RAMABLE_REGION, ROMABLE_REGION)
|
|
|
|
Z_ITERABLE_SECTION_RAM(_static_thread_data, 4)
|
|
|
|
#pragma push_macro("Z_ITERABLE_SECTION_RAM")
|
|
#undef Z_ITERABLE_SECTION_RAM
|
|
#define Z_ITERABLE_SECTION_RAM(x, y)
|
|
#include <linker/common-ram.ld>
|
|
#pragma pop_macro("Z_ITERABLE_SECTION_RAM")
|
|
|
|
SECTION_DATA_PROLOGUE(log_static_section,,)
|
|
{
|
|
__log_const_start = .;
|
|
KEEP(*(SORT(.log_const_*)));
|
|
__log_const_end = .;
|
|
|
|
__log_backends_start = .;
|
|
KEEP(*("._log_backend.*"));
|
|
__log_backends_end = .;
|
|
} GROUP_LINK_IN(ROMABLE_REGION)
|
|
|
|
SECTION_DATA_PROLOGUE(shell_static_section,,)
|
|
{
|
|
. = ALIGN(4);
|
|
Z_LINK_ITERABLE(shell);
|
|
. = ALIGN(4);
|
|
|
|
__shell_root_cmds_start = .;
|
|
KEEP(*(SORT(.shell_root_cmd_*)));
|
|
__shell_root_cmds_end = .;
|
|
} GROUP_LINK_IN(ROMABLE_REGION)
|
|
|
|
#include <linker/common-rom.ld>
|
|
|
|
SECTION_PROLOGUE(_TEXT_SECTION_NAME, , ALIGN(4))
|
|
{
|
|
/* Code marked as running out of IRAM */
|
|
_iram_text_start = ABSOLUTE(.);
|
|
*(.iram1 .iram1.*)
|
|
*(.iram0.literal .iram.literal .iram.text.literal .iram0.text .iram.text)
|
|
*(.literal .text .literal.* .text.*)
|
|
_iram_text_end = ABSOLUTE(.);
|
|
} GROUP_LINK_IN(ROMABLE_REGION)
|
|
|
|
.dram0.data :
|
|
{
|
|
_data_start = ABSOLUTE(.);
|
|
*(.data)
|
|
*(.data.*)
|
|
*(.gnu.linkonce.d.*)
|
|
*(.data1)
|
|
*(.sdata)
|
|
*(.sdata.*)
|
|
*(.gnu.linkonce.s.*)
|
|
*(.sdata2)
|
|
*(.sdata2.*)
|
|
*(.gnu.linkonce.s2.*)
|
|
KEEP(*(.jcr))
|
|
*(.dram1 .dram1.*)
|
|
_data_end = ABSOLUTE(.);
|
|
. = ALIGN(4);
|
|
} GROUP_LINK_IN(RAMABLE_REGION)
|
|
|
|
SECTION_PROLOGUE(_RODATA_SECTION_NAME,,ALIGN(4))
|
|
{
|
|
_rodata_start = ABSOLUTE(.);
|
|
*(.rodata)
|
|
*(.rodata.*)
|
|
*(.gnu.linkonce.r.*)
|
|
*(.rodata1)
|
|
__XT_EXCEPTION_TABLE__ = ABSOLUTE(.);
|
|
KEEP (*(.xt_except_table))
|
|
KEEP (*(.gcc_except_table .gcc_except_table.*))
|
|
*(.gnu.linkonce.e.*)
|
|
*(.gnu.version_r)
|
|
KEEP (*(.eh_frame))
|
|
/* C++ constructor and destructor tables, properly ordered: */
|
|
KEEP (*crtbegin.o(.ctors))
|
|
KEEP (*(EXCLUDE_FILE (*crtend.o) .ctors))
|
|
KEEP (*(SORT(.ctors.*)))
|
|
KEEP (*(.ctors))
|
|
KEEP (*crtbegin.o(.dtors))
|
|
KEEP (*(EXCLUDE_FILE (*crtend.o) .dtors))
|
|
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)
|
|
. = ALIGN(4); /* this table MUST be 4-byte aligned */
|
|
_rodata_end = ABSOLUTE(.);
|
|
} GROUP_LINK_IN(RAMABLE_REGION)
|
|
|
|
|
|
/* Shared RAM */
|
|
SECTION_DATA_PROLOGUE(_BSS_SECTION_NAME,(NOLOAD),)
|
|
{
|
|
. = ALIGN (8);
|
|
_bss_start = ABSOLUTE(.);
|
|
*(.dynsbss)
|
|
*(.sbss)
|
|
*(.sbss.*)
|
|
*(.gnu.linkonce.sb.*)
|
|
*(.scommon)
|
|
*(.sbss2)
|
|
*(.sbss2.*)
|
|
*(.gnu.linkonce.sb2.*)
|
|
*(.dynbss)
|
|
*(.bss)
|
|
*(.bss.*)
|
|
*(.share.mem)
|
|
*(.gnu.linkonce.b.*)
|
|
*(COMMON)
|
|
. = ALIGN (8);
|
|
_bss_end = ABSOLUTE(.);
|
|
} GROUP_LINK_IN(RAMABLE_REGION)
|
|
|
|
|
|
SECTION_DATA_PROLOGUE(_NOINIT_SECTION_NAME, (NOLOAD),)
|
|
{
|
|
. = ALIGN (8);
|
|
*(.noinit)
|
|
*(".noinit.*")
|
|
. = ALIGN (8);
|
|
_heap_start = ABSOLUTE(.);
|
|
} GROUP_LINK_IN(RAMABLE_REGION)
|
|
|
|
#ifdef CONFIG_GEN_ISR_TABLES
|
|
#include <linker/intlist.ld>
|
|
#endif
|
|
|
|
#include <linker/debug-sections.ld>
|
|
|
|
SECTION_PROLOGUE(.xtensa.info, 0,)
|
|
{
|
|
*(.xtensa.info)
|
|
}
|
|
|
|
}
|