startup code: wrote linkerscript, created startup-code file
This commit is contained in:
		
							
								
								
									
										0
									
								
								startup/startup_stm32f746.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								startup/startup_stm32f746.c
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										166
									
								
								startup/stm32f746zgt-axim.ld
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								startup/stm32f746zgt-axim.ld
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,166 @@
 | 
			
		||||
/*
 | 
			
		||||
* STM32F746ZG Linkerscript for FLASH access over AXI-M
 | 
			
		||||
* Copyright (C) 2017 Mario Hüttel <mario.huettel@gmx.net>
 | 
			
		||||
*
 | 
			
		||||
* This file is part of 'STM32F7 code template'.
 | 
			
		||||
*
 | 
			
		||||
* It is free software: you can redistribute it and/or modify
 | 
			
		||||
* it under the terms of the GNU General Public License as published by
 | 
			
		||||
* the Free Software Foundation, version 2 of the License.
 | 
			
		||||
*
 | 
			
		||||
* This code is distributed in the hope that it will be useful,
 | 
			
		||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
			
		||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
			
		||||
* GNU General Public License for more details.
 | 
			
		||||
*
 | 
			
		||||
* You should have received a copy of the GNU General Public License
 | 
			
		||||
* along with this template.  If not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
* --------------------------------------------------------------------
 | 
			
		||||
* FLASH: 1024K
 | 
			
		||||
* RAM: 256K
 | 
			
		||||
* TCM-Data-RAM: 64K
 | 
			
		||||
* FPU: fpv5-sp-d16
 | 
			
		||||
* 
 | 
			
		||||
* Flash sections are accessed via the AXI Interface of the Core
 | 
			
		||||
* Data is stored in normal SRAM unless specified to lay in TCM RAM (section: .dtcm, .dtcm.*)
 | 
			
		||||
* Code can be configured to lay in I-TCM RAM fpr ultra low latency applications (section: .itcm, .itcm.*)
 | 
			
		||||
*/
 | 
			
		||||
 | 
			
		||||
/* USER PARAMETERS */
 | 
			
		||||
__ld_stack_size = 0x400
 | 
			
		||||
__ld_heap_size = 0x200
 | 
			
		||||
 | 
			
		||||
/* END OF USER PARAMETERS */
 | 
			
		||||
ENTRY(reset_handler)
 | 
			
		||||
__ld_top_of_stack = 0x20050000 /* One byte above the end of the SRAM. Stack is pre-decrewmenting, so this is okay */
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/* Available memory areas */
 | 
			
		||||
MEMORY
 | 
			
		||||
{
 | 
			
		||||
	ITCMRAM (xrw)	: ORIGIN = 0x00000000, LENGTH = 16K
 | 
			
		||||
	ITCMFLASH (xr)	: ORIGIN = 0x00200000, LENGTH = 1024K
 | 
			
		||||
	AXIFLASH (xr)	: ORIGIN = 0x08000000, LENGTH = 1024K
 | 
			
		||||
	DTCMRAM (xrw)	: ORIGIN = 0x20000000, LENGTH = 64K
 | 
			
		||||
	RAM (xrw)	: ORIGIN = 0x20010000, LENGTH = 256K	
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
SECTIONS
 | 
			
		||||
{
 | 
			
		||||
	.vectors :
 | 
			
		||||
	{
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
		KEEP(*(.vectors))
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
	} >AXIFLASH
 | 
			
		||||
	
 | 
			
		||||
	.text :
 | 
			
		||||
	{
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
		*(.text)           /* .text sections (code) */
 | 
			
		||||
    		*(.text*)          /* .text* sections (code) */
 | 
			
		||||
    		*(.rodata)         /* .rodata sections (constants, strings, etc.) */
 | 
			
		||||
    		*(.rodata*)        /* .rodata* sections (constants, strings, etc.) */
 | 
			
		||||
    		*(.glue_7)         /* glue arm to thumb code */
 | 
			
		||||
    		*(.glue_7t)        /* glue thumb to arm code */
 | 
			
		||||
		*(.eh_frame)
 | 
			
		||||
		KEEP(*(.init))	   /* Constructors */
 | 
			
		||||
		KEEP(*(.fini))     /* Destructors  */
 | 
			
		||||
	} >AXIFLASH
 | 
			
		||||
	
 | 
			
		||||
	.ARM.extab : 
 | 
			
		||||
	{ 
 | 
			
		||||
		*(.ARM.extab* .gnu.linkonce.armextab.*) 
 | 
			
		||||
	} >AXIFLASH
 | 
			
		||||
	
 | 
			
		||||
	.ARM :
 | 
			
		||||
	{
 | 
			
		||||
    		__exidx_start = .;
 | 
			
		||||
      		*(.ARM.exidx*)
 | 
			
		||||
      		__exidx_end = .;
 | 
			
		||||
   	} >AXIFLASH
 | 
			
		||||
	
 | 
			
		||||
	/* Constructor/Destructor tables */
 | 
			
		||||
 	.preinit_array     :
 | 
			
		||||
	{
 | 
			
		||||
    		PROVIDE_HIDDEN (__preinit_array_start = .);
 | 
			
		||||
    		KEEP (*(.preinit_array*))
 | 
			
		||||
    		PROVIDE_HIDDEN (__preinit_array_end = .);
 | 
			
		||||
  	} >AXIFLASH
 | 
			
		||||
  	
 | 
			
		||||
	.init_array :
 | 
			
		||||
  	{
 | 
			
		||||
    		PROVIDE_HIDDEN (__init_array_start = .);
 | 
			
		||||
    		KEEP (*(SORT(.init_array.*)))
 | 
			
		||||
    		KEEP (*(.init_array*))
 | 
			
		||||
    		PROVIDE_HIDDEN (__init_array_end = .);
 | 
			
		||||
  	} >AXIFLASH
 | 
			
		||||
  
 | 
			
		||||
	.fini_array :
 | 
			
		||||
	{
 | 
			
		||||
    		PROVIDE_HIDDEN (__fini_array_start = .);
 | 
			
		||||
    		KEEP (*(.fini_array*))
 | 
			
		||||
    		KEEP (*(SORT(.fini_array.*)))
 | 
			
		||||
    		PROVIDE_HIDDEN (__fini_array_end = .);
 | 
			
		||||
  	} >AXIFLASH
 | 
			
		||||
	
 | 
			
		||||
	/* Tightly coupled instruction RAM */
 | 
			
		||||
	__ld_load_itcm = LOADADDR(.itcm);
 | 
			
		||||
	.itcm :
 | 
			
		||||
	{
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
		__ld_sitcm = .;
 | 
			
		||||
		*(.itcm)
 | 
			
		||||
		*(.itcm*)
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
		__ld_eitcm = .;
 | 
			
		||||
	} >ITCMRAM AT> AXIFLASH
 | 
			
		||||
	
 | 
			
		||||
	/* Tightly Coupled Memory for Data */
 | 
			
		||||
	__ld_load_dtcm = LOADADDR(.dtcm);	
 | 
			
		||||
	.dtcm :
 | 
			
		||||
	{
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
		__ld_sdtcm = .;
 | 
			
		||||
		*(.dtcm)
 | 
			
		||||
		*(.dtcm*)
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
		__ld_edtcm = .
 | 
			
		||||
	} >DTCMRAM AT> AXIFLASH
 | 
			
		||||
	
 | 
			
		||||
	/* Initialized Data */
 | 
			
		||||
	__ld_load_data = LOADADDR(.data);
 | 
			
		||||
	.data : 
 | 
			
		||||
	{
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
		__ld_sdata = .;
 | 
			
		||||
		*(.data)
 | 
			
		||||
		*(.data*)
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
		__ld_edata = .;
 | 
			
		||||
	} >RAM AT> AXIFLASH
 | 
			
		||||
	
 | 
			
		||||
	/* Uninitialized static data */
 | 
			
		||||
	.bss :
 | 
			
		||||
	{
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
		__ld_sbss = .;
 | 
			
		||||
		*(.bss)
 | 
			
		||||
		*(.bss*)
 | 
			
		||||
		*(COMMON)
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
		__ld_ebss = .;
 | 
			
		||||
	} >RAM
 | 
			
		||||
 | 
			
		||||
	.heap_stack (NOLOAD) :
 | 
			
		||||
	{
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
		__ld_sheap = .;
 | 
			
		||||
		. = . + __ld_heap_size;
 | 
			
		||||
		__ld_eheap = .;
 | 
			
		||||
		. = . + __ld_stack_size;
 | 
			
		||||
		. = ALIGN(4);
 | 
			
		||||
	} >RAM
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user