1*31b31015Sliushiwei/* SPDX-License-Identifier: BSD-2-Clause */ 2*31b31015Sliushiwei#ifdef RV32 3*31b31015SliushiweiOUTPUT_FORMAT("elf32-littleriscv") 4*31b31015SliushiweiOUTPUT_ARCH(riscv) 5*31b31015Sliushiwei#endif 6*31b31015Sliushiwei#ifdef RV64 7*31b31015SliushiweiOUTPUT_FORMAT("elf64-littleriscv") 8*31b31015SliushiweiOUTPUT_ARCH(riscv) 9*31b31015Sliushiwei#endif 10*31b31015Sliushiwei 11*31b31015Sliushiwei#ifndef CFG_FTRACE_BUF_SIZE 12*31b31015Sliushiwei#define CFG_FTRACE_BUF_SIZE 2048 13*31b31015Sliushiwei#endif 14*31b31015Sliushiwei 15*31b31015SliushiweiSECTIONS { 16*31b31015Sliushiwei .ta_head : {*(.ta_head)} 17*31b31015Sliushiwei .text : { 18*31b31015Sliushiwei __text_start = .; 19*31b31015Sliushiwei *(.text .text.*) 20*31b31015Sliushiwei *(.stub) 21*31b31015Sliushiwei *(.gnu.linkonce.t.*) 22*31b31015Sliushiwei __text_end = .; 23*31b31015Sliushiwei } 24*31b31015Sliushiwei .note.gnu.property : { *(.note.gnu.property) } 25*31b31015Sliushiwei .plt : { *(.plt) } 26*31b31015Sliushiwei 27*31b31015Sliushiwei .eh_frame_hdr : { 28*31b31015Sliushiwei *(.eh_frame_hdr) 29*31b31015Sliushiwei *(.eh_frame_entry .eh_frame_entry.*) 30*31b31015Sliushiwei } 31*31b31015Sliushiwei .eh_frame : { KEEP(*(.eh_frame)) *(.eh_frame.*) } 32*31b31015Sliushiwei .gcc_except_table : { *(.gcc_except_table .gcc_except_table.*) } 33*31b31015Sliushiwei .rodata : { 34*31b31015Sliushiwei *(.gnu.linkonce.r.*) 35*31b31015Sliushiwei *(.rodata .rodata.*) 36*31b31015Sliushiwei } 37*31b31015Sliushiwei .ctors : { *(.ctors) } 38*31b31015Sliushiwei .dtors : { *(.dtors) } 39*31b31015Sliushiwei .dynsym : { *(.dynsym) } 40*31b31015Sliushiwei .dynstr : { *(.dynstr) } 41*31b31015Sliushiwei .hash : { *(.hash) } 42*31b31015Sliushiwei 43*31b31015Sliushiwei /* Page align to allow dropping execute bit for RW data */ 44*31b31015Sliushiwei . = ALIGN(4096); 45*31b31015Sliushiwei 46*31b31015Sliushiwei .dynamic : { *(.dynamic) } 47*31b31015Sliushiwei .tdata : { *(.tdata .tdata.* .gnu.linkonce.td.*) } 48*31b31015Sliushiwei .tbss : { *(.tbss .tbss.* .gnu.linkonce.tb.*) *(.tcommon) } 49*31b31015Sliushiwei .got : { *(.got.plt) *(.got) } 50*31b31015Sliushiwei .rel.text : { *(.rel.text) *(.rel.gnu.linkonce.t*) } 51*31b31015Sliushiwei .rela.text : { *(.rela.text) *(.rela.gnu.linkonce.t*) } 52*31b31015Sliushiwei .rel.data : { *(.rel.data) *(.rel.gnu.linkonce.d*) } 53*31b31015Sliushiwei .rela.data : { *(.rela.data) *(.rela.gnu.linkonce.d*) } 54*31b31015Sliushiwei .rel.tdata : { *(.rel.tdata .rel.tdata.* .rel.gnu.linkonce.td.*) } 55*31b31015Sliushiwei .rela.tdata : { *(.rela.tdata .rela.tdata.* .rela.gnu.linkonce.td.*) } 56*31b31015Sliushiwei .rel.tbss : { *(.rel.tbss .rel.tbss.* .rel.gnu.linkonce.tb.*) } 57*31b31015Sliushiwei .rela.tbss : { *(.rela.tbss .rela.tbss.* .rela.gnu.linkonce.tb.*) } 58*31b31015Sliushiwei .rel.rodata : { *(.rel.rodata) *(.rel.gnu.linkonce.r*) } 59*31b31015Sliushiwei .rela.rodata : { *(.rela.rodata) *(.rela.gnu.linkonce.r*) } 60*31b31015Sliushiwei .rel.dyn : { *(.rel.dyn) } 61*31b31015Sliushiwei .rel.got : { *(.rel.got) } 62*31b31015Sliushiwei .rela.got : { *(.rela.got) } 63*31b31015Sliushiwei .rel.ctors : { *(.rel.ctors) } 64*31b31015Sliushiwei .rela.ctors : { *(.rela.ctors) } 65*31b31015Sliushiwei .rel.dtors : { *(.rel.dtors) } 66*31b31015Sliushiwei .rela.dtors : { *(.rela.dtors) } 67*31b31015Sliushiwei .rel.init : { *(.rel.init) } 68*31b31015Sliushiwei .rela.init : { *(.rela.init) } 69*31b31015Sliushiwei .rel.fini : { *(.rel.fini) } 70*31b31015Sliushiwei .rela.fini : { *(.rela.fini) } 71*31b31015Sliushiwei .rel.bss : { *(.rel.bss) } 72*31b31015Sliushiwei .rela.bss : { *(.rela.bss) } 73*31b31015Sliushiwei .rel.plt : { *(.rel.plt) } 74*31b31015Sliushiwei .rela.plt : { *(.rela.plt) } 75*31b31015Sliushiwei 76*31b31015Sliushiwei .data : { *(.data .data.* .gnu.linkonce.d.*) } 77*31b31015Sliushiwei .bss : { 78*31b31015Sliushiwei *(.bss .bss.* .gnu.linkonce.b.* COMMON) 79*31b31015Sliushiwei 80*31b31015Sliushiwei /* 81*31b31015Sliushiwei * TA tracing using ftrace 82*31b31015Sliushiwei * Reserve some space for the ftrace buffer, only if the 83*31b31015Sliushiwei * TA is instrumented (i.e., some files were built with -pg). 84*31b31015Sliushiwei */ 85*31b31015Sliushiwei . = ALIGN(8); 86*31b31015Sliushiwei __ftrace_buf_start = .; 87*31b31015Sliushiwei . += DEFINED(MCOUNT_SYM) ? 88*31b31015Sliushiwei CFG_FTRACE_BUF_SIZE : 0; 89*31b31015Sliushiwei __ftrace_buf_end = .; 90*31b31015Sliushiwei } 91*31b31015Sliushiwei 92*31b31015Sliushiwei /DISCARD/ : { *(.interp) } 93*31b31015Sliushiwei} 94*31b31015Sliushiwei 95