forked from cloud-hypervisor/rust-hypervisor-firmware
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathx86_64-unknown-none.ld
51 lines (43 loc) · 1.33 KB
/
x86_64-unknown-none.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
ENTRY(ram32_start) /* coreboot uses the ELF entrypoint */
PHDRS
{
ram PT_LOAD FILEHDR PHDRS ;
note PT_NOTE ;
}
/* Loaders like to put stuff in low memory (< 1M), so we don't use it. */
ram_min = 1M;
SECTIONS
{
/* Mapping the program headers and note into RAM makes the file smaller. */
. = ram_min;
. += SIZEOF_HEADERS;
.note : { *(.note) } :note :ram
/* These sections are mapped into RAM from the file. Omitting :ram from
later sections avoids emitting empty sections in the final binary. */
.rodata : { *(.rodata .rodata.*) } :ram
. = ALIGN(4K);
code_start = .;
.text : { *(.text .text.*) }
.text32 : { *(.text32) }
. = ALIGN(4K);
code_end = .;
data_start = .;
.data : { *(.data .data.*) }
/* The BSS section isn't mapped from file data. It is just zeroed in RAM. */
.bss : {
*(.bss .bss.*)
}
. = ALIGN(4K);
data_end = .;
/* Our stack grows down and is page-aligned. TODO: Add stack guard pages. */
stack_start = .;
.stack (NOLOAD) : ALIGN(4K) { . += 128K; }
/* ram32.s only maps the first 2 MiB, and that must include the stack. */
ASSERT((. <= 2M), "Stack overflows initial identity-mapped memory region")
stack_end = .;
/* Strip symbols from the output binary (comment out to get symbols) */
/DISCARD/ : {
*(.symtab)
*(.strtab)
}
}