gnuk/src/gnuk.ld.in

194 lines
4.7 KiB
Plaintext
Raw Normal View History

2010-08-10 03:11:02 +00:00
/*
* ST32F103 memory setup.
*/
2013-06-20 07:19:49 +00:00
__main_stack_size__ = 0x0100; /* Exception handlers */
__process0_stack_size__ = 0x0100; /* main */
__process1_stack_size__ = 0x0140; /* ccid */
__process2_stack_size__ = 0x0180; /* rng */
__process3_stack_size__ = 0x1600; /* gpg */
2013-07-19 04:40:49 +00:00
__process4_stack_size__ = 0x0100; /* intr: usb */
2013-11-02 05:33:34 +00:00
__process5_stack_size__ = @MSC_SIZE@; /* msc */
__process6_stack_size__ = @TIM_SIZE@; /* intr: timer */
__process7_stack_size__ = @EXT_SIZE@; /* intr: ext */
2010-08-10 03:11:02 +00:00
MEMORY
{
2013-02-18 06:07:13 +00:00
flash0 : org = @ORIGIN@, len = 4k
flash : org = @ORIGIN@+0x1000, len = @FLASH_SIZE@k - 4k
2013-02-18 06:07:13 +00:00
ram : org = 0x20000000, len = @MEMORY_SIZE@k
2010-08-10 03:11:02 +00:00
}
/* __flash_start__: flash ROM start address regardless of DFU_SUPPORT */
__flash_start__ = 0x08001000;
2013-06-20 07:19:49 +00:00
__flash_end__ = ORIGIN(flash) + LENGTH(flash);
2012-05-25 08:06:14 +00:00
2010-08-10 03:11:02 +00:00
__ram_start__ = ORIGIN(ram);
__ram_size__ = LENGTH(ram);
__ram_end__ = __ram_start__ + __ram_size__;
SECTIONS
{
. = 0;
2013-06-20 07:19:49 +00:00
.sys : ALIGN(4) SUBALIGN(4)
2012-05-25 08:06:14 +00:00
{
2012-05-29 01:07:23 +00:00
_sys = .;
2012-05-25 08:06:14 +00:00
KEEP(*(.vectors))
2013-06-20 07:19:49 +00:00
. = ALIGN(16);
*(.sys.version)
build/sys.o(.text)
build/sys.o(.text.*)
build/sys.o(.rodata)
build/sys.o(.rodata.*)
. = ALIGN(1024);
*(.sys.0)
*(.sys.1)
*(.sys.2)
2012-05-25 08:06:14 +00:00
} > flash0
2013-02-17 15:21:35 +00:00
_text = .;
2013-06-20 07:19:49 +00:00
.startup : ALIGN(128) SUBALIGN(128)
2010-08-10 03:11:02 +00:00
{
2013-06-20 07:19:49 +00:00
KEEP(*(.startup.vectors))
2013-02-17 15:21:35 +00:00
. = ALIGN (16);
} > flash =0xffffffff
.text : ALIGN(16) SUBALIGN(16)
{
*(.text.startup.*)
2010-08-10 03:11:02 +00:00
*(.text)
*(.text.*)
*(.rodata)
*(.rodata.*)
*(.glue_7t)
*(.glue_7)
*(.gcc*)
} > flash
2013-02-17 15:21:35 +00:00
.ARM.extab : {*(.ARM.extab* .gnu.linkonce.armextab.*)} > flash
2010-08-10 03:11:02 +00:00
2013-02-17 15:21:35 +00:00
.ARM.exidx : {
PROVIDE(__exidx_start = .);
*(.ARM.exidx* .gnu.linkonce.armexidx.*)
PROVIDE(__exidx_end = .);
} > flash
2010-08-10 03:11:02 +00:00
2013-02-17 15:21:35 +00:00
.eh_frame_hdr : {*(.eh_frame_hdr)} > flash
2010-08-10 03:11:02 +00:00
2013-02-17 15:21:35 +00:00
.eh_frame : ONLY_IF_RO {*(.eh_frame)} > flash
2010-08-10 03:11:02 +00:00
2013-02-17 15:21:35 +00:00
.textalign : ONLY_IF_RO { . = ALIGN(8); } > flash
2010-08-10 03:11:02 +00:00
_etext = .;
_textdata = _etext;
2013-02-17 15:21:35 +00:00
.stacks :
{
2013-06-20 07:19:49 +00:00
. = ALIGN(8);
2013-07-19 04:40:49 +00:00
__main_stack_base__ = .;
. += __main_stack_size__;
2013-06-20 07:19:49 +00:00
. = ALIGN(8);
2013-07-19 04:40:49 +00:00
__main_stack_end__ = .;
__process0_stack_base__ = .;
. += __process0_stack_size__;
2013-06-20 07:19:49 +00:00
. = ALIGN(8);
2013-07-19 04:40:49 +00:00
__process0_stack_end__ = .;
__process1_stack_base__ = .;
. += __process1_stack_size__;
2013-06-20 07:19:49 +00:00
. = ALIGN(8);
2013-07-19 04:40:49 +00:00
__process1_stack_end__ = .;
2013-06-20 07:19:49 +00:00
__process2_stack_base__ = .;
. += __process2_stack_size__;
. = ALIGN(8);
__process2_stack_end__ = .;
2013-07-19 04:40:49 +00:00
__process3_stack_base__ = .;
. += __process3_stack_size__;
2013-06-20 07:19:49 +00:00
. = ALIGN(8);
2013-07-19 04:40:49 +00:00
__process3_stack_end__ = .;
__process4_stack_base__ = .;
. += __process4_stack_size__;
2013-06-20 07:19:49 +00:00
. = ALIGN(8);
2013-07-19 04:40:49 +00:00
__process4_stack_end__ = .;
__process5_stack_base__ = .;
. += __process5_stack_size__;
2013-02-17 15:21:35 +00:00
. = ALIGN(8);
2013-07-19 04:40:49 +00:00
__process5_stack_end__ = .;
2013-11-02 05:33:34 +00:00
__process6_stack_base__ = .;
. += __process6_stack_size__;
. = ALIGN(8);
__process6_stack_end__ = .;
__process7_stack_base__ = .;
. += __process7_stack_size__;
. = ALIGN(8);
__process7_stack_end__ = .;
2013-02-17 15:21:35 +00:00
. = ALIGN(8);
} > ram
2010-08-10 03:11:02 +00:00
.data :
{
2013-02-17 15:21:35 +00:00
. = ALIGN(4);
PROVIDE(_data = .);
2010-08-10 03:11:02 +00:00
*(.data)
. = ALIGN(4);
*(.data.*)
. = ALIGN(4);
*(.ramtext)
. = ALIGN(4);
2013-02-17 15:21:35 +00:00
PROVIDE(_edata = .);
2010-08-10 03:11:02 +00:00
} > ram AT > flash
.bss :
{
2013-02-17 15:21:35 +00:00
. = ALIGN(4);
PROVIDE(_bss_start = .);
2010-08-10 03:11:02 +00:00
*(.bss)
. = ALIGN(4);
*(.bss.*)
. = ALIGN(4);
*(COMMON)
. = ALIGN(4);
2013-02-17 15:21:35 +00:00
PROVIDE(_bss_end = .);
2010-09-05 09:10:54 +00:00
} > ram
2013-07-19 05:15:11 +00:00
. = ALIGN(16);
2010-09-05 09:10:54 +00:00
PROVIDE(end = .);
_end = .;
2012-05-18 17:05:31 +00:00
. = ALIGN(512);
2013-02-17 15:21:35 +00:00
2012-05-18 07:54:17 +00:00
_regnual_start = .;
2010-08-10 03:11:02 +00:00
2011-12-21 05:14:28 +00:00
@CERTDO_SUPPORT_START@
2011-01-27 09:17:01 +00:00
.gnuk_ch_certificate :
{
. = ALIGN (@FLASH_PAGE_SIZE@);
ch_certificate_start = .;
2013-06-20 07:19:49 +00:00
LONG(0xffffffff);
. += 1920;
2011-01-27 09:17:01 +00:00
. = ALIGN (@FLASH_PAGE_SIZE@);
} > flash =0xffffffff
2011-12-21 05:14:28 +00:00
@CERTDO_SUPPORT_END@
2011-01-27 09:17:01 +00:00
2011-01-27 01:02:46 +00:00
.gnuk_flash :
2010-09-05 09:10:54 +00:00
{
. = ALIGN (@FLASH_PAGE_SIZE@);
2013-06-20 07:19:49 +00:00
_data_pool = .;
KEEP(*(.gnuk_data))
. = ALIGN(@FLASH_PAGE_SIZE@);
. += @FLASH_PAGE_SIZE@;
_keystore_pool = .;
. += 512;
. = ALIGN(@FLASH_PAGE_SIZE@);
. += 512;
. = ALIGN(@FLASH_PAGE_SIZE@);
. += 512;
2013-06-20 07:19:49 +00:00
. = ALIGN(@FLASH_PAGE_SIZE@);
_updatekey_store = .;
. += 1024;
. = ALIGN(@FLASH_PAGE_SIZE@);
2011-01-27 01:02:46 +00:00
} > flash =0xffffffff
2010-09-05 09:10:54 +00:00
}
2010-08-10 03:11:02 +00:00
__heap_base__ = _end;
2013-02-17 15:21:35 +00:00
__heap_end__ = __ram_end__;