2022-09-19 08:51:11 +02:00
|
|
|
/*
|
2023-03-06 14:07:03 +01:00
|
|
|
* Copyright (C) 2022, 2023 - Tillitis AB
|
2022-09-19 08:51:11 +02:00
|
|
|
* SPDX-License-Identifier: GPL-2.0-only
|
|
|
|
*/
|
|
|
|
|
|
|
|
OUTPUT_ARCH( "riscv" )
|
|
|
|
ENTRY(_start)
|
|
|
|
|
|
|
|
MEMORY
|
|
|
|
{
|
|
|
|
ROM (rx) : ORIGIN = 0x00000000, LENGTH = 0x20000 /* 128 KB */
|
|
|
|
RAM (rwx) : ORIGIN = 0x40000000, LENGTH = 0x20000 /* 128 KB */
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTIONS
|
|
|
|
{
|
|
|
|
.text.init :
|
|
|
|
{
|
|
|
|
*(.text.init)
|
|
|
|
} >ROM
|
|
|
|
|
|
|
|
.htif :
|
|
|
|
{
|
|
|
|
. = ALIGN(0x00000000);
|
|
|
|
*(.htif)
|
|
|
|
} >ROM
|
|
|
|
|
|
|
|
.text :
|
|
|
|
{
|
|
|
|
. = ALIGN(4);
|
|
|
|
*(.text) /* .text sections (code) */
|
|
|
|
*(.text*) /* .text* sections (code) */
|
|
|
|
*(.rodata) /* .rodata sections (constants, strings, etc.) */
|
|
|
|
*(.rodata*) /* .rodata* sections (constants, strings, etc.) */
|
|
|
|
*(.srodata) /* .rodata sections (constants, strings, etc.) */
|
|
|
|
*(.srodata*) /* .rodata* sections (constants, strings, etc.) */
|
|
|
|
. = ALIGN(4);
|
|
|
|
_etext = .;
|
|
|
|
_sidata = _etext;
|
|
|
|
} >ROM
|
|
|
|
|
2023-03-07 12:01:00 +01:00
|
|
|
/* XXX We don't allow any data or BSS - but they need be defined or linking will fail */
|
|
|
|
|
2022-09-19 08:51:11 +02:00
|
|
|
.data : AT (_etext)
|
|
|
|
{
|
|
|
|
. = ALIGN(4);
|
|
|
|
_sdata = .;
|
|
|
|
. = ALIGN(4);
|
|
|
|
*(.data) /* .data sections */
|
|
|
|
*(.data*) /* .data* sections */
|
|
|
|
*(.sdata) /* .sdata sections */
|
|
|
|
*(.sdata*) /* .sdata* sections */
|
|
|
|
. = ALIGN(4);
|
|
|
|
_edata = .;
|
2023-03-07 12:01:00 +01:00
|
|
|
} >ROM
|
2022-09-19 08:51:11 +02:00
|
|
|
|
|
|
|
/* Uninitialized data section */
|
|
|
|
.bss :
|
|
|
|
{
|
|
|
|
. = ALIGN(4);
|
|
|
|
_sbss = .;
|
|
|
|
*(.bss)
|
|
|
|
*(.bss*)
|
|
|
|
*(.sbss)
|
|
|
|
*(.sbss*)
|
|
|
|
*(COMMON)
|
|
|
|
|
|
|
|
. = ALIGN(4);
|
|
|
|
_ebss = .;
|
2023-03-07 12:01:00 +01:00
|
|
|
} >ROM
|
2022-09-19 08:51:11 +02:00
|
|
|
}
|