209 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			209 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
/*
 | 
						|
******************************************************************************
 | 
						|
**
 | 
						|
** @file        : LinkerScript.ld
 | 
						|
**
 | 
						|
** @author      : Auto-generated by STM32CubeIDE
 | 
						|
**
 | 
						|
** @brief       : Linker script for STM32H7S3xx Device from STM32H7RS series
 | 
						|
**                      64Kbytes FLASH
 | 
						|
**                      456Kbytes RAM
 | 
						|
**
 | 
						|
**                Set heap size, stack size and stack location according
 | 
						|
**                to application requirements.
 | 
						|
**
 | 
						|
**                Set memory bank area and size if external memory is used
 | 
						|
**
 | 
						|
**  Target      : STMicroelectronics STM32
 | 
						|
**
 | 
						|
**  Distribution: The file is distributed as is, without any warranty
 | 
						|
**                of any kind.
 | 
						|
**
 | 
						|
******************************************************************************
 | 
						|
** @attention
 | 
						|
**
 | 
						|
** Copyright (c) 2023 STMicroelectronics.
 | 
						|
** All rights reserved.
 | 
						|
**
 | 
						|
** This software is licensed under terms that can be found in the LICENSE file
 | 
						|
** in the root directory of this software component.
 | 
						|
** If no LICENSE file comes with this software, it is provided AS-IS.
 | 
						|
**
 | 
						|
******************************************************************************
 | 
						|
*/
 | 
						|
 | 
						|
/* Entry Point */
 | 
						|
ENTRY(Reset_Handler)
 | 
						|
 | 
						|
_Min_Heap_Size = 0x200; /* required amount of heap */
 | 
						|
_Min_Stack_Size = 0x400; /* required amount of stack */
 | 
						|
 | 
						|
__FLASH_BEGIN  = 0x08000000;
 | 
						|
__FLASH_SIZE   = 0x00010000;
 | 
						|
 | 
						|
__RAM_BEGIN    = 0x24000000;
 | 
						|
__RAM_SIZE     = 0x4FC00;
 | 
						|
__RAM_NONCACHEABLEBUFFER_SIZE = 0x400;
 | 
						|
 | 
						|
/* Memories definition */
 | 
						|
MEMORY
 | 
						|
{
 | 
						|
  RAM       (xrw) : ORIGIN = __RAM_BEGIN,    LENGTH = __RAM_SIZE
 | 
						|
  RAM_NONCACHEABLEBUFFER (xrw) : ORIGIN = __RAM_BEGIN + __RAM_SIZE,  LENGTH = __RAM_NONCACHEABLEBUFFER_SIZE
 | 
						|
 | 
						|
  ITCM      (xrw) : ORIGIN = 0x00000000,    LENGTH = 0x00010000
 | 
						|
  DTCM       (rw) : ORIGIN = 0x20000000,    LENGTH = 0x00010000
 | 
						|
  SRAMAHB   (rw)  : ORIGIN = 0x30000000,  LENGTH = 0x00008000
 | 
						|
  BKPSRAM   (rw)  : ORIGIN = 0x38800000,  LENGTH = 0x00001000
 | 
						|
 | 
						|
  FLASH     (xrw) : ORIGIN = __FLASH_BEGIN, LENGTH = __FLASH_SIZE
 | 
						|
}
 | 
						|
 | 
						|
/* Highest address of the user mode stack */
 | 
						|
_estack = ORIGIN(DTCM) + LENGTH(DTCM); /* end of "DTCM" Ram type memory */
 | 
						|
 | 
						|
/* Sections */
 | 
						|
SECTIONS
 | 
						|
{
 | 
						|
  /* The startup code into "FLASH" Rom type memory */
 | 
						|
  .isr_vector :
 | 
						|
  {
 | 
						|
    . = ALIGN(4);
 | 
						|
    KEEP(*(.isr_vector)) /* Startup code */
 | 
						|
    . = ALIGN(4);
 | 
						|
  } >FLASH
 | 
						|
 | 
						|
  /* The program code and other data into "FLASH" Rom type memory */
 | 
						|
  .text :
 | 
						|
  {
 | 
						|
    . = ALIGN(4);
 | 
						|
    *(.text)           /* .text sections (code) */
 | 
						|
    *(.text*)          /* .text* sections (code) */
 | 
						|
    *(.glue_7)         /* glue arm to thumb code */
 | 
						|
    *(.glue_7t)        /* glue thumb to arm code */
 | 
						|
    *(.eh_frame)
 | 
						|
 | 
						|
    KEEP (*(.init))
 | 
						|
    KEEP (*(.fini))
 | 
						|
 | 
						|
    . = ALIGN(4);
 | 
						|
    _etext = .;        /* define a global symbols at end of code */
 | 
						|
  } >FLASH
 | 
						|
 | 
						|
  /* Constant data into "FLASH" Rom type memory */
 | 
						|
  .rodata :
 | 
						|
  {
 | 
						|
    . = ALIGN(4);
 | 
						|
    *(.rodata)         /* .rodata sections (constants, strings, etc.) */
 | 
						|
    *(.rodata*)        /* .rodata* sections (constants, strings, etc.) */
 | 
						|
    . = ALIGN(4);
 | 
						|
  } >FLASH
 | 
						|
 | 
						|
  .ARM.extab :
 | 
						|
  {
 | 
						|
    . = ALIGN(4);
 | 
						|
    *(.ARM.extab* .gnu.linkonce.armextab.*)
 | 
						|
    . = ALIGN(4);
 | 
						|
  } >FLASH
 | 
						|
 | 
						|
  .ARM :
 | 
						|
   {
 | 
						|
    . = ALIGN(4);
 | 
						|
    __exidx_start = .;
 | 
						|
    *(.ARM.exidx*)
 | 
						|
    __exidx_end = .;
 | 
						|
    . = ALIGN(4);
 | 
						|
  } >FLASH
 | 
						|
 | 
						|
  .preinit_array   :
 | 
						|
  {
 | 
						|
    . = ALIGN(4);
 | 
						|
    PROVIDE_HIDDEN (__preinit_array_start = .);
 | 
						|
    KEEP (*(.preinit_array*))
 | 
						|
    PROVIDE_HIDDEN (__preinit_array_end = .);
 | 
						|
    . = ALIGN(4);
 | 
						|
  } >FLASH
 | 
						|
 | 
						|
  .init_array  :
 | 
						|
  {
 | 
						|
    . = ALIGN(4);
 | 
						|
    PROVIDE_HIDDEN (__init_array_start = .);
 | 
						|
    KEEP (*(SORT(.init_array.*)))
 | 
						|
    KEEP (*(.init_array*))
 | 
						|
    PROVIDE_HIDDEN (__init_array_end = .);
 | 
						|
    . = ALIGN(4);
 | 
						|
  } >FLASH
 | 
						|
 | 
						|
  .fini_array  :
 | 
						|
  {
 | 
						|
    . = ALIGN(4);
 | 
						|
    PROVIDE_HIDDEN (__fini_array_start = .);
 | 
						|
    KEEP (*(SORT(.fini_array.*)))
 | 
						|
    KEEP (*(.fini_array*))
 | 
						|
    PROVIDE_HIDDEN (__fini_array_end = .);
 | 
						|
    . = ALIGN(4);
 | 
						|
  } >FLASH
 | 
						|
 | 
						|
  /* Used by the startup to initialize data */
 | 
						|
  _sidata = LOADADDR(.data);
 | 
						|
 | 
						|
  /* Initialized data sections into "RAM" Ram type memory */
 | 
						|
  .data :
 | 
						|
  {
 | 
						|
    . = ALIGN(4);
 | 
						|
    _sdata = .;        /* create a global symbol at data start */
 | 
						|
    *(.data)           /* .data sections */
 | 
						|
    *(.data*)          /* .data* sections */
 | 
						|
    *(.RamFunc)        /* .RamFunc sections */
 | 
						|
    *(.RamFunc*)       /* .RamFunc* sections */
 | 
						|
 | 
						|
    . = ALIGN(4);
 | 
						|
    _edata = .;        /* define a global symbol at data end */
 | 
						|
 | 
						|
  } >RAM AT> FLASH
 | 
						|
 | 
						|
  /* Uninitialized data section into "RAM" Ram type memory */
 | 
						|
  . = ALIGN(4);
 | 
						|
  .bss :
 | 
						|
  {
 | 
						|
    /* This is used by the startup in order to initialize the .bss section */
 | 
						|
    _sbss = .;         /* define a global symbol at bss start */
 | 
						|
    __bss_start__ = _sbss;
 | 
						|
    *(.bss)
 | 
						|
    *(.bss*)
 | 
						|
    *(COMMON)
 | 
						|
 | 
						|
    . = ALIGN(4);
 | 
						|
    _ebss = .;         /* define a global symbol at bss end */
 | 
						|
    __bss_end__ = _ebss;
 | 
						|
  } >RAM
 | 
						|
 | 
						|
  RW_NONCACHEABLE :
 | 
						|
  {
 | 
						|
    __NONCACHEABLEBUFFER_BEGIN = .;/* create symbol for start of section */
 | 
						|
    KEEP(*(noncacheable_buffer))
 | 
						|
    __NONCACHEABLEBUFFER_END = .;  /* create symbol for end of section */
 | 
						|
  } > RAM_NONCACHEABLEBUFFER
 | 
						|
 | 
						|
  /* User_heap_stack section, used to check that there is enough "DTCM" Ram  type memory left */
 | 
						|
  ._user_heap_stack :
 | 
						|
  {
 | 
						|
    . = ALIGN(8);
 | 
						|
    PROVIDE ( end = . );
 | 
						|
    PROVIDE ( _end = . );
 | 
						|
    . = . + _Min_Heap_Size;
 | 
						|
    . = . + _Min_Stack_Size;
 | 
						|
    . = ALIGN(8);
 | 
						|
  } >DTCM
 | 
						|
 | 
						|
  /* Remove information from the compiler libraries */
 | 
						|
  /DISCARD/ :
 | 
						|
  {
 | 
						|
    libc.a ( * )
 | 
						|
    libm.a ( * )
 | 
						|
    libgcc.a ( * )
 | 
						|
  }
 | 
						|
 | 
						|
  .ARM.attributes 0 : { *(.ARM.attributes) }
 | 
						|
}
 |