xref: /freebsd/sys/conf/ldscript.powerpc64 (revision 3e76d05231b0aa77d922bdbc9abf62d9747a91ab)
166c80959SBaptiste DaroussinOUTPUT_FORMAT("elf64-powerpc-freebsd", "elf64-powerpc-freebsd",
266c80959SBaptiste Daroussin	      "elf64-powerpc-freebsd")
3618abe8bSAndreas ToblerOUTPUT_ARCH(powerpc:common64)
4060d347dSNathan WhitehornENTRY(__start)
5060d347dSNathan WhitehornSEARCH_DIR(/usr/lib);
6060d347dSNathan WhitehornPROVIDE (__stack = 0);
7484717a4SJustin HibbitsPHDRS
8484717a4SJustin Hibbits{
99411e24dSBrandon Bergren	kernel PT_LOAD;
10484717a4SJustin Hibbits	dynamic PT_DYNAMIC;
11484717a4SJustin Hibbits}
12060d347dSNathan WhitehornSECTIONS
13060d347dSNathan Whitehorn{
14060d347dSNathan Whitehorn
1570f65499SNathan Whitehorn  /* Low-address wrapper for bootloaders (kexec/kboot) that can't parse ELF */
1670f65499SNathan Whitehorn  . = kernbase - 0x100;
179411e24dSBrandon Bergren  .kboot : { *(.text.kboot) } :kernel
1870f65499SNathan Whitehorn
1970f65499SNathan Whitehorn  /* Read-only sections, merged into text segment: */
2025449e73SNathan Whitehorn  . = kernbase;
217cc0ad62SNathan Whitehorn  PROVIDE (begin = .);
22060d347dSNathan Whitehorn
23060d347dSNathan Whitehorn  .text      :
24060d347dSNathan Whitehorn  {
25484717a4SJustin Hibbits    *(.glink)
26060d347dSNathan Whitehorn    *(.text)
27060d347dSNathan Whitehorn    *(.stub)
28060d347dSNathan Whitehorn    /* .gnu.warning sections are handled specially by elf32.em.  */
29060d347dSNathan Whitehorn    *(.gnu.warning)
30060d347dSNathan Whitehorn    *(.gnu.linkonce.t*)
31060d347dSNathan Whitehorn  } =0
32060d347dSNathan Whitehorn  _etext = .;
33060d347dSNathan Whitehorn  PROVIDE (etext = .);
34060d347dSNathan Whitehorn
3525449e73SNathan Whitehorn  /* Do not emit PT_INTERP section, which confuses some loaders (kexec-lite) */
3625449e73SNathan Whitehorn  /DISCARD/   : { *(.interp)	}
3725449e73SNathan Whitehorn
38060d347dSNathan Whitehorn  .hash          : { *(.hash)		}
39060d347dSNathan Whitehorn  .dynsym        : { *(.dynsym)		}
40060d347dSNathan Whitehorn  .dynstr        : { *(.dynstr)		}
41060d347dSNathan Whitehorn  .gnu.version   : { *(.gnu.version)	}
42060d347dSNathan Whitehorn  .gnu.version_d   : { *(.gnu.version_d)	}
43060d347dSNathan Whitehorn  .gnu.version_r   : { *(.gnu.version_r)	}
4474cd06b4SEd Maste  .note.gnu.build-id : {
4574cd06b4SEd Maste    PROVIDE (__build_id_start = .);
4674cd06b4SEd Maste    *(.note.gnu.build-id)
4774cd06b4SEd Maste    PROVIDE (__build_id_end = .);
4874cd06b4SEd Maste  }
4930dc2aebSBrandon Bergren
5030dc2aebSBrandon Bergren  /* Do not emit any additional notes. */
5130dc2aebSBrandon Bergren  /DISCARD/   : { *(.note.*)	}
5230dc2aebSBrandon Bergren
53060d347dSNathan Whitehorn  .rela.text     :
54060d347dSNathan Whitehorn    { *(.rela.text) *(.rela.gnu.linkonce.t*) }
55060d347dSNathan Whitehorn  .rela.data     :
56060d347dSNathan Whitehorn    { *(.rela.data) *(.rela.gnu.linkonce.d*) }
57060d347dSNathan Whitehorn  .rela.rodata   :
58060d347dSNathan Whitehorn    { *(.rela.rodata) *(.rela.gnu.linkonce.r*) }
59060d347dSNathan Whitehorn  .rela.got      : { *(.rela.got)		}
60060d347dSNathan Whitehorn  .rela.got1     : { *(.rela.got1)		}
61060d347dSNathan Whitehorn  .rela.got2     : { *(.rela.got2)		}
62060d347dSNathan Whitehorn  .rela.ctors    : { *(.rela.ctors)	}
63060d347dSNathan Whitehorn  .rela.dtors    : { *(.rela.dtors)	}
64060d347dSNathan Whitehorn  .rela.init     : { *(.rela.init)	}
65060d347dSNathan Whitehorn  .rela.fini     : { *(.rela.fini)	}
66060d347dSNathan Whitehorn  .rela.bss      : { *(.rela.bss)		}
67060d347dSNathan Whitehorn  .rela.plt      : { *(.rela.plt)		}
68060d347dSNathan Whitehorn  .rela.sdata    : { *(.rela.sdata)		}
69060d347dSNathan Whitehorn  .rela.sbss     : { *(.rela.sbss)		}
70060d347dSNathan Whitehorn  .rela.sdata2   : { *(.rela.sdata2)		}
71060d347dSNathan Whitehorn  .rela.sbss2    : { *(.rela.sbss2)		}
72060d347dSNathan Whitehorn
73060d347dSNathan Whitehorn  .init      : { *(.init)    } =0
74060d347dSNathan Whitehorn  .fini      : { *(.fini)    } =0
75060d347dSNathan Whitehorn  .rodata    : { *(.rodata) *(.gnu.linkonce.r*) }
76060d347dSNathan Whitehorn  .rodata1   : { *(.rodata1) }
77060d347dSNathan Whitehorn  .sdata2    : { *(.sdata2)  }
78060d347dSNathan Whitehorn  .sbss2     : { *(.sbss2)   }
79060d347dSNathan Whitehorn  /* Adjust the address for the data segment to the next page up. */
80618abe8bSAndreas Tobler  . = ALIGN(4096);
8129064656SJustin Hibbits  .data.read_frequently :
8229064656SJustin Hibbits  {
8329064656SJustin Hibbits    *(SORT_BY_ALIGNMENT(.data.read_frequently))
8429064656SJustin Hibbits  }
8529064656SJustin Hibbits  .data.read_mostly :
8629064656SJustin Hibbits  {
8729064656SJustin Hibbits    *(.data.read_mostly)
8829064656SJustin Hibbits  }
8929064656SJustin Hibbits  . = ALIGN(128);
9029064656SJustin Hibbits  .data.exclusive_cache_line :
9129064656SJustin Hibbits  {
9229064656SJustin Hibbits    *(.data.exclusive_cache_line)
9329064656SJustin Hibbits  }
9429064656SJustin Hibbits  . = ALIGN(128);
95060d347dSNathan Whitehorn  .data    :
96060d347dSNathan Whitehorn  {
97060d347dSNathan Whitehorn    *(.data)
98060d347dSNathan Whitehorn    *(.gnu.linkonce.d*)
99060d347dSNathan Whitehorn  }
100060d347dSNathan Whitehorn  .data1     : { *(.data1) }
101618abe8bSAndreas Tobler  .toc1      : ALIGN(8) { *(.toc1) }
102618abe8bSAndreas Tobler  .opd       : ALIGN(8) { KEEP (*(.opd)) }
103618abe8bSAndreas Tobler  .branch_lt : ALIGN(8) { *(.branch_lt) }
104466d476aSNathan Whitehorn  . = ALIGN(4096);
1050632bb89SLeandro Lupori  .got       : ALIGN(8) { __tocbase = .; *(.got) }
1060632bb89SLeandro Lupori  .toc       : ALIGN(8) { *(.toc) }
107*3e76d052SZhenlei Huang  .init_array     :
108*3e76d052SZhenlei Huang  {
109*3e76d052SZhenlei Huang    PROVIDE_HIDDEN (__init_array_start = .);
110*3e76d052SZhenlei Huang    KEEP (*(SORT_BY_INIT_PRIORITY(.init_array.*)))
111*3e76d052SZhenlei Huang    KEEP (*(.init_array))
112*3e76d052SZhenlei Huang    PROVIDE_HIDDEN (__init_array_end = .);
113*3e76d052SZhenlei Huang  }
114*3e76d052SZhenlei Huang  .fini_array     :
115*3e76d052SZhenlei Huang  {
116*3e76d052SZhenlei Huang    PROVIDE_HIDDEN (__fini_array_start = .);
117*3e76d052SZhenlei Huang    KEEP (*(SORT_BY_INIT_PRIORITY(.fini_array.*)))
118*3e76d052SZhenlei Huang    KEEP (*(.fini_array))
119*3e76d052SZhenlei Huang    PROVIDE_HIDDEN (__fini_array_end = .);
120*3e76d052SZhenlei Huang  }
1219411e24dSBrandon Bergren  .dynamic        : { *(.dynamic) } :kernel :dynamic
122060d347dSNathan Whitehorn  /* Put .ctors and .dtors next to the .got2 section, so that the pointers
123060d347dSNathan Whitehorn     get relocated with -mrelocatable. Also put in the .fixup pointers.
124060d347dSNathan Whitehorn     The current compiler no longer needs this, but keep it around for 2.7.2  */
125060d347dSNathan Whitehorn                PROVIDE (_GOT2_START_ = .);
1263896a6ccSJessica Clarke  .got2           :  { *(.got2) } :kernel
127060d347dSNathan Whitehorn                PROVIDE (__CTOR_LIST__ = .);
128060d347dSNathan Whitehorn  .ctors          : { *(.ctors) }
129060d347dSNathan Whitehorn                PROVIDE (__CTOR_END__ = .);
130060d347dSNathan Whitehorn                PROVIDE (__DTOR_LIST__ = .);
131060d347dSNathan Whitehorn  .dtors          : { *(.dtors) }
132060d347dSNathan Whitehorn                PROVIDE (__DTOR_END__ = .);
133060d347dSNathan Whitehorn                PROVIDE (_FIXUP_START_ = .);
134060d347dSNathan Whitehorn  .fixup          : { *(.fixup) }
135060d347dSNathan Whitehorn                PROVIDE (_FIXUP_END_ = .);
136060d347dSNathan Whitehorn                PROVIDE (_GOT2_END_ = .);
137060d347dSNathan Whitehorn  /* We want the small data sections together, so single-instruction offsets
138060d347dSNathan Whitehorn     can access them all, and initialized data all before uninitialized, so
139060d347dSNathan Whitehorn     we can shorten the on-disk segment size.  */
1403896a6ccSJessica Clarke  .sdata     : { *(.sdata) }
141060d347dSNathan Whitehorn  _edata  =  .;
142060d347dSNathan Whitehorn  PROVIDE (edata = .);
143060d347dSNathan Whitehorn  .sbss      :
144060d347dSNathan Whitehorn  {
145060d347dSNathan Whitehorn    PROVIDE (__sbss_start = .);
146060d347dSNathan Whitehorn    *(.sbss)
147060d347dSNathan Whitehorn    *(.scommon)
148060d347dSNathan Whitehorn    *(.dynsbss)
149060d347dSNathan Whitehorn    PROVIDE (__sbss_end = .);
150060d347dSNathan Whitehorn  }
151060d347dSNathan Whitehorn  .plt   : { *(.plt) }
152060d347dSNathan Whitehorn  .bss       :
153060d347dSNathan Whitehorn  {
154060d347dSNathan Whitehorn   PROVIDE (__bss_start = .);
155060d347dSNathan Whitehorn   *(.dynbss)
156060d347dSNathan Whitehorn   *(.bss)
157060d347dSNathan Whitehorn   *(COMMON)
158060d347dSNathan Whitehorn  }
159060d347dSNathan Whitehorn  _end = . ;
160060d347dSNathan Whitehorn  PROVIDE (end = .);
16137d6d682SWarner Losh
16237d6d682SWarner Losh  /* Debug */
16337d6d682SWarner Losh  INCLUDE debuginfo.ldscript
164060d347dSNathan Whitehorn
16523dff4fdSWarner Losh  .gnu.attributes 0 : { KEEP (*(.gnu.attributes)) }
16623dff4fdSWarner Losh  /DISCARD/ : { *(.note.GNU-stack) }
16723dff4fdSWarner Losh}
168