* m68hc11/sim-valid-m68hc12.ld, mcore/elf-cmb.ld, mips/cfe.ld, * mips/ddb-kseg0.ld, mips/ddb.ld, mips/dve.ld, mips/idt.ld, * mips/idt32.ld, mips/idt64.ld, mips/jmr3904app-java.ld, * mips/jmr3904app.ld, mips/jmr3904dram-java.ld, mips/jmr3904dram.ld, * mips/nullmon.ld, mips/pmon.ld, mn10200/eval.ld, mn10200/sim.ld, * mn10300/asb2303.ld, mn10300/asb2305.ld, mn10300/eval.ld, * mn10300/sim.ld, rs6000/ads.ld, rs6000/mbx.ld, rs6000/yellowknife.ld, * sh/sh1lcevb.ld, sh/sh2lcevb.ld, sh/sh3bb.ld, sh/sh3lcevb.ld, * sparc/elfsim.ld, sparc/ex930.ld, sparc/ex931.ld, sparc/ex934.ld, * sparc/sparc86x.ld, xstormy16/eva_app.ld, xstormy16/eva_stub.ld, * xstormy16/sim_high.ld, xstormy16/sim_rom.ld: Add .debug_ranges section.
		
			
				
	
	
		
			192 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			192 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| OUTPUT_FORMAT("elf32-mcore-big", "elf32-mcore-big",
 | |
| 	      "elf32-mcore-little")
 | |
| OUTPUT_ARCH(mcore)
 | |
| GROUP(-lc -lcmb -lgcc)
 | |
| ENTRY(_start)
 | |
| /* Do we need any of these for elf?
 | |
|    __DYNAMIC = 0;    */
 | |
| SECTIONS
 | |
| {
 | |
|   /* Read-only sections, merged into text segment: */
 | |
|   . = 0x2f000000;
 | |
|   .interp     : { *(.interp) 	}
 | |
|   .hash          : { *(.hash)		}
 | |
|   .dynsym        : { *(.dynsym)		}
 | |
|   .dynstr        : { *(.dynstr)		}
 | |
|   .gnu.version   : { *(.gnu.version)	}
 | |
|   .gnu.version_d   : { *(.gnu.version_d)	}
 | |
|   .gnu.version_r   : { *(.gnu.version_r)	}
 | |
|   .rel.text      :
 | |
|     {
 | |
|       *(.rel.text)
 | |
|       *(.rel.text.*)
 | |
|       *(.rel.gnu.linkonce.t*)
 | |
|     }
 | |
|   .rela.text     :
 | |
|     {
 | |
|       *(.rela.text)
 | |
|       *(.rela.text.*)
 | |
|       *(.rela.gnu.linkonce.t*)
 | |
|     }
 | |
|   .rel.data      :
 | |
|     {
 | |
|       *(.rel.data)
 | |
|       *(.rel.data.*)
 | |
|       *(.rel.gnu.linkonce.d*)
 | |
|     }
 | |
|   .rela.data     :
 | |
|     {
 | |
|       *(.rela.data)
 | |
|       *(.rela.data.*)
 | |
|       *(.rela.gnu.linkonce.d*)
 | |
|     }
 | |
|   .rel.rodata    :
 | |
|     {
 | |
|       *(.rel.rodata)
 | |
|       *(.rel.rodata.*)
 | |
|       *(.rel.gnu.linkonce.r*)
 | |
|     }
 | |
|   .rela.rodata   :
 | |
|     {
 | |
|       *(.rela.rodata)
 | |
|       *(.rela.rodata.*)
 | |
|       *(.rela.gnu.linkonce.r*)
 | |
|     }
 | |
|   .rel.got       : { *(.rel.got)		}
 | |
|   .rela.got      : { *(.rela.got)		}
 | |
|   .rel.ctors     : { *(.rel.ctors)	}
 | |
|   .rela.ctors    : { *(.rela.ctors)	}
 | |
|   .rel.dtors     : { *(.rel.dtors)	}
 | |
|   .rela.dtors    : { *(.rela.dtors)	}
 | |
|   .rel.init      : { *(.rel.init)	}
 | |
|   .rela.init     : { *(.rela.init)	}
 | |
|   .rel.fini      : { *(.rel.fini)	}
 | |
|   .rela.fini     : { *(.rela.fini)	}
 | |
|   .rel.bss       : { *(.rel.bss)		}
 | |
|   .rela.bss      : { *(.rela.bss)		}
 | |
|   .rel.plt       : { *(.rel.plt)		}
 | |
|   .rela.plt      : { *(.rela.plt)		}
 | |
|   .init          : { KEEP (*(.init))	} =0x0e0e
 | |
|   .plt      : { *(.plt)	}
 | |
|   .text      :
 | |
|   {
 | |
|     *(.text)
 | |
|     *(.text.*)
 | |
|     *(.stub)
 | |
|     /* .gnu.warning sections are handled specially by elf32.em.  */
 | |
|     *(.gnu.warning)
 | |
|     *(.gnu.linkonce.t*)
 | |
|   } =0x0e0e
 | |
|   _etext = .;
 | |
|   PROVIDE (etext = .);
 | |
|   .fini      : { KEEP (*(.fini))		} =0x0e0e
 | |
|   .rodata    :
 | |
|   {
 | |
|     *(.rodata)
 | |
|     *(.rodata.*)
 | |
|     *(.gnu.linkonce.r*)
 | |
|   }
 | |
|   .rodata1   : { *(.rodata1) }
 | |
|   /* Adjust the address for the data segment.  We want to adjust up to
 | |
|      the same address within the page on the next page up.  */
 | |
|   . = ALIGN(0x1000) + (. & (0x1000 - 1));
 | |
|   .data    :
 | |
|   {
 | |
|     *(.data)
 | |
|     *(.data.*)
 | |
|     *(.gnu.linkonce.d*)
 | |
|     SORT(CONSTRUCTORS)
 | |
|   }
 | |
|   .data1   : { *(.data1) }
 | |
|   .eh_frame : { *(.eh_frame) }
 | |
|   .gcc_except_table : { *(.gcc_except_table) }
 | |
|   .ctors   : 
 | |
|   {
 | |
|     /* gcc uses crtbegin.o to find the start of
 | |
|        the constructors, so we make sure it is
 | |
|        first.  Because this is a wildcard, it
 | |
|        doesn't matter if the user does not
 | |
|        actually link against crtbegin.o; the
 | |
|        linker won't look for a file to match a
 | |
|        wildcard.  The wildcard also means that it
 | |
|        doesn't matter which directory crtbegin.o
 | |
|        is in.  */
 | |
|     KEEP (*crtbegin.o(.ctors))
 | |
|     /* We don't want to include the .ctor section from
 | |
|        from the crtend.o file until after the sorted ctors.
 | |
|        The .ctor section from the crtend file contains the
 | |
|        end of ctors marker and it must be last */
 | |
|     KEEP (*(EXCLUDE_FILE (*crtend.o) .ctors))
 | |
|     KEEP (*(SORT(.ctors.*)))
 | |
|     KEEP (*(.ctors))
 | |
|   }
 | |
|    .dtors         :
 | |
|   {
 | |
|     KEEP (*crtbegin.o(.dtors))
 | |
|     KEEP (*(EXCLUDE_FILE (*crtend.o) .dtors))
 | |
|     KEEP (*(SORT(.dtors.*)))
 | |
|     KEEP (*(.dtors))
 | |
|   }
 | |
|   .got           : { *(.got.plt) *(.got) }
 | |
|   .dynamic       : { *(.dynamic) }
 | |
|   /* We want the small data sections together, so single-instruction offsets
 | |
|      can access them all, and initialized data all before uninitialized, so
 | |
|      we can shorten the on-disk segment size.  */
 | |
|   .sdata     : { *(.sdata) *(.sdata.*) }
 | |
|   _edata  =  .;
 | |
|   PROVIDE (edata = .);
 | |
|   __bss_start = .;
 | |
|   __bss_start__ = . ;
 | |
|   .sbss      : { *(.sbss) *(.scommon) }
 | |
|   .bss       :
 | |
|   {
 | |
|    *(.dynbss)
 | |
|    *(.bss)
 | |
|    *(COMMON)
 | |
|    /* Align here to ensure that the .bss section occupies space up to
 | |
|       _end.  Align after .bss to ensure correct alignment even if the
 | |
|       .bss section disappears because there are no input sections.  */
 | |
|    . = ALIGN(32 / 8);
 | |
|   }
 | |
|   . = ALIGN(32 / 8);
 | |
|   _end = . ;
 | |
|   __bss_end__ = . ;
 | |
|   PROVIDE (end = .);
 | |
|   /* 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) }
 | |
|   .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) }
 | |
|   .debug_ranges   0 : { *(.debug_ranges) }
 | |
|   /* 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) }
 | |
|   .stack 0x2f0ffffc : { _stack = .; *(.stack) }
 | |
|   /* These must appear regardless of  .  */
 | |
| }
 |