Home | History | Annotate | Line # | Download | only in conf
kern.ldscript revision 1.6
      1  1.6  uebayasi /*	$NetBSD: kern.ldscript,v 1.6 2015/08/20 07:00:49 uebayasi Exp $	*/
      2  1.1        pk 
      3  1.1        pk /*
      4  1.1        pk  * Kernel linker script for NetBSD/sparc.  This script is based on
      5  1.1        pk  * elf32_sparc.xn, but puts _etext after all of the read-only sections.
      6  1.1        pk  */
      7  1.1        pk 
      8  1.1        pk OUTPUT_FORMAT("elf32-sparc", "elf32-sparc",
      9  1.1        pk 	      "elf32-sparc")
     10  1.1        pk OUTPUT_ARCH(sparc)
     11  1.1        pk ENTRY(_start)
     12  1.1        pk SEARCH_DIR(/usr/lib);
     13  1.1        pk /* Do we need any of these for elf?
     14  1.1        pk    __DYNAMIC = 0;    */
     15  1.1        pk SECTIONS
     16  1.1        pk {
     17  1.1        pk   /* Read-only sections, merged into text segment: */
     18  1.4    martin   . = 0x10000 + SIZEOF_HEADERS;
     19  1.1        pk   .interp     : { *(.interp) 	}
     20  1.1        pk   .hash          : { *(.hash)		}
     21  1.1        pk   .dynsym        : { *(.dynsym)		}
     22  1.1        pk   .dynstr        : { *(.dynstr)		}
     23  1.1        pk   .gnu.version   : { *(.gnu.version)	}
     24  1.1        pk   .gnu.version_d   : { *(.gnu.version_d)	}
     25  1.1        pk   .gnu.version_r   : { *(.gnu.version_r)	}
     26  1.1        pk   .rel.text      :
     27  1.1        pk     { *(.rel.text) *(.rel.gnu.linkonce.t*) }
     28  1.1        pk   .rela.text     :
     29  1.1        pk     { *(.rela.text) *(.rela.gnu.linkonce.t*) }
     30  1.1        pk   .rel.data      :
     31  1.1        pk     { *(.rel.data) *(.rel.gnu.linkonce.d*) }
     32  1.1        pk   .rela.data     :
     33  1.1        pk     { *(.rela.data) *(.rela.gnu.linkonce.d*) }
     34  1.1        pk   .rel.rodata    :
     35  1.1        pk     { *(.rel.rodata) *(.rel.gnu.linkonce.r*) }
     36  1.1        pk   .rela.rodata   :
     37  1.1        pk     { *(.rela.rodata) *(.rela.gnu.linkonce.r*) }
     38  1.1        pk   .rel.got       : { *(.rel.got)		}
     39  1.1        pk   .rela.got      : { *(.rela.got)		}
     40  1.1        pk   .rel.ctors     : { *(.rel.ctors)	}
     41  1.1        pk   .rela.ctors    : { *(.rela.ctors)	}
     42  1.1        pk   .rel.dtors     : { *(.rel.dtors)	}
     43  1.1        pk   .rela.dtors    : { *(.rela.dtors)	}
     44  1.1        pk   .rel.init      : { *(.rel.init)	}
     45  1.1        pk   .rela.init     : { *(.rela.init)	}
     46  1.1        pk   .rel.fini      : { *(.rel.fini)	}
     47  1.1        pk   .rela.fini     : { *(.rela.fini)	}
     48  1.1        pk   .rel.bss       : { *(.rel.bss)		}
     49  1.1        pk   .rela.bss      : { *(.rela.bss)		}
     50  1.1        pk   .rel.plt       : { *(.rel.plt)		}
     51  1.1        pk   .rela.plt      : { *(.rela.plt)		}
     52  1.1        pk   .init          : { *(.init)	} =0
     53  1.1        pk   .text      :
     54  1.1        pk   {
     55  1.1        pk     *(.text)
     56  1.1        pk     *(.stub)
     57  1.1        pk     /* .gnu.warning sections are handled specially by elf32.em.  */
     58  1.1        pk     *(.gnu.warning)
     59  1.1        pk     *(.gnu.linkonce.t*)
     60  1.1        pk   } =0
     61  1.1        pk   .fini      : { *(.fini)    } =0
     62  1.1        pk   .rodata    : { *(.rodata) *(.gnu.linkonce.r*) }
     63  1.1        pk   .rodata1   : { *(.rodata1) }
     64  1.1        pk   _etext = .;
     65  1.1        pk   PROVIDE (etext = .);
     66  1.1        pk   /* Adjust the address for the data segment.  We want to adjust up to
     67  1.1        pk      the same address within the page on the next page up.  */
     68  1.1        pk   . = ALIGN(0x10000) + (. & (0x10000 - 1));
     69  1.2        pk   kernel_data_start = .;
     70  1.1        pk   .data    :
     71  1.1        pk   {
     72  1.1        pk     *(.data)
     73  1.1        pk     *(.gnu.linkonce.d*)
     74  1.1        pk     CONSTRUCTORS
     75  1.1        pk   }
     76  1.1        pk   .data1   : { *(.data1) }
     77  1.1        pk   .ctors         :
     78  1.1        pk   {
     79  1.1        pk     *(.ctors)
     80  1.1        pk   }
     81  1.1        pk   .dtors         :
     82  1.1        pk   {
     83  1.1        pk     *(.dtors)
     84  1.1        pk   }
     85  1.1        pk   .plt      : { *(.plt)	}
     86  1.1        pk   .got           : { *(.got.plt) *(.got) }
     87  1.1        pk   .dynamic       : { *(.dynamic) }
     88  1.1        pk   /* We want the small data sections together, so single-instruction offsets
     89  1.1        pk      can access them all, and initialized data all before uninitialized, so
     90  1.1        pk      we can shorten the on-disk segment size.  */
     91  1.1        pk   .sdata     : { *(.sdata) }
     92  1.1        pk   _edata  =  .;
     93  1.1        pk   PROVIDE (edata = .);
     94  1.1        pk   __bss_start = .;
     95  1.1        pk   .sbss      : { *(.sbss) *(.scommon) }
     96  1.1        pk   .bss       :
     97  1.1        pk   {
     98  1.6  uebayasi     *(.dynbss)
     99  1.6  uebayasi     *(.bss)
    100  1.6  uebayasi     *(COMMON)
    101  1.1        pk   }
    102  1.1        pk   . = ALIGN(32 / 8);
    103  1.1        pk   _end = . ;
    104  1.1        pk   PROVIDE (end = .);
    105  1.1        pk   /* Stabs debugging sections.  */
    106  1.1        pk   .stab 0 : { *(.stab) }
    107  1.1        pk   .stabstr 0 : { *(.stabstr) }
    108  1.1        pk   .stab.excl 0 : { *(.stab.excl) }
    109  1.1        pk   .stab.exclstr 0 : { *(.stab.exclstr) }
    110  1.1        pk   .stab.index 0 : { *(.stab.index) }
    111  1.1        pk   .stab.indexstr 0 : { *(.stab.indexstr) }
    112  1.1        pk   .comment 0 : { *(.comment) }
    113  1.1        pk   /* DWARF debug sections.
    114  1.1        pk      Symbols in the DWARF debugging sections are relative to the beginning
    115  1.1        pk      of the section so we begin them at 0.  */
    116  1.1        pk   /* DWARF 1 */
    117  1.1        pk   .debug          0 : { *(.debug) }
    118  1.1        pk   .line           0 : { *(.line) }
    119  1.1        pk   /* GNU DWARF 1 extensions */
    120  1.1        pk   .debug_srcinfo  0 : { *(.debug_srcinfo) }
    121  1.1        pk   .debug_sfnames  0 : { *(.debug_sfnames) }
    122  1.1        pk   /* DWARF 1.1 and DWARF 2 */
    123  1.1        pk   .debug_aranges  0 : { *(.debug_aranges) }
    124  1.1        pk   .debug_pubnames 0 : { *(.debug_pubnames) }
    125  1.1        pk   /* DWARF 2 */
    126  1.1        pk   .debug_info     0 : { *(.debug_info) }
    127  1.1        pk   .debug_abbrev   0 : { *(.debug_abbrev) }
    128  1.1        pk   .debug_line     0 : { *(.debug_line) }
    129  1.1        pk   .debug_frame    0 : { *(.debug_frame) }
    130  1.1        pk   .debug_str      0 : { *(.debug_str) }
    131  1.1        pk   .debug_loc      0 : { *(.debug_loc) }
    132  1.1        pk   .debug_macinfo  0 : { *(.debug_macinfo) }
    133  1.1        pk   /* SGI/MIPS DWARF 2 extensions */
    134  1.1        pk   .debug_weaknames 0 : { *(.debug_weaknames) }
    135  1.1        pk   .debug_funcnames 0 : { *(.debug_funcnames) }
    136  1.1        pk   .debug_typenames 0 : { *(.debug_typenames) }
    137  1.1        pk   .debug_varnames  0 : { *(.debug_varnames) }
    138  1.1        pk   /* These must appear regardless of  .  */
    139  1.1        pk }
    140