Skip to content

Commit 4d9c434

Browse files
committed
Support boot stack size configuration option
1 parent 75d4705 commit 4d9c434

File tree

3 files changed

+18
-3
lines changed

3 files changed

+18
-3
lines changed

targets/TARGET_GigaDevice/TARGET_GD32E10X/device/TOOLCHAIN_ARM_STD/gd32e103vb.sct

Lines changed: 10 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,12 @@
1111
#define MBED_APP_SIZE 0x20000
1212
#endif
1313

14+
#if !defined(MBED_BOOT_STACK_SIZE)
15+
#define MBED_BOOT_STACK_SIZE 0x400
16+
#endif
17+
18+
#define Stack_Size MBED_BOOT_STACK_SIZE
19+
1420
LR_IROM1 MBED_APP_START MBED_APP_SIZE { ; load region size_region (1024K)
1521

1622
ER_IROM1 MBED_APP_START MBED_APP_SIZE { ; load address = execution address
@@ -20,8 +26,11 @@ LR_IROM1 MBED_APP_START MBED_APP_SIZE { ; load region size_region (1024K)
2026
}
2127

2228
; 84 vectors (16 core + 68 peripheral) * 4 bytes = 336 bytes to reserve (0x150)
23-
RW_IRAM1 (0x20000000+0x150) (0x8000-0x150) { ; RW data
29+
RW_IRAM1 (0x20000000+0x150) (0x8000-0x150-Stack_Size) { ; RW data
2430
.ANY (+RW +ZI)
2531
}
32+
33+
ARM_LIB_STACK 0x20000000+0x8000 EMPTY -Stack_Size { ; Stack region growing down
34+
}
2635
}
2736

targets/TARGET_GigaDevice/TARGET_GD32E10X/device/TOOLCHAIN_GCC_ARM/GD32E103xB.ld

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,10 @@
66
#define MBED_APP_SIZE 128K
77
#endif
88

9+
#if !defined(MBED_BOOT_STACK_SIZE)
10+
#define MBED_BOOT_STACK_SIZE 0x400
11+
#endif
12+
913
/* specify memory regions */
1014
MEMORY
1115
{
@@ -112,6 +116,7 @@ SECTIONS
112116
__end__ = .;
113117
end = __end__;
114118
*(.heap*)
119+
. = ORIGIN(RAM) + LENGTH(RAM) - MBED_BOOT_STACK_SIZE;
115120
__HeapLimit = .;
116121
} > RAM
117122

@@ -123,7 +128,7 @@ SECTIONS
123128
/* initializes stack on the end of block */
124129
__StackTop = ORIGIN(RAM) + LENGTH(RAM);
125130
_estack = __StackTop;
126-
__StackLimit = __StackTop - SIZEOF(.stack_dummy);
131+
__StackLimit = __StackTop - MBED_BOOT_STACK_SIZE;
127132
PROVIDE(__stack = __StackTop);
128133

129134
ASSERT(__StackLimit >= __HeapLimit, "region RAM overflowed with stack")

targets/TARGET_GigaDevice/TARGET_GD32E10X/device/TOOLCHAIN_IAR/gd32e103vb.icf

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,7 @@
44

55
if (!isdefinedsymbol(MBED_APP_START)) { define symbol MBED_APP_START = 0x08000000; }
66
if (!isdefinedsymbol(MBED_APP_SIZE)) { define symbol MBED_APP_SIZE = 0x20000; }
7+
if (!isdefinedsymbol(MBED_BOOT_STACK_SIZE)) { define symbol MBED_BOOT_STACK_SIZE = 0x400; }
78
/*-Specials-*/
89
define symbol __ICFEDIT_intvec_start__ = MBED_APP_START;
910
/*-Memory Regions-*/
@@ -15,7 +16,7 @@ define symbol __ICFEDIT_region_RAM_start__ = 0x20000150;
1516
define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF;
1617
/*-Sizes-*/
1718
/*Heap 1/4 of ram and stack 1/8*/
18-
define symbol __ICFEDIT_size_cstack__ = 0x1000;
19+
define symbol __ICFEDIT_size_cstack__ = MBED_BOOT_STACK_SIZE;
1920
define symbol __ICFEDIT_size_heap__ = 0x2000;
2021
/**** End of ICF editor section. ###ICF###*/
2122

0 commit comments

Comments
 (0)