2019-05-31 15:45:59 +02:00
|
|
|
OUTPUT_ARCH( "riscv" )
|
|
|
|
ENTRY( _entry )
|
2011-08-07 18:30:34 +02:00
|
|
|
|
|
|
|
SECTIONS
|
|
|
|
{
|
2019-05-31 15:45:59 +02:00
|
|
|
/*
|
|
|
|
* ensure that entry.S / _entry is at 0x80000000,
|
|
|
|
* where qemu's -kernel jumps.
|
|
|
|
*/
|
|
|
|
. = 0x80000000;
|
2019-10-22 04:27:18 +02:00
|
|
|
|
2024-08-07 11:26:07 +02:00
|
|
|
/*
|
|
|
|
* This section contains the code. This is, the machine language instructions
|
|
|
|
* that will be executed by the processor. In here we will find symbols
|
|
|
|
* that reference the functions in your object file.
|
|
|
|
*/
|
2019-10-22 04:27:18 +02:00
|
|
|
.text : {
|
|
|
|
*(.text .text.*)
|
2019-05-31 15:45:59 +02:00
|
|
|
. = ALIGN(0x1000);
|
2019-10-22 04:27:18 +02:00
|
|
|
_trampoline = .;
|
2019-07-26 10:53:46 +02:00
|
|
|
*(trampsec)
|
2019-10-22 04:27:18 +02:00
|
|
|
. = ALIGN(0x1000);
|
|
|
|
ASSERT(. - _trampoline == 0x1000, "error: trampoline larger than one page");
|
|
|
|
PROVIDE(etext = .);
|
2019-05-31 15:45:59 +02:00
|
|
|
}
|
2011-08-07 18:30:34 +02:00
|
|
|
|
2024-08-07 11:26:07 +02:00
|
|
|
/*
|
|
|
|
* This contains any data that is marked as read only.
|
|
|
|
* It is not unusual to find this data interleaved with the text section.
|
|
|
|
*/
|
2019-10-22 04:27:18 +02:00
|
|
|
.rodata : {
|
|
|
|
. = ALIGN(16);
|
|
|
|
*(.srodata .srodata.*) /* do not need to distinguish this from .rodata */
|
|
|
|
. = ALIGN(16);
|
|
|
|
*(.rodata .rodata.*)
|
|
|
|
}
|
2011-08-07 18:30:34 +02:00
|
|
|
|
2024-08-07 11:26:07 +02:00
|
|
|
/*
|
|
|
|
* This section contains initialized global and static variables.
|
|
|
|
* Any global object that has been explicitly initialized to a value different than zero.
|
|
|
|
*/
|
2019-05-31 15:45:59 +02:00
|
|
|
.data : {
|
2019-10-22 04:27:18 +02:00
|
|
|
. = ALIGN(16);
|
|
|
|
*(.sdata .sdata.*) /* do not need to distinguish this from .data */
|
|
|
|
. = ALIGN(16);
|
|
|
|
*(.data .data.*)
|
2019-05-31 15:45:59 +02:00
|
|
|
}
|
2019-10-22 04:27:18 +02:00
|
|
|
|
2024-08-07 11:26:07 +02:00
|
|
|
/*
|
|
|
|
* Contains all uninitialized global and static var iables. These are usually
|
|
|
|
* zeroed out by the startup code before we reach the main function. However,
|
|
|
|
* In an embedded system we usually provide our own startup code, which means
|
|
|
|
* we need to remember to do this ourselves.
|
|
|
|
*/
|
2019-09-08 12:51:58 +02:00
|
|
|
.bss : {
|
2019-10-22 04:27:18 +02:00
|
|
|
. = ALIGN(16);
|
|
|
|
*(.sbss .sbss.*) /* do not need to distinguish this from .bss */
|
|
|
|
. = ALIGN(16);
|
|
|
|
*(.bss .bss.*)
|
2019-05-31 15:45:59 +02:00
|
|
|
}
|
2019-10-22 04:27:18 +02:00
|
|
|
|
2024-08-07 11:26:07 +02:00
|
|
|
/* PROVIDE, see vm.c */
|
2019-10-22 04:27:18 +02:00
|
|
|
PROVIDE(end = .);
|
2011-08-07 18:30:34 +02:00
|
|
|
}
|