blob: 70a717b72f2ea257cb1342f0450ad2a9d7d8d704 (
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
MEMORY
{
ITCM (rwx): ORIGIN = 0x00000000, LENGTH = 0x00080000 /* 512 Kib */
DTCM (rwx): ORIGIN = 0x20000000, LENGTH = 0x00080000 /* 512 Kib */
RAM (rwx): ORIGIN = 0x20200000, LENGTH = 0x00080000 /* 512 Kib */
FLASH (rx): ORIGIN = 0x60000000, LENGTH = 0x001FFFF0 /* 1984 Kib */
}
ENTRY(Reset_Handler);
_stack_size = 4K;
SECTIONS
{
.text : ALIGN(8) {
FILL(0xFFFFFFFF);
/* place flash config at beginning of flash device */
KEEP(*(.flash_config));
/* IVT must be located at +4 Kbyte offset from base address of flash. */
. = ORIGIN(FLASH) + 0x1000;
KEEP(*(.ivt));
. = ORIGIN(FLASH) + 0x1020;
KEEP(*(.boot_data));
. = ORIGIN(FLASH) + 0x2000;
_svectors = ABSOLUTE(.);
KEEP(*(.isr_vector));
. = ALIGN(8);
*(.text.Reset_Handler);
. = ALIGN(8);
_stext = .;
*(.text*);
*(.rodata* .constdata*);
. = ALIGN(8);
_etext = .;
} > FLASH
.tinygo_stacksizes : ALIGN(8) {
*(.tinygo_stacksizes);
. = ALIGN(8);
} > FLASH
.text.padding (NOLOAD) : {
. = ALIGN(32768);
} > ITCM
.stack (NOLOAD) : {
. = ALIGN(8);
. += _stack_size;
_stack_top = .;
} > DTCM
.data : ALIGN(8) {
FILL(0xFFFFFFFF);
_sdata = .;
*(.data*);
. = ALIGN(8);
_edata = .;
} > DTCM AT > FLASH
.bss : ALIGN(8) {
_sbss = .;
*(.bss*);
*(COMMON);
. = ALIGN(8);
_ebss = .;
} > DTCM AT > DTCM
/DISCARD/ : {
*(.ARM.exidx*); /* causes spurious 'undefined reference' errors */
}
_sidata = LOADADDR(.data);
_heap_start = ORIGIN(RAM);
_heap_end = ORIGIN(RAM) + LENGTH(RAM);
_globals_start = _sdata;
_globals_end = _ebss;
_image_size = SIZEOF(.text) + SIZEOF(.tinygo_stacksizes) + SIZEOF(.data);
/* TODO: link .text to ITCM */
_itcm_blocks = (0 + 0x7FFF) >> 15;
_flexram_cfg = 0xAAAAAAAA | ((1 << (_itcm_blocks * 2)) - 1);
}
|