historical/m0-applesillicon.git/xnu-qemu-arm64-5.1.0/roms/skiboot/skiboot.lds.S
2024-01-16 11:20:27 -06:00

234 lines
5 KiB
ArmAsm

/* Copyright 2013-2018 IBM Corp.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
* implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <config.h>
#include <mem-map.h>
/* Debug sections from binutils `ld --verbose` */
#define DEBUG_SECTIONS \
/* 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_line.* .debug_line_end ) } \
.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) } \
/* DWARF 3 */ \
.debug_pubtypes 0 : { *(.debug_pubtypes) } \
.debug_ranges 0 : { *(.debug_ranges) } \
/* DWARF Extension. */ \
.debug_macro 0 : { *(.debug_macro) } \
.debug_addr 0 : { *(.debug_addr) }
ENTRY(boot_entry);
SECTIONS
{
_start = .;
. = 0;
.head : {
KEEP(*(.head))
}
. = SPIRA_OFF;
.spira : {
KEEP(*(.spira.data))
}
. = SPIRAH_OFF;
.spirah : {
KEEP(*(.spirah.data))
}
. = PROCIN_OFF;
.procin.data : {
KEEP(*(.procin.data))
}
. = MDST_TABLE_OFF;
.mdst : {
KEEP(*(.mdst.data))
}
. = CPU_CTL_OFF;
.cpuctrl : {
KEEP(*(.cpuctrl.data))
}
. = ALIGN(0x10);
_stext = .;
.text : {
*(.text*)
*(.sfpr .glink)
}
_etext = .;
.rodata : {
__rodata_start = .;
*(.rodata .rodata.*)
__rodata_end = .;
}
. = ALIGN(0x10);
.init : {
__ctors_start = .;
KEEP(*(.ctors*))
KEEP(*(SORT(.init_array.*)))
KEEP(*(.init_array))
__ctors_end = .;
}
. = ALIGN(0x10);
.opd : {
*(.opd)
}
. = ALIGN(0x100);
.got : {
__toc_start = . + 0x8000;
*(.got)
*(.toc)
}
. = ALIGN(0x10);
.opal_table : {
__opal_table_start = .;
KEEP(*(.opal_table))
__opal_table_end = .;
}
.platforms : {
__platforms_start = .;
KEEP(*(.platforms))
__platforms_end = .;
}
/* Do I need to keep these ? */
.dynsym : { *(.dynsym) }
.dynstr : { *(.dynstr) }
/* Relocations */
. = ALIGN(0x10);
.dynamic : {
__dynamic_start = .;
*(.dynamic)
__dynamic_end = .;
}
. = ALIGN(0x10);
.rela.dyn : {
__rela_dyn_start = .;
*(.rela*)
__rela_dyn_end = .;
}
.plt : { *(.plt) *(.iplt) }
.hash : { *(.hash) }
.gnu.hash : { *(.gnu.hash) }
.dynsym : { *(.dynsym) }
.dynstr : { *(.dynstr) }
.gnu.version : { *(.gnu.version) }
.gnu.version_d : { *(.gnu.version_d) }
.gnu.version_r : { *(.gnu.version_r) }
. = ALIGN(0x10);
.sym_map : {
__sym_map_start = . ;
KEEP(*(.sym_map))
__sym_map_end = . ;
}
/*
* Memory above this point should be un-changing after the OS
* boots, and is verified with a checksum upon fast reboot.
*/
_romem_end = .;
.data : {
/*
* A couple of things that need to be 4K aligned and
* to reside in their own pages for the sake of TCE
* mappings
*/
. = ALIGN(0x1000);
*(.data.memcons);
. = ALIGN(0x10000);
*(.data.boot_trace);
. = ALIGN(0x10000);
*(.data*)
*(.force.data)
*(.toc1)
*(.branch_lt)
}
/* We locate the BSS at 4M to leave room for the symbol map */
. = 0x400000;
_sbss = .;
.bss : {
*(.dynbss)
*(.bss*)
}
. = ALIGN(0x10000);
_ebss = .;
_end = .;
DEBUG_SECTIONS
/* Optional kernel image */
. = ALIGN(0x10000);
.builtin_kernel : {
__builtin_kernel_start = .;
KEEP(*(.builtin_kernel))
__builtin_kernel_end = .;
}
/* Discards */
/DISCARD/ : {
*(.note.GNU-stack)
*(.comment)
*(.eh_frame)
*(.interp)
*(.fini_array.*)
}
}