228 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			228 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
/* Linker script for Dialog DA1469x devices
 | 
						|
 *
 | 
						|
 * Version: Sourcery G++ 4.5-1
 | 
						|
 * Support: https://support.codesourcery.com/GNUToolchain/
 | 
						|
 *
 | 
						|
 * Copyright (c) 2007, 2008, 2009, 2010 CodeSourcery, Inc.
 | 
						|
 *
 | 
						|
 * The authors hereby grant permission to use, copy, modify, distribute,
 | 
						|
 * and license this software and its documentation for any purpose, provided
 | 
						|
 * that existing copyright notices are retained in all copies and that this
 | 
						|
 * notice is included verbatim in any distributions.  No written agreement,
 | 
						|
 * license, or royalty fee is required for any of the authorized uses.
 | 
						|
 * Modifications to this software may be copyrighted by their authors
 | 
						|
 * and need not follow the licensing terms described here, provided that
 | 
						|
 * the new terms are clearly indicated on the first page of each file where
 | 
						|
 * they apply.
 | 
						|
 */
 | 
						|
OUTPUT_FORMAT ("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
 | 
						|
 | 
						|
/* Linker script to place sections and symbol values. Should be used together
 | 
						|
 * with other linker script that defines memory regions FLASH and RAM.
 | 
						|
 * It references following symbols, which must be defined in code:
 | 
						|
 *   Reset_Handler : Entry of reset handler
 | 
						|
 *
 | 
						|
 * It defines following symbols, which code can use without definition:
 | 
						|
 *   __exidx_start
 | 
						|
 *   __exidx_end
 | 
						|
 *   __etext
 | 
						|
 *   __data_start__
 | 
						|
 *   __preinit_array_start
 | 
						|
 *   __preinit_array_end
 | 
						|
 *   __init_array_start
 | 
						|
 *   __init_array_end
 | 
						|
 *   __fini_array_start
 | 
						|
 *   __fini_array_end
 | 
						|
 *   __data_end__
 | 
						|
 *   __bss_start__
 | 
						|
 *   __bss_end__
 | 
						|
 *   __HeapBase
 | 
						|
 *   __HeapLimit
 | 
						|
 *   __StackLimit
 | 
						|
 *   __StackTop
 | 
						|
 *   __stack
 | 
						|
 *   __bssnz_start__
 | 
						|
 *   __bssnz_end__
 | 
						|
 */
 | 
						|
ENTRY(Reset_Handler)
 | 
						|
 | 
						|
SECTIONS
 | 
						|
{
 | 
						|
    .imghdr (NOLOAD):
 | 
						|
    {
 | 
						|
        . = . + _imghdr_size;
 | 
						|
    } > FLASH
 | 
						|
 | 
						|
    __text = .;
 | 
						|
 | 
						|
    .text :
 | 
						|
    {
 | 
						|
        __isr_vector_start = .;
 | 
						|
        KEEP(*(.isr_vector))
 | 
						|
        /* ISR vector shall have exactly 512 bytes */
 | 
						|
        . = __isr_vector_start + 0x200;
 | 
						|
        __isr_vector_end = .;
 | 
						|
 | 
						|
        *(.text)
 | 
						|
        *(.text.*)
 | 
						|
 | 
						|
        KEEP(*(.init))
 | 
						|
        KEEP(*(.fini))
 | 
						|
 | 
						|
        /* .ctors */
 | 
						|
        *crtbegin.o(.ctors)
 | 
						|
        *crtbegin?.o(.ctors)
 | 
						|
        *(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors)
 | 
						|
        *(SORT(.ctors.*))
 | 
						|
        *(.ctors)
 | 
						|
 | 
						|
        /* .dtors */
 | 
						|
        *crtbegin.o(.dtors)
 | 
						|
        *crtbegin?.o(.dtors)
 | 
						|
        *(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors)
 | 
						|
        *(SORT(.dtors.*))
 | 
						|
        *(.dtors)
 | 
						|
 | 
						|
        *(.rodata*)
 | 
						|
 | 
						|
        *(.eh_frame*)
 | 
						|
        . = ALIGN(4);
 | 
						|
    } > FLASH
 | 
						|
 | 
						|
    .ARM.extab :
 | 
						|
    {
 | 
						|
        *(.ARM.extab* .gnu.linkonce.armextab.*)
 | 
						|
        . = ALIGN(4);
 | 
						|
    } > FLASH
 | 
						|
 | 
						|
    __exidx_start = .;
 | 
						|
    .ARM.exidx :
 | 
						|
    {
 | 
						|
        *(.ARM.exidx* .gnu.linkonce.armexidx.*)
 | 
						|
        . = ALIGN(4);
 | 
						|
    } > FLASH
 | 
						|
    __exidx_end = .;
 | 
						|
 | 
						|
    .intvect :
 | 
						|
    {
 | 
						|
        . = ALIGN(4);
 | 
						|
        __intvect_start__ = .;
 | 
						|
        . = . + (__isr_vector_end - __isr_vector_start);
 | 
						|
        . = ALIGN(4);
 | 
						|
    } > RAM
 | 
						|
 | 
						|
    .sleep_state (NOLOAD) :
 | 
						|
    {
 | 
						|
        . = ALIGN(4);
 | 
						|
        *(sleep_state)
 | 
						|
    } > RAM
 | 
						|
 | 
						|
    /* This section will be zeroed by RTT package init */
 | 
						|
    .rtt (NOLOAD):
 | 
						|
    {
 | 
						|
        . = ALIGN(4);
 | 
						|
        *(.rtt)
 | 
						|
        . = ALIGN(4);
 | 
						|
    } > RAM
 | 
						|
 | 
						|
    __text_ram_addr = LOADADDR(.text_ram);
 | 
						|
 | 
						|
    .text_ram :
 | 
						|
    {
 | 
						|
        . = ALIGN(4);
 | 
						|
        __text_ram_start__ = .;
 | 
						|
        *(.text_ram*)
 | 
						|
        . = ALIGN(4);
 | 
						|
        __text_ram_end__ = .;
 | 
						|
    } > RAM AT > FLASH
 | 
						|
 | 
						|
    __etext = LOADADDR(.data);
 | 
						|
 | 
						|
    .data :
 | 
						|
    {
 | 
						|
        __data_start__ = .;
 | 
						|
        *(vtable)
 | 
						|
        *(.data*)
 | 
						|
 | 
						|
        . = ALIGN(4);
 | 
						|
        /* preinit data */
 | 
						|
        PROVIDE_HIDDEN (__preinit_array_start = .);
 | 
						|
        *(.preinit_array)
 | 
						|
        PROVIDE_HIDDEN (__preinit_array_end = .);
 | 
						|
 | 
						|
        . = ALIGN(4);
 | 
						|
        /* init data */
 | 
						|
        PROVIDE_HIDDEN (__init_array_start = .);
 | 
						|
        *(SORT(.init_array.*))
 | 
						|
        *(.init_array)
 | 
						|
        PROVIDE_HIDDEN (__init_array_end = .);
 | 
						|
 | 
						|
 | 
						|
        . = ALIGN(4);
 | 
						|
        /* finit data */
 | 
						|
        PROVIDE_HIDDEN (__fini_array_start = .);
 | 
						|
        *(SORT(.fini_array.*))
 | 
						|
        *(.fini_array)
 | 
						|
        PROVIDE_HIDDEN (__fini_array_end = .);
 | 
						|
 | 
						|
        *(.jcr)
 | 
						|
        . = ALIGN(4);
 | 
						|
        /* All data end */
 | 
						|
        __data_end__ = .;
 | 
						|
    } > RAM AT > FLASH
 | 
						|
 | 
						|
    .bssnz :
 | 
						|
    {
 | 
						|
        . = ALIGN(4);
 | 
						|
        __bssnz_start__ = .;
 | 
						|
        *(.bss.core.nz*)
 | 
						|
        . = ALIGN(4);
 | 
						|
        __bssnz_end__ = .;
 | 
						|
    } > RAM
 | 
						|
 | 
						|
    .bss :
 | 
						|
    {
 | 
						|
        . = ALIGN(4);
 | 
						|
        __bss_start__ = .;
 | 
						|
        *(.bss*)
 | 
						|
        *(COMMON)
 | 
						|
        . = ALIGN(4);
 | 
						|
        __bss_end__ = .;
 | 
						|
    } > RAM
 | 
						|
 | 
						|
    .cmac (NOLOAD) :
 | 
						|
    {
 | 
						|
        . = ALIGN(0x400);
 | 
						|
        *(.libcmac.ram)
 | 
						|
    } > RAM
 | 
						|
 | 
						|
    /* Heap starts after BSS */
 | 
						|
    . = ALIGN(8);
 | 
						|
    __HeapBase = .;
 | 
						|
 | 
						|
    /* .stack_dummy section doesn't contains any symbols. It is only
 | 
						|
     * used for linker to calculate size of stack sections, and assign
 | 
						|
     * values to stack symbols later */
 | 
						|
    .stack_dummy (COPY):
 | 
						|
    {
 | 
						|
        *(.stack*)
 | 
						|
    } > RAM
 | 
						|
 | 
						|
    _ram_start = ORIGIN(RAM);
 | 
						|
 | 
						|
    /* Set stack top to end of RAM, and stack limit move down by
 | 
						|
     * size of stack_dummy section */
 | 
						|
    __StackTop = ORIGIN(RAM) + LENGTH(RAM);
 | 
						|
    __StackLimit = __StackTop - SIZEOF(.stack_dummy);
 | 
						|
    PROVIDE(__stack = __StackTop);
 | 
						|
 | 
						|
    /* Top of head is the bottom of the stack */
 | 
						|
    __HeapLimit = __StackLimit;
 | 
						|
 | 
						|
    /* Check if data + heap + stack exceeds RAM limit */
 | 
						|
    ASSERT(__HeapBase <= __HeapLimit, "region RAM overflowed with stack")
 | 
						|
 | 
						|
    /* Check that intvect is at the beginning of RAM */
 | 
						|
    ASSERT(__intvect_start__ == ORIGIN(RAM), "intvect is not at beginning of RAM")
 | 
						|
}
 |