-
Notifications
You must be signed in to change notification settings - Fork 4
/
app64.lds
112 lines (98 loc) · 2.19 KB
/
app64.lds
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
OUTPUT_ARCH( "riscv" )
ENTRY( _start )
PROG_LENGTH = 0x00040000; /* 448 KB */
RAM_LENGTH = 0x00010000; /* 64 KB */
STACK_SIZE = 0x00001000;
MEMORY {
FLASH (RX) : ORIGIN = 0x80000000, LENGTH = PROG_LENGTH
SRAM (RWX) : ORIGIN = 0x00000000, LENGTH = RAM_LENGTH
}
SECTIONS
{
/* Discard allocatable sections we don't need */
/DISCARD/ :
{
*(.dynsym)
*(.gnu.hash)
*(.hash)
*(.dynstr)
*(.dynamic)
}
.crt0_header :
{
/**
* Populate the header expected by `crt0`:
*
* struct hdr {
* size_t data_load_start;
* size_t data_start;
* size_t data_size;
* size_t bss_start;
* size_t bss_size;
* size_t rela_dyn_start;
* size_t rela_dyn_size;
* };
*/
/* Address of data in flash */
QUAD(LOADADDR(.data));
/* Address of data section */
QUAD(ADDR(.data));
/* Size of data section */
QUAD(SIZEOF(.data));
/* Address of BSS section */
QUAD(ADDR(.bss));
/* Size of BSS section */
QUAD(SIZEOF(.bss));
/* Address of .rela.dyn section */
QUAD(LOADADDR(.rela.dyn));
/* Size of .rela.dyn section */
QUAD(SIZEOF(.rela.dyn));
} > FLASH =0xFF
.rela.dyn :
{
__rela_dyn_start = .;
*(.rela.dyn)
__rela_dyn_end = .;
} > FLASH
.text ALIGN(4):
{
_ftext = .;
*(.text.init)
*(.text)
*(.text.*)
*(.gnu.linkonce.t.*)
} > FLASH
.rodata ALIGN(8):
{
*(.rdata)
*(.rodata)
*(.rodata.*)
*(.gnu.linkonce.r.*)
} > FLASH
_etext = .;
.data ALIGN(8):
{
*(.data)
*(.data.*)
*(.sdata*)
*(.srodata*)
*(.gnu.linkonce.d.*)
*(.comment)
. = ALIGN(4);
} > SRAM AT > FLASH
_edata = .;
/* bss: Uninitialized writeable data section */
.bss ALIGN(8):
{
*(.bss)
*(.bss.*)
*(.sbss*)
*(.gnu.linkonce.b.*)
*(COMMON)
. = ALIGN(4);
} > SRAM
.endflash :
{
} > FLASH
_end = .;
}