linker: move all linker headers to include/linker
Signed-off-by: Anas Nashif <anas.nashif@intel.com>
This commit is contained in:
parent
be366b7ba6
commit
397d29db42
151 changed files with 186 additions and 186 deletions
159
include/linker/linker-defs.h
Normal file
159
include/linker/linker-defs.h
Normal file
|
@ -0,0 +1,159 @@
|
|||
/*
|
||||
* Copyright (c) 2013-2014, Wind River Systems, Inc.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
/*
|
||||
* DESCRIPTION
|
||||
* Platform independent, commonly used macros and defines related to linker
|
||||
* script.
|
||||
*
|
||||
* This file may be included by:
|
||||
* - Linker script files: for linker section declarations
|
||||
* - C files: for external declaration of address or size of linker section
|
||||
* - Assembly files: for external declaration of address or size of linker
|
||||
* section
|
||||
*/
|
||||
|
||||
#ifndef _LINKERDEFS_H
|
||||
#define _LINKERDEFS_H
|
||||
|
||||
#include <toolchain.h>
|
||||
#include <linker/sections.h>
|
||||
|
||||
/* include platform dependent linker-defs */
|
||||
#ifdef CONFIG_X86
|
||||
/* Nothing yet to include */
|
||||
#elif defined(CONFIG_ARM)
|
||||
/* Nothing yet to include */
|
||||
#elif defined(CONFIG_ARC)
|
||||
/* Nothing yet to include */
|
||||
#elif defined(CONFIG_NIOS2)
|
||||
/* Nothing yet to include */
|
||||
#elif defined(CONFIG_RISCV32)
|
||||
/* Nothing yet to include */
|
||||
#elif defined(CONFIG_XTENSA)
|
||||
/* Nothing yet to include */
|
||||
#else
|
||||
#error Arch not supported.
|
||||
#endif
|
||||
|
||||
#ifdef _LINKER
|
||||
|
||||
|
||||
/*
|
||||
* Space for storing per device busy bitmap. Since we do not know beforehand
|
||||
* the number of devices, we go through the below mechanism to allocate the
|
||||
* required space.
|
||||
*/
|
||||
#ifdef CONFIG_DEVICE_POWER_MANAGEMENT
|
||||
#define DEVICE_COUNT \
|
||||
((__device_init_end - __device_init_start) / _DEVICE_STRUCT_SIZE)
|
||||
#define DEV_BUSY_SZ (((DEVICE_COUNT + 31) / 32) * 4)
|
||||
#define DEVICE_BUSY_BITFIELD() \
|
||||
FILL(0x00) ; \
|
||||
__device_busy_start = .; \
|
||||
. = . + DEV_BUSY_SZ; \
|
||||
__device_busy_end = .;
|
||||
#else
|
||||
#define DEVICE_BUSY_BITFIELD()
|
||||
#endif
|
||||
|
||||
/*
|
||||
* generate a symbol to mark the start of the device initialization objects for
|
||||
* the specified level, then link all of those objects (sorted by priority);
|
||||
* ensure the objects aren't discarded if there is no direct reference to them
|
||||
*/
|
||||
|
||||
#define DEVICE_INIT_LEVEL(level) \
|
||||
__device_##level##_start = .; \
|
||||
KEEP(*(SORT(.init_##level[0-9]))); \
|
||||
KEEP(*(SORT(.init_##level[1-9][0-9]))); \
|
||||
|
||||
/*
|
||||
* link in device initialization objects for all devices that are automatically
|
||||
* initialized by the kernel; the objects are sorted in the order they will be
|
||||
* initialized (i.e. ordered by level, sorted by priority within a level)
|
||||
*/
|
||||
|
||||
#define DEVICE_INIT_SECTIONS() \
|
||||
__device_init_start = .; \
|
||||
DEVICE_INIT_LEVEL(PRE_KERNEL_1) \
|
||||
DEVICE_INIT_LEVEL(PRE_KERNEL_2) \
|
||||
DEVICE_INIT_LEVEL(POST_KERNEL) \
|
||||
DEVICE_INIT_LEVEL(APPLICATION) \
|
||||
__device_init_end = .; \
|
||||
DEVICE_BUSY_BITFIELD() \
|
||||
|
||||
|
||||
/* define a section for undefined device initialization levels */
|
||||
#define DEVICE_INIT_UNDEFINED_SECTION() \
|
||||
KEEP(*(SORT(.init_[_A-Z0-9]*))) \
|
||||
|
||||
/*
|
||||
* link in shell initialization objects for all modules that use shell and
|
||||
* their shell commands are automatically initialized by the kernel.
|
||||
*/
|
||||
|
||||
#define SHELL_INIT_SECTIONS() \
|
||||
__shell_cmd_start = .; \
|
||||
KEEP(*(".shell_*")); \
|
||||
__shell_cmd_end = .;
|
||||
|
||||
|
||||
#ifdef CONFIG_X86 /* LINKER FILES: defines used by linker script */
|
||||
/* Should be moved to linker-common-defs.h */
|
||||
#if defined(CONFIG_XIP)
|
||||
#define ROMABLE_REGION ROM
|
||||
#else
|
||||
#define ROMABLE_REGION RAM
|
||||
#endif
|
||||
#endif
|
||||
|
||||
/*
|
||||
* If image is loaded via kexec Linux system call, then program
|
||||
* headers need to be page aligned.
|
||||
* This can be done by section page aligning.
|
||||
*/
|
||||
#ifdef CONFIG_BOOTLOADER_KEXEC
|
||||
#define KEXEC_PGALIGN_PAD(x) . = ALIGN(x);
|
||||
#else
|
||||
#define KEXEC_PGALIGN_PAD(x)
|
||||
#endif
|
||||
|
||||
#elif defined(_ASMLANGUAGE)
|
||||
|
||||
/* Assembly FILES: declaration defined by the linker script */
|
||||
GDATA(__bss_start)
|
||||
GDATA(__bss_num_words)
|
||||
#ifdef CONFIG_XIP
|
||||
GDATA(__data_rom_start)
|
||||
GDATA(__data_ram_start)
|
||||
GDATA(__data_num_words)
|
||||
#endif
|
||||
|
||||
#else /* ! _ASMLANGUAGE */
|
||||
|
||||
#include <zephyr/types.h>
|
||||
extern char __bss_start[];
|
||||
extern char __bss_end[];
|
||||
#ifdef CONFIG_XIP
|
||||
extern char __data_rom_start[];
|
||||
extern char __data_ram_start[];
|
||||
extern char __data_ram_end[];
|
||||
#endif
|
||||
|
||||
extern char _image_rom_start[];
|
||||
extern char _image_rom_end[];
|
||||
extern char _image_ram_start[];
|
||||
extern char _image_ram_end[];
|
||||
extern char _image_text_start[];
|
||||
extern char _image_text_end[];
|
||||
|
||||
/* end address of image. */
|
||||
extern char _end[];
|
||||
|
||||
#endif /* ! _ASMLANGUAGE */
|
||||
|
||||
#endif /* _LINKERDEFS_H */
|
110
include/linker/linker-tool-gcc.h
Normal file
110
include/linker/linker-tool-gcc.h
Normal file
|
@ -0,0 +1,110 @@
|
|||
/*
|
||||
* Copyright (c) 2013-2014, Wind River Systems, Inc.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
/**
|
||||
* @file
|
||||
* @brief GCC toolchain linker defs
|
||||
*
|
||||
* This header file defines the necessary macros used by the linker script for
|
||||
* use with the GCC linker.
|
||||
*/
|
||||
|
||||
#ifndef __LINKER_TOOL_GCC_H
|
||||
#define __LINKER_TOOL_GCC_H
|
||||
|
||||
#if defined(CONFIG_ARM)
|
||||
OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
|
||||
#elif defined(CONFIG_ARC)
|
||||
OUTPUT_FORMAT("elf32-littlearc", "elf32-bigarc", "elf32-littlearc")
|
||||
#elif defined(CONFIG_X86)
|
||||
#if defined(__IAMCU)
|
||||
OUTPUT_FORMAT("elf32-iamcu")
|
||||
OUTPUT_ARCH(iamcu:intel)
|
||||
#else
|
||||
OUTPUT_FORMAT("elf32-i386", "elf32-i386", "elf32-i386")
|
||||
OUTPUT_ARCH(i386)
|
||||
#endif
|
||||
#elif defined(CONFIG_NIOS2)
|
||||
OUTPUT_FORMAT("elf32-littlenios2", "elf32-bignios2", "elf32-littlenios2")
|
||||
#elif defined(CONFIG_RISCV32)
|
||||
OUTPUT_ARCH(riscv)
|
||||
OUTPUT_FORMAT("elf32-littleriscv")
|
||||
#elif defined(CONFIG_XTENSA)
|
||||
/* Not needed */
|
||||
#else
|
||||
#error Arch not supported.
|
||||
#endif
|
||||
|
||||
/*
|
||||
* The GROUP_START() and GROUP_END() macros are used to define a group
|
||||
* of sections located in one memory area, such as RAM, ROM, etc.
|
||||
* The <where> parameter is the name of the memory area.
|
||||
*/
|
||||
#define GROUP_START(where)
|
||||
#define GROUP_END(where)
|
||||
|
||||
/*
|
||||
* The GROUP_LINK_IN() macro is located at the end of the section
|
||||
* description and tells the linker that this section is located in
|
||||
* the memory area specified by <where> argument.
|
||||
*/
|
||||
#define GROUP_LINK_IN(where) > where
|
||||
|
||||
/*
|
||||
* As GROUP_LINK_IN(), but takes a second argument indicating the
|
||||
* memory region (e.g. "ROM") for the load address. Used for
|
||||
* initialized data sections that on XIP platforms must be copied at
|
||||
* startup.
|
||||
*
|
||||
* And, because output directives in GNU ld are "sticky", this must
|
||||
* also be used on the first section *after* such an initialized data
|
||||
* section, specifying the same memory region (e.g. "RAM") for both
|
||||
* vregion and lregion.
|
||||
*/
|
||||
#ifdef CONFIG_XIP
|
||||
#define GROUP_DATA_LINK_IN(vregion, lregion) > vregion AT> lregion
|
||||
#else
|
||||
#define GROUP_DATA_LINK_IN(vregion, lregion) > vregion
|
||||
#endif
|
||||
|
||||
/*
|
||||
* The GROUP_FOLLOWS_AT() macro is located at the end of the section
|
||||
* and indicates that the section does not specify an address at which
|
||||
* it is to be loaded, but that it follows a section which did specify
|
||||
* such an address
|
||||
*/
|
||||
#define GROUP_FOLLOWS_AT(where) AT > where
|
||||
|
||||
/*
|
||||
* The SECTION_PROLOGUE() macro is used to define the beginning of a section.
|
||||
* The <name> parameter is the name of the section, and the <option> parameter
|
||||
* is to include any special options such as (NOLOAD). Page alignment has its
|
||||
* own parameter since it needs abstraction across the different toolchains.
|
||||
* If not required, the <options> and <align> parameters should be left blank.
|
||||
*/
|
||||
|
||||
#define SECTION_PROLOGUE(name, options, align) name options : align
|
||||
|
||||
/*
|
||||
* As for SECTION_PROLOGUE(), except that this one must (!) be used
|
||||
* for data sections which on XIP platforms will have differing
|
||||
* virtual and load addresses (i.e. they'll be copied into RAM at
|
||||
* program startup). Such a section must (!) also use
|
||||
* GROUP_LINK_IN_LMA to specify the correct output load address.
|
||||
*/
|
||||
#ifdef CONFIG_XIP
|
||||
#define SECTION_DATA_PROLOGUE(name, options, align) \
|
||||
name options : ALIGN_WITH_INPUT align
|
||||
#else
|
||||
#define SECTION_DATA_PROLOGUE(name, options, align) name options : align
|
||||
#endif
|
||||
|
||||
#define SORT_BY_NAME(x) SORT(x)
|
||||
#define OPTIONAL
|
||||
|
||||
#define COMMON_SYMBOLS *(COMMON)
|
||||
|
||||
#endif /* !__LINKER_TOOL_GCC_H */
|
26
include/linker/linker-tool.h
Normal file
26
include/linker/linker-tool.h
Normal file
|
@ -0,0 +1,26 @@
|
|||
/*
|
||||
* Copyright (c) 2013-2014, Wind River Systems, Inc.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
/**
|
||||
* @file
|
||||
* @brief Toolchain-agnostic linker defs
|
||||
*
|
||||
* This header file is used to automatically select the proper set of macro
|
||||
* definitions (based on the toolchain) for the linker script.
|
||||
*/
|
||||
|
||||
#ifndef __LINKER_TOOL_H
|
||||
#define __LINKER_TOOL_H
|
||||
|
||||
#if defined(_LINKER)
|
||||
#if defined(__GCC_LINKER_CMD__)
|
||||
#include <linker/linker-tool-gcc.h>
|
||||
#else
|
||||
#error "Unknown toolchain"
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#endif /* !__LINKER_TOOL_H */
|
27
include/linker/section_tags.h
Normal file
27
include/linker/section_tags.h
Normal file
|
@ -0,0 +1,27 @@
|
|||
/* Macros for tagging symbols and putting them in the correct sections. */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2013-2014, Wind River Systems, Inc.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
#ifndef _section_tags__h_
|
||||
#define _section_tags__h_
|
||||
|
||||
#include <toolchain.h>
|
||||
|
||||
#if !defined(_ASMLANGUAGE)
|
||||
|
||||
#define __noinit __in_section_unique(NOINIT)
|
||||
#define __irq_vector_table _GENERIC_SECTION(IRQ_VECTOR_TABLE)
|
||||
#define __sw_isr_table _GENERIC_SECTION(SW_ISR_TABLE)
|
||||
|
||||
#if defined(CONFIG_ARM)
|
||||
#define __kinetis_flash_config_section __in_section_unique(KINETIS_FLASH_CONFIG)
|
||||
#define __ti_ccfg_section _GENERIC_SECTION(TI_CCFG)
|
||||
#endif /* CONFIG_ARM */
|
||||
|
||||
#endif /* !_ASMLANGUAGE */
|
||||
|
||||
#endif /* _section_tags__h_ */
|
54
include/linker/sections.h
Normal file
54
include/linker/sections.h
Normal file
|
@ -0,0 +1,54 @@
|
|||
/*
|
||||
* Copyright (c) 2013-2014, Wind River Systems, Inc.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
/**
|
||||
* @file
|
||||
* @brief Definitions of various linker Sections.
|
||||
*
|
||||
* Linker Section declarations used by linker script, C files and Assembly
|
||||
* files.
|
||||
*/
|
||||
|
||||
#ifndef _SECTIONS_H
|
||||
#define _SECTIONS_H
|
||||
|
||||
#define _TEXT_SECTION_NAME text
|
||||
#define _RODATA_SECTION_NAME rodata
|
||||
#define _CTOR_SECTION_NAME ctors
|
||||
/* Linker issue with XIP where the name "data" cannot be used */
|
||||
#define _DATA_SECTION_NAME datas
|
||||
#define _BSS_SECTION_NAME bss
|
||||
#define _NOINIT_SECTION_NAME noinit
|
||||
|
||||
#define _UNDEFINED_SECTION_NAME undefined
|
||||
|
||||
/* Various text section names */
|
||||
#define TEXT text
|
||||
#if defined(CONFIG_X86)
|
||||
#define TEXT_START text_start /* beginning of TEXT section */
|
||||
#else
|
||||
#define TEXT_START text /* beginning of TEXT section */
|
||||
#endif
|
||||
|
||||
/* Various data type section names */
|
||||
#define BSS bss
|
||||
#define RODATA rodata
|
||||
#define DATA data
|
||||
#define NOINIT noinit
|
||||
|
||||
/* Interrupts */
|
||||
#define IRQ_VECTOR_TABLE .gnu.linkonce.irq_vector_table
|
||||
#define SW_ISR_TABLE .gnu.linkonce.sw_isr_table
|
||||
|
||||
/* Architecture-specific sections */
|
||||
#if defined(CONFIG_ARM)
|
||||
#define KINETIS_FLASH_CONFIG kinetis_flash_config
|
||||
#define TI_CCFG .ti_ccfg
|
||||
#endif
|
||||
|
||||
#include <linker/section_tags.h>
|
||||
|
||||
#endif /* _SECTIONS_H */
|
Loading…
Add table
Add a link
Reference in a new issue