-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathlinker-riscv64.ld
55 lines (46 loc) · 979 Bytes
/
linker-riscv64.ld
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
OUTPUT_ARCH(riscv)
ENTRY(_start)
BASE_ADDRESS = 0x0000000080200000;
SECTIONS
{
/* Load the kernel at this address: "." means the current address */
. = BASE_ADDRESS;
start = .;
_skernel = .;
.text ALIGN(4K): {
stext = .;
*(.text.entry)
*(.text .text.*)
etext = .;
}
.rodata ALIGN(4K): {
srodata = .;
*(.rodata .rodata.*)
. = ALIGN(4K);
erodata = .;
}
.data ALIGN(4K): {
. = ALIGN(4K);
*(.data.prepage .data.prepage.*)
. = ALIGN(4K);
_sdata = .;
*(.data .data.*)
*(.sdata .sdata.*)
_edata = .;
}
.sigtrx ALIGN(4K): {
*(.sigtrx .sigtrx.*)
}
_load_end = .;
.bss ALIGN(4K): {
*(.bss.stack)
_sbss = .;
*(.bss .bss.*)
*(.sbss .sbss.*)
_ebss = .;
}
PROVIDE(end = .);
/DISCARD/ : {
*(.comment) *(.gnu*) *(.note*) *(.eh_frame*)
}
}