blob: e07cbc04b9fa63a37b3c15e9992cd1e053e4ff36 (
plain)
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
|
/*
* model.lds.S - simple linker script for stand-alone Linux booting
*
* Copyright (C) 2012 ARM Limited. All rights reserved.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE.txt file.
*/
#define _STR(s) #s
#define STR(s) _STR(s)
#ifdef BOOTWRAPPER_32
OUTPUT_FORMAT("elf32-littlearm")
OUTPUT_ARCH(arm)
#else
OUTPUT_FORMAT("elf64-littleaarch64")
OUTPUT_ARCH(aarch64)
#endif
TARGET(binary)
#ifdef XEN
INPUT(STR(XEN))
#endif
INPUT(STR(KERNEL))
INPUT(./fdt.dtb)
#ifdef USE_INITRD
INPUT(STR(FILESYSTEM))
#endif
ENTRY(_start)
SECTIONS
{
/*
* Order matters: consume binary blobs first, so they won't appear in
* the boot section's *(.data)
*/
.kernel (PHYS_OFFSET + KERNEL_OFFSET): {
kernel__start = .;
STR(KERNEL)
kernel__end = .;
}
#ifdef XEN
.xen (PHYS_OFFSET + XEN_OFFSET): {
xen__start = .;
STR(XEN)
xen__end = .;
}
entrypoint = xen__start;
#else
entrypoint = kernel__start;
#endif
.dtb (PHYS_OFFSET + FDT_OFFSET): {
dtb__start = .;
dtb = .;
./fdt.dtb
dtb__end = .;
}
#ifdef USE_INITRD
.filesystem (PHYS_OFFSET + FS_OFFSET): {
filesystem__start = .;
STR(FILESYSTEM)
filesystem__end = .;
}
#endif
.boot PHYS_OFFSET: {
text__start = .;
*(.init)
*(.text*)
*(.data* .rodata* .bss* COMMON)
*(.vectors)
*(.stack)
PROVIDE(etext = .);
text__end = .;
}
.mbox (PHYS_OFFSET + MBOX_OFFSET): {
mbox__start = .;
mbox = .;
QUAD(0x0)
mbox__end = .;
}
ASSERT(etext <= (PHYS_OFFSET + TEXT_LIMIT), ".text overflow!")
}
|