mirror of
				https://github.com/marqs85/ossc
				synced 2025-10-26 13:36:02 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			406 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			406 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| /*
 | |
|  * linker.x - Linker script
 | |
|  *
 | |
|  * Machine generated for CPU 'nios2_qsys_0' in SOPC Builder design 'sys'
 | |
|  * SOPC Builder design path: ../../sys.sopcinfo
 | |
|  *
 | |
|  * Generated: Fri Oct 05 19:59:02 EEST 2018
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * DO NOT MODIFY THIS FILE
 | |
|  *
 | |
|  * Changing this file will have subtle consequences
 | |
|  * which will almost certainly lead to a nonfunctioning
 | |
|  * system. If you do modify this file, be aware that your
 | |
|  * changes will be overwritten and lost when this file
 | |
|  * is generated again.
 | |
|  *
 | |
|  * DO NOT MODIFY THIS FILE
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * License Agreement
 | |
|  *
 | |
|  * Copyright (c) 2008
 | |
|  * Altera Corporation, San Jose, California, USA.
 | |
|  * All rights reserved.
 | |
|  *
 | |
|  * Permission is hereby granted, free of charge, to any person obtaining a
 | |
|  * copy of this software and associated documentation files (the "Software"),
 | |
|  * to deal in the Software without restriction, including without limitation
 | |
|  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 | |
|  * and/or sell copies of the Software, and to permit persons to whom the
 | |
|  * Software is furnished to do so, subject to the following conditions:
 | |
|  *
 | |
|  * The above copyright notice and this permission notice shall be included in
 | |
|  * all copies or substantial portions of the Software.
 | |
|  *
 | |
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | |
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | |
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | |
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | |
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 | |
|  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 | |
|  * DEALINGS IN THE SOFTWARE.
 | |
|  *
 | |
|  * This agreement shall be governed in all respects by the laws of the State
 | |
|  * of California and by the laws of the United States of America.
 | |
|  */
 | |
| 
 | |
| MEMORY
 | |
| {
 | |
|     reset : ORIGIN = 0x10000, LENGTH = 32
 | |
|     onchip_memory2_0 : ORIGIN = 0x10020, LENGTH = 36832
 | |
|     epcq_controller_0_avl_mem : ORIGIN = 0x800000, LENGTH = 8388608
 | |
| }
 | |
| 
 | |
| /* Define symbols for each memory base-address */
 | |
| __alt_mem_onchip_memory2_0 = 0x10000;
 | |
| __alt_mem_epcq_controller_0_avl_mem = 0x800000;
 | |
| 
 | |
| OUTPUT_FORMAT( "elf32-littlenios2",
 | |
|                "elf32-littlenios2",
 | |
|                "elf32-littlenios2" )
 | |
| OUTPUT_ARCH( nios2 )
 | |
| ENTRY( _start )
 | |
| 
 | |
| /*
 | |
|  * The alt_load() facility is enabled. This typically happens when there isn't
 | |
|  * an external bootloader (e.g. flash bootloader).
 | |
|  * The LMA (aka physical address) of each loaded section is
 | |
|  * set to the .text memory device.
 | |
|  * The HAL alt_load() routine called from crt0 copies sections from
 | |
|  * the .text memory to RAM as needed.
 | |
|  */
 | |
| 
 | |
| SECTIONS
 | |
| {
 | |
| 
 | |
|     /*
 | |
|      * Output sections associated with reset and exceptions (they have to be first)
 | |
|      */
 | |
| 
 | |
|     .entry :
 | |
|     {
 | |
|         KEEP (*(.entry))
 | |
|     } > reset
 | |
| 
 | |
|     .exceptions :
 | |
|     {
 | |
|         PROVIDE (__ram_exceptions_start = ABSOLUTE(.));
 | |
|         . = ALIGN(0x20);
 | |
|         KEEP (*(.irq));
 | |
|         KEEP (*(.exceptions.entry.label));
 | |
|         KEEP (*(.exceptions.entry.user));
 | |
|         KEEP (*(.exceptions.entry.ecc_fatal));
 | |
|         KEEP (*(.exceptions.entry));
 | |
|         KEEP (*(.exceptions.irqtest.user));
 | |
|         KEEP (*(.exceptions.irqtest));
 | |
|         KEEP (*(.exceptions.irqhandler.user));
 | |
|         KEEP (*(.exceptions.irqhandler));
 | |
|         KEEP (*(.exceptions.irqreturn.user));
 | |
|         KEEP (*(.exceptions.irqreturn));
 | |
|         KEEP (*(.exceptions.notirq.label));
 | |
|         KEEP (*(.exceptions.notirq.user));
 | |
|         KEEP (*(.exceptions.notirq));
 | |
|         KEEP (*(.exceptions.soft.user));
 | |
|         KEEP (*(.exceptions.soft));
 | |
|         KEEP (*(.exceptions.unknown.user));
 | |
|         KEEP (*(.exceptions.unknown));
 | |
|         KEEP (*(.exceptions.exit.label));
 | |
|         KEEP (*(.exceptions.exit.user));
 | |
|         KEEP (*(.exceptions.exit));
 | |
|         KEEP (*(.exceptions));
 | |
|         PROVIDE (__ram_exceptions_end = ABSOLUTE(.));
 | |
|     } > onchip_memory2_0
 | |
| 
 | |
|     PROVIDE (__flash_exceptions_start = LOADADDR(.exceptions));
 | |
| 
 | |
|     .text :
 | |
|     {
 | |
|         /*
 | |
|          * All code sections are merged into the text output section, along with
 | |
|          * the read only data sections.
 | |
|          *
 | |
|          */
 | |
| 
 | |
|         PROVIDE (stext = ABSOLUTE(.));
 | |
| 
 | |
|         *(.interp)
 | |
|         *(.hash)
 | |
|         *(.dynsym)
 | |
|         *(.dynstr)
 | |
|         *(.gnu.version)
 | |
|         *(.gnu.version_d)
 | |
|         *(.gnu.version_r)
 | |
|         *(.rel.init)
 | |
|         *(.rela.init)
 | |
|         *(.rel.text .rel.text.* .rel.gnu.linkonce.t.*)
 | |
|         *(.rela.text .rela.text.* .rela.gnu.linkonce.t.*)
 | |
|         *(.rel.fini)
 | |
|         *(.rela.fini)
 | |
|         *(.rel.rodata .rel.rodata.* .rel.gnu.linkonce.r.*)
 | |
|         *(.rela.rodata .rela.rodata.* .rela.gnu.linkonce.r.*)
 | |
|         *(.rel.data .rel.data.* .rel.gnu.linkonce.d.*)
 | |
|         *(.rela.data .rela.data.* .rela.gnu.linkonce.d.*)
 | |
|         *(.rel.tdata .rel.tdata.* .rel.gnu.linkonce.td.*)
 | |
|         *(.rela.tdata .rela.tdata.* .rela.gnu.linkonce.td.*)
 | |
|         *(.rel.tbss .rel.tbss.* .rel.gnu.linkonce.tb.*)
 | |
|         *(.rela.tbss .rela.tbss.* .rela.gnu.linkonce.tb.*)
 | |
|         *(.rel.ctors)
 | |
|         *(.rela.ctors)
 | |
|         *(.rel.dtors)
 | |
|         *(.rela.dtors)
 | |
|         *(.rel.got)
 | |
|         *(.rela.got)
 | |
|         *(.rel.sdata .rel.sdata.* .rel.gnu.linkonce.s.*)
 | |
|         *(.rela.sdata .rela.sdata.* .rela.gnu.linkonce.s.*)
 | |
|         *(.rel.sbss .rel.sbss.* .rel.gnu.linkonce.sb.*)
 | |
|         *(.rela.sbss .rela.sbss.* .rela.gnu.linkonce.sb.*)
 | |
|         *(.rel.sdata2 .rel.sdata2.* .rel.gnu.linkonce.s2.*)
 | |
|         *(.rela.sdata2 .rela.sdata2.* .rela.gnu.linkonce.s2.*)
 | |
|         *(.rel.sbss2 .rel.sbss2.* .rel.gnu.linkonce.sb2.*)
 | |
|         *(.rela.sbss2 .rela.sbss2.* .rela.gnu.linkonce.sb2.*)
 | |
|         *(.rel.bss .rel.bss.* .rel.gnu.linkonce.b.*)
 | |
|         *(.rela.bss .rela.bss.* .rela.gnu.linkonce.b.*)
 | |
|         *(.rel.plt)
 | |
|         *(.rela.plt)
 | |
|         *(.rel.dyn)
 | |
| 
 | |
|         KEEP (*(.init))
 | |
|         *(.plt)
 | |
|         *(.text .stub .text.* .gnu.linkonce.t.*)
 | |
| 
 | |
|         /* .gnu.warning sections are handled specially by elf32.em.  */
 | |
| 
 | |
|         *(.gnu.warning.*)
 | |
|         KEEP (*(.fini))
 | |
|         PROVIDE (__etext = ABSOLUTE(.));
 | |
|         PROVIDE (_etext = ABSOLUTE(.));
 | |
|         PROVIDE (etext = ABSOLUTE(.));
 | |
| 
 | |
|         *(.eh_frame_hdr)
 | |
|         /* Ensure the __preinit_array_start label is properly aligned.  We
 | |
|            could instead move the label definition inside the section, but
 | |
|            the linker would then create the section even if it turns out to
 | |
|            be empty, which isn't pretty.  */
 | |
|         . = ALIGN(4);
 | |
|         PROVIDE (__preinit_array_start = ABSOLUTE(.));
 | |
|         *(.preinit_array)
 | |
|         PROVIDE (__preinit_array_end = ABSOLUTE(.));
 | |
|         PROVIDE (__init_array_start = ABSOLUTE(.));
 | |
|         *(.init_array)
 | |
|         PROVIDE (__init_array_end = ABSOLUTE(.));
 | |
|         PROVIDE (__fini_array_start = ABSOLUTE(.));
 | |
|         *(.fini_array)
 | |
|         PROVIDE (__fini_array_end = ABSOLUTE(.));
 | |
|         SORT(CONSTRUCTORS)
 | |
|         KEEP (*(.eh_frame))
 | |
|         *(.gcc_except_table .gcc_except_table.*)
 | |
|         *(.dynamic)
 | |
|         PROVIDE (__CTOR_LIST__ = ABSOLUTE(.));
 | |
|         KEEP (*(.ctors))
 | |
|         KEEP (*(SORT(.ctors.*)))
 | |
|         PROVIDE (__CTOR_END__ = ABSOLUTE(.));
 | |
|         PROVIDE (__DTOR_LIST__ = ABSOLUTE(.));
 | |
|         KEEP (*(.dtors))
 | |
|         KEEP (*(SORT(.dtors.*)))
 | |
|         PROVIDE (__DTOR_END__ = ABSOLUTE(.));
 | |
|         KEEP (*(.jcr))
 | |
|         . = ALIGN(4);
 | |
|     } > onchip_memory2_0 = 0x3a880100 /* NOP instruction (always in big-endian byte ordering) */
 | |
| 
 | |
|     .rodata :
 | |
|     {
 | |
|         PROVIDE (__ram_rodata_start = ABSOLUTE(.));
 | |
|         . = ALIGN(4);
 | |
|         *(.rodata .rodata.* .gnu.linkonce.r.*)
 | |
|         *(.rodata1)
 | |
|         . = ALIGN(4);
 | |
|         PROVIDE (__ram_rodata_end = ABSOLUTE(.));
 | |
|     } > onchip_memory2_0
 | |
| 
 | |
|     PROVIDE (__flash_rodata_start = LOADADDR(.rodata));
 | |
| 
 | |
|     /*
 | |
|      *
 | |
|      * This section's LMA is set to the .text region.
 | |
|      * crt0 will copy to this section's specified mapped region virtual memory address (VMA)
 | |
|      *
 | |
|      * .rwdata region equals the .text region, and is set to be loaded into .text region.
 | |
|      * This requires two copies of .rwdata in the .text region. One read writable at VMA.
 | |
|      * and one read-only at LMA. crt0 will copy from LMA to VMA on reset
 | |
|      *
 | |
|      */
 | |
| 
 | |
|     .rwdata LOADADDR (.rodata) + SIZEOF (.rodata) : AT ( LOADADDR (.rodata) + SIZEOF (.rodata)+ SIZEOF (.rwdata) )
 | |
|     {
 | |
|         PROVIDE (__ram_rwdata_start = ABSOLUTE(.));
 | |
|         . = ALIGN(4);
 | |
|         *(.got.plt) *(.got)
 | |
|         *(.data1)
 | |
|         *(.data .data.* .gnu.linkonce.d.*)
 | |
| 
 | |
|         _gp = ABSOLUTE(. + 0x8000);
 | |
|         PROVIDE(gp = _gp);
 | |
| 
 | |
|         *(.rwdata .rwdata.*)
 | |
|         *(.sdata .sdata.* .gnu.linkonce.s.*)
 | |
|         *(.sdata2 .sdata2.* .gnu.linkonce.s2.*)
 | |
| 
 | |
|         . = ALIGN(4);
 | |
|         _edata = ABSOLUTE(.);
 | |
|         PROVIDE (edata = ABSOLUTE(.));
 | |
|         PROVIDE (__ram_rwdata_end = ABSOLUTE(.));
 | |
|     } > onchip_memory2_0
 | |
| 
 | |
|     PROVIDE (__flash_rwdata_start = LOADADDR(.rwdata));
 | |
| 
 | |
|     /*
 | |
|      *
 | |
|      * This section's LMA is set to the .text region.
 | |
|      * crt0 will copy to this section's specified mapped region virtual memory address (VMA)
 | |
|      *
 | |
|      */
 | |
| 
 | |
|     .bss LOADADDR (.rwdata) + SIZEOF (.rwdata) : AT ( LOADADDR (.rwdata) + SIZEOF (.rwdata) )
 | |
|     {
 | |
|         __bss_start = ABSOLUTE(.);
 | |
|         PROVIDE (__sbss_start = ABSOLUTE(.));
 | |
|         PROVIDE (___sbss_start = ABSOLUTE(.));
 | |
| 
 | |
|         *(.dynsbss)
 | |
|         *(.sbss .sbss.* .gnu.linkonce.sb.*)
 | |
|         *(.sbss2 .sbss2.* .gnu.linkonce.sb2.*)
 | |
|         *(.scommon)
 | |
| 
 | |
|         PROVIDE (__sbss_end = ABSOLUTE(.));
 | |
|         PROVIDE (___sbss_end = ABSOLUTE(.));
 | |
| 
 | |
|         *(.dynbss)
 | |
|         *(.bss .bss.* .gnu.linkonce.b.*)
 | |
|         *(COMMON)
 | |
| 
 | |
|         . = ALIGN(4);
 | |
|         __bss_end = ABSOLUTE(.);
 | |
|     } > onchip_memory2_0
 | |
| 
 | |
|     /*
 | |
|      *
 | |
|      * One output section mapped to the associated memory device for each of
 | |
|      * the available memory devices. These are not used by default, but can
 | |
|      * be used by user applications by using the .section directive.
 | |
|      *
 | |
|      * The output section used for the heap is treated in a special way,
 | |
|      * i.e. the symbols "end" and "_end" are added to point to the heap start.
 | |
|      *
 | |
|      * Because alt_load() is enabled, these sections have
 | |
|      * their LMA set to be loaded into the .text memory region.
 | |
|      * However, the alt_load() code will NOT automatically copy
 | |
|      * these sections into their mapped memory region.
 | |
|      *
 | |
|      */
 | |
| 
 | |
|     /*
 | |
|      *
 | |
|      * This section's LMA is set to the .text region.
 | |
|      * crt0 will copy to this section's specified mapped region virtual memory address (VMA)
 | |
|      *
 | |
|      */
 | |
| 
 | |
|     .onchip_memory2_0 LOADADDR (.bss) + SIZEOF (.bss) : AT ( LOADADDR (.bss) + SIZEOF (.bss) )
 | |
|     {
 | |
|         PROVIDE (_alt_partition_onchip_memory2_0_start = ABSOLUTE(.));
 | |
|         *(.onchip_memory2_0 .onchip_memory2_0. onchip_memory2_0.*)
 | |
|         . = ALIGN(4);
 | |
|         PROVIDE (_alt_partition_onchip_memory2_0_end = ABSOLUTE(.));
 | |
|         _end = ABSOLUTE(.);
 | |
|         end = ABSOLUTE(.);
 | |
|         __alt_stack_base = ABSOLUTE(.);
 | |
|     } > onchip_memory2_0
 | |
| 
 | |
|     PROVIDE (_alt_partition_onchip_memory2_0_load_addr = LOADADDR(.onchip_memory2_0));
 | |
| 
 | |
|     /*
 | |
|      *
 | |
|      * This section's LMA is set to the .text region.
 | |
|      * crt0 will copy to this section's specified mapped region virtual memory address (VMA)
 | |
|      *
 | |
|      */
 | |
| 
 | |
|     .epcq_controller_0_avl_mem : AT ( LOADADDR (.onchip_memory2_0) + SIZEOF (.onchip_memory2_0) )
 | |
|     {
 | |
|         PROVIDE (_alt_partition_epcq_controller_0_avl_mem_start = ABSOLUTE(.));
 | |
|         *(.epcq_controller_0_avl_mem .epcq_controller_0_avl_mem. epcq_controller_0_avl_mem.*)
 | |
|         . = ALIGN(4);
 | |
|         PROVIDE (_alt_partition_epcq_controller_0_avl_mem_end = ABSOLUTE(.));
 | |
|     } > epcq_controller_0_avl_mem
 | |
| 
 | |
|     PROVIDE (_alt_partition_epcq_controller_0_avl_mem_load_addr = LOADADDR(.epcq_controller_0_avl_mem));
 | |
| 
 | |
|     /*
 | |
|      * Stabs debugging sections.
 | |
|      *
 | |
|      */
 | |
| 
 | |
|     .stab          0 : { *(.stab) }
 | |
|     .stabstr       0 : { *(.stabstr) }
 | |
|     .stab.excl     0 : { *(.stab.excl) }
 | |
|     .stab.exclstr  0 : { *(.stab.exclstr) }
 | |
|     .stab.index    0 : { *(.stab.index) }
 | |
|     .stab.indexstr 0 : { *(.stab.indexstr) }
 | |
|     .comment       0 : { *(.comment) }
 | |
|     /* DWARF debug sections.
 | |
|        Symbols in the DWARF debugging sections are relative to the beginning
 | |
|        of the section so we begin them at 0.  */
 | |
|     /* DWARF 1 */
 | |
|     .debug          0 : { *(.debug) }
 | |
|     .line           0 : { *(.line) }
 | |
|     /* GNU DWARF 1 extensions */
 | |
|     .debug_srcinfo  0 : { *(.debug_srcinfo) }
 | |
|     .debug_sfnames  0 : { *(.debug_sfnames) }
 | |
|     /* DWARF 1.1 and DWARF 2 */
 | |
|     .debug_aranges  0 : { *(.debug_aranges) }
 | |
|     .debug_pubnames 0 : { *(.debug_pubnames) }
 | |
|     /* DWARF 2 */
 | |
|     .debug_info     0 : { *(.debug_info .gnu.linkonce.wi.*) }
 | |
|     .debug_abbrev   0 : { *(.debug_abbrev) }
 | |
|     .debug_line     0 : { *(.debug_line) }
 | |
|     .debug_frame    0 : { *(.debug_frame) }
 | |
|     .debug_str      0 : { *(.debug_str) }
 | |
|     .debug_loc      0 : { *(.debug_loc) }
 | |
|     .debug_macinfo  0 : { *(.debug_macinfo) }
 | |
|     /* SGI/MIPS DWARF 2 extensions */
 | |
|     .debug_weaknames 0 : { *(.debug_weaknames) }
 | |
|     .debug_funcnames 0 : { *(.debug_funcnames) }
 | |
|     .debug_typenames 0 : { *(.debug_typenames) }
 | |
|     .debug_varnames  0 : { *(.debug_varnames) }
 | |
| 
 | |
|     /* Altera debug extensions */
 | |
|     .debug_alt_sim_info 0 : { *(.debug_alt_sim_info) }
 | |
| }
 | |
| 
 | |
| /* provide a pointer for the stack */
 | |
| 
 | |
| /*
 | |
|  * Don't override this, override the __alt_stack_* symbols instead.
 | |
|  */
 | |
| __alt_data_end = 0x19000;
 | |
| 
 | |
| /*
 | |
|  * The next two symbols define the location of the default stack.  You can
 | |
|  * override them to move the stack to a different memory.
 | |
|  */
 | |
| PROVIDE( __alt_stack_pointer = __alt_data_end );
 | |
| PROVIDE( __alt_stack_limit   = __alt_stack_base );
 | |
| 
 | |
| /*
 | |
|  * This symbol controls where the start of the heap is.  If the stack is
 | |
|  * contiguous with the heap then the stack will contract as memory is
 | |
|  * allocated to the heap.
 | |
|  * Override this symbol to put the heap in a different memory.
 | |
|  */
 | |
| PROVIDE( __alt_heap_start    = end );
 | |
| PROVIDE( __alt_heap_limit    = 0x19000 );
 | 
