diff --git a/bsp/renesas/rzn2l_rsk/.cproject b/bsp/renesas/rzn2l_rsk/.cproject
new file mode 100644
index 00000000000..e5c18fc2dd0
--- /dev/null
+++ b/bsp/renesas/rzn2l_rsk/.cproject
@@ -0,0 +1,221 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/bsp/renesas/rzn2l_rsk/.project b/bsp/renesas/rzn2l_rsk/.project
new file mode 100644
index 00000000000..a96db4e2202
--- /dev/null
+++ b/bsp/renesas/rzn2l_rsk/.project
@@ -0,0 +1,28 @@
+
+
+ hh
+
+
+
+
+
+ org.eclipse.cdt.managedbuilder.core.genmakebuilder
+ clean,full,incremental,
+
+
+
+
+ org.eclipse.cdt.managedbuilder.core.ScannerConfigBuilder
+ full,incremental,
+
+
+
+
+
+ org.eclipse.cdt.core.cnature
+ org.rt-thread.studio.rttnature
+ org.eclipse.cdt.managedbuilder.core.managedBuildNature
+ org.eclipse.cdt.managedbuilder.core.ScannerConfigNature
+
+
+
diff --git a/bsp/renesas/rzn2l_rsk/.settings/hh.JLink.Debug.rttlaunch b/bsp/renesas/rzn2l_rsk/.settings/hh.JLink.Debug.rttlaunch
new file mode 100644
index 00000000000..618eadd9b7c
--- /dev/null
+++ b/bsp/renesas/rzn2l_rsk/.settings/hh.JLink.Debug.rttlaunch
@@ -0,0 +1,94 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/bsp/renesas/rzn2l_rsk/.settings/ilg.gnumcueclipse.managedbuild.cross.arm.prefs b/bsp/renesas/rzn2l_rsk/.settings/ilg.gnumcueclipse.managedbuild.cross.arm.prefs
new file mode 100644
index 00000000000..7dbfc8a7d95
--- /dev/null
+++ b/bsp/renesas/rzn2l_rsk/.settings/ilg.gnumcueclipse.managedbuild.cross.arm.prefs
@@ -0,0 +1,2 @@
+eclipse.preferences.version=1
+toolchain.path.1287942917=${toolchain_install_path}/ARM/GNU_Tools_for_ARM_Embedded_Processors/10.2.1/bin
diff --git a/bsp/renesas/rzn2l_rsk/.settings/language.settings.xml b/bsp/renesas/rzn2l_rsk/.settings/language.settings.xml
new file mode 100644
index 00000000000..67360abb077
--- /dev/null
+++ b/bsp/renesas/rzn2l_rsk/.settings/language.settings.xml
@@ -0,0 +1,14 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/bsp/renesas/rzn2l_rsk/.settings/local_temp_storage.prefs b/bsp/renesas/rzn2l_rsk/.settings/local_temp_storage.prefs
new file mode 100644
index 00000000000..6c3ab86d840
--- /dev/null
+++ b/bsp/renesas/rzn2l_rsk/.settings/local_temp_storage.prefs
@@ -0,0 +1,2 @@
+eclipse.preferences.version=1
+temp.toolchain.exec.path=D\:\\manufacture_apps\\RT-ThreadStudio\\repo\\Extract\\ToolChain_Support_Packages\\ARM\\GNU_Tools_for_ARM_Embedded_Processors\\10.2.1/bin
diff --git a/bsp/renesas/rzn2l_rsk/.settings/org.eclipse.core.runtime.prefs b/bsp/renesas/rzn2l_rsk/.settings/org.eclipse.core.runtime.prefs
new file mode 100644
index 00000000000..9f1acfcfba2
--- /dev/null
+++ b/bsp/renesas/rzn2l_rsk/.settings/org.eclipse.core.runtime.prefs
@@ -0,0 +1,3 @@
+content-types/enabled=true
+content-types/org.eclipse.cdt.core.asmSource/file-extensions=s
+eclipse.preferences.version=1
\ No newline at end of file
diff --git a/bsp/renesas/rzn2l_rsk/.settings/projcfg.ini b/bsp/renesas/rzn2l_rsk/.settings/projcfg.ini
new file mode 100644
index 00000000000..f8e9f80e4ae
--- /dev/null
+++ b/bsp/renesas/rzn2l_rsk/.settings/projcfg.ini
@@ -0,0 +1,19 @@
+#RT-Thread Studio Project Configuration
+#Thu Nov 28 18:09:09 CST 2024
+cfg_version=v3.0
+board_name=rzn2l_rsk
+example_name=
+hardware_adapter=J-Link
+board_base_nano_proj=false
+project_type=rt-thread
+chip_name=R9A07G084
+selected_rtt_version=latest
+bsp_version=1.0.0
+os_branch=master
+project_base_rtt_bsp=true
+output_project_path=D\:\\manufacture_apps\\RT-ThreadStudio\\repo\\Local\\Board_Support_Packages\\Renesas\\EtherKit\\1.0.0\\projects
+is_base_example_project=false
+is_use_scons_build=true
+project_name=etherkit_blink_led
+os_version=latest
+bsp_path=
diff --git a/bsp/renesas/rzn2l_rsk/.settings/project.JLink.Debug.rttlaunch b/bsp/renesas/rzn2l_rsk/.settings/project.JLink.Debug.rttlaunch
new file mode 100644
index 00000000000..db20f2562b2
--- /dev/null
+++ b/bsp/renesas/rzn2l_rsk/.settings/project.JLink.Debug.rttlaunch
@@ -0,0 +1,92 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/bsp/renesas/rzn2l_rsk/.settings/standalone.prefs b/bsp/renesas/rzn2l_rsk/.settings/standalone.prefs
index 5e6ead989e8..1f9ccf199ad 100644
--- a/bsp/renesas/rzn2l_rsk/.settings/standalone.prefs
+++ b/bsp/renesas/rzn2l_rsk/.settings/standalone.prefs
@@ -1,24 +1,26 @@
-#Sat Sep 14 16:03:03 CST 2024
-com.renesas.cdt.ddsc.content/com.renesas.cdt.ddsc.content.defaultlinkerscript=script/fsp_xspi0_boot.icf
+#Wed Nov 27 16:37:16 CST 2024
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#BSP\#\#Board\#\#rzn2l_rsk\#\#xspi0_x1_boot\#\#2.0.0/libraries=
-com.renesas.cdt.ddsc.packs.componentfiles/Arm\#\#CMSIS\#\#CMSIS5\#\#Core\#\#\#\#5.7.0+renesas.1.fsp.2.0.0/all=1441545198,rzn/arm/CMSIS_5/LICENSE.txt|4247764709,rzn/arm/CMSIS_5/CMSIS/Core_R/Include/cmsis_gcc.h|1135074086,rzn/arm/CMSIS_5/CMSIS/Core_R/Include/core_cr52.h|510668081,rzn/arm/CMSIS_5/CMSIS/Core_R/Include/cmsis_iccarm.h|4245531541,rzn/arm/CMSIS_5/CMSIS/Core_R/Include/cmsis_compiler.h|1887099957,rzn/arm/CMSIS_5/CMSIS/Core_R/Include/cmsis_cp15.h|3334069041,rzn/arm/CMSIS_5/CMSIS/Core_R/Include/cmsis_version.h
-com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#BSP\#\#rzn2l\#\#device\#\#R9A07G084M04GBG\#\#2.0.0/all=
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#BSP\#\#Board\#\#rzn2l_rsk\#\#xspi0_x1_boot\#\#2.0.0/all=907937621,script/fsp_xspi0_boot.icf|3822962514,rzn/board/rzn2l_rsk/board_leds.c|358444977,rzn/board/rzn2l_rsk/board_init.c|2067006575,rzn/board/rzn2l_rsk/board.h|736691883,rzn/board/rzn2l_rsk/board_ethernet_phy.h|1631979823,rzn/board/rzn2l_rsk/board_leds.h|1430483072,rzn/board/rzn2l_rsk/board_init.h
com.renesas.cdt.ddsc.contentgen.options/options/suppresswarningspaths=
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#HAL\ Drivers\#\#all\#\#r_ioport\#\#\#\#2.0.0/libraries=
com.renesas.cdt.ddsc.threads.configurator/collapse/module.driver.uart_on_sci_uart.86814920=false
-com.renesas.cdt.ddsc.settingseditor/com.renesas.cdt.ddsc.settingseditor.active_page=SWPConfigurator
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#Common\#\#all\#\#fsp_common\#\#\#\#2.0.0/all=908052335,rzn/fsp/src/bsp/cmsis/Device/RENESAS/Source/system.c|3563504244,rzn/fsp/src/bsp/cmsis/Device/RENESAS/Source/startup.c|870156648,rzn/fsp/src/bsp/cmsis/Device/RENESAS/Source/cr/system_core.c|368480523,rzn/fsp/src/bsp/cmsis/Device/RENESAS/Source/cr/startup_core.c|3243637314,rzn/fsp/src/bsp/cmsis/Device/RENESAS/Include/system.h|1280798555,rzn/fsp/src/bsp/cmsis/Device/RENESAS/Include/renesas.h|3352808441,rzn/fsp/src/bsp/cmsis/Device/RENESAS/Include/R9A07G084.h|1310386533,rzn/fsp/src/bsp/mcu/all/bsp_io.h|3643995939,rzn/fsp/src/bsp/mcu/all/bsp_cache.h|1033616941,rzn/fsp/src/bsp/mcu/all/bsp_register_protection.h|1572168446,rzn/fsp/src/bsp/mcu/all/bsp_io.c|3001342594,rzn/fsp/src/bsp/mcu/all/bsp_common.h|263477342,rzn/fsp/src/bsp/mcu/all/bsp_reset.h|2534029381,rzn/fsp/src/bsp/mcu/all/bsp_module_stop.h|4193244082,rzn/fsp/src/bsp/mcu/all/bsp_irq.h|2136575248,rzn/fsp/src/bsp/mcu/all/bsp_tfu.h|2170977041,rzn/fsp/src/bsp/mcu/all/bsp_delay.c|526389185,rzn/fsp/src/bsp/mcu/all/bsp_compiler_support.h|8162287,rzn/fsp/src/bsp/mcu/all/bsp_clocks.h|3045644015,rzn/fsp/src/bsp/mcu/all/bsp_common.c|1908923075,rzn/fsp/src/bsp/mcu/all/bsp_clocks.c|1289851302,rzn/fsp/src/bsp/mcu/all/bsp_irq.c|358242822,rzn/fsp/src/bsp/mcu/all/bsp_sbrk.c|2321472163,rzn/fsp/src/bsp/mcu/all/bsp_cache.c|225356254,rzn/fsp/src/bsp/mcu/all/bsp_exceptions.h|2518644892,rzn/fsp/src/bsp/mcu/all/bsp_register_protection.c|392613868,rzn/fsp/src/bsp/mcu/all/bsp_reset.c|2238656401,rzn/fsp/src/bsp/mcu/all/bsp_mcu_api.h|1611830052,rzn/fsp/src/bsp/mcu/all/bsp_delay.h|2060190483,rzn/fsp/src/bsp/mcu/all/cr/bsp_cache_core.h|1543064539,rzn/fsp/src/bsp/mcu/all/cr/bsp_delay_core.h|3717942516,rzn/fsp/src/bsp/mcu/all/cr/bsp_cache_core.c|3396795463,rzn/fsp/src/bsp/mcu/all/cr/bsp_irq_core.c|2195931215,rzn/fsp/src/bsp/mcu/all/cr/bsp_delay_core.c|1126344352,rzn/fsp/src/bsp/mcu/all/cr/bsp_irq_core.h|1926319940,rzn/fsp/inc/fsp_features.h|2508067197,rzn/fsp/inc/fsp_version.h|3571247719,rzn/fsp/inc/fsp_common_api.h|3347087544,rzn/fsp/inc/instances/r_ioport.h|1765016794,rzn/fsp/inc/api/bsp_api.h|250199021,rzn/fsp/inc/api/r_ioport_api.h
-com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#BSP\#\#rzn2l\#\#device\#\#R9A07G084M04GBG\#\#2.0.0/libraries=
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#BSP\#\#rzn2l\#\#fsp\#\#\#\#2.0.0/libraries=
com.renesas.cdt.ddsc.project.standalone.projectgenerationoptions/isCpp=false
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#BSP\#\#all\#\#Memory\#\#\#\#2.0.0/libraries=
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#BSP\#\#all\#\#Memory\#\#\#\#2.0.0/all=
com.renesas.cdt.ddsc.packs.componentfiles/Arm\#\#CMSIS\#\#CMSIS5\#\#Core\#\#\#\#5.7.0+renesas.1.fsp.2.0.0/libraries=
+com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#Common\#\#all\#\#fsp_common\#\#\#\#2.0.0/libraries=
+com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#HAL\ Drivers\#\#all\#\#r_rtc\#\#\#\#2.0.0/all=3551601681,rzn/fsp/src/r_rtc/r_rtc.c|3948337697,rzn/fsp/inc/instances/r_rtc.h|3795688877,rzn/fsp/inc/api/r_rtc_api.h
+com.renesas.cdt.ddsc.content/com.renesas.cdt.ddsc.content.defaultlinkerscript=script/fsp_xspi0_boot.icf
+com.renesas.cdt.ddsc.packs.componentfiles/Arm\#\#CMSIS\#\#CMSIS5\#\#Core\#\#\#\#5.7.0+renesas.1.fsp.2.0.0/all=1441545198,rzn/arm/CMSIS_5/LICENSE.txt|4247764709,rzn/arm/CMSIS_5/CMSIS/Core_R/Include/cmsis_gcc.h|1135074086,rzn/arm/CMSIS_5/CMSIS/Core_R/Include/core_cr52.h|510668081,rzn/arm/CMSIS_5/CMSIS/Core_R/Include/cmsis_iccarm.h|4245531541,rzn/arm/CMSIS_5/CMSIS/Core_R/Include/cmsis_compiler.h|1887099957,rzn/arm/CMSIS_5/CMSIS/Core_R/Include/cmsis_cp15.h|3334069041,rzn/arm/CMSIS_5/CMSIS/Core_R/Include/cmsis_version.h
+com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#BSP\#\#rzn2l\#\#device\#\#R9A07G084M04GBG\#\#2.0.0/all=
+com.renesas.cdt.ddsc.settingseditor/com.renesas.cdt.ddsc.settingseditor.active_page=SWPConfigurator
+com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#BSP\#\#rzn2l\#\#device\#\#R9A07G084M04GBG\#\#2.0.0/libraries=
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#HAL\ Drivers\#\#all\#\#r_sci_uart\#\#\#\#2.0.0/all=2921827146,rzn/fsp/src/r_sci_uart/r_sci_uart.c|4093801030,rzn/fsp/inc/instances/r_sci_uart.h|1119704027,rzn/fsp/inc/api/r_uart_api.h|3586794436,rzn/fsp/inc/api/r_transfer_api.h
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#BSP\#\#rzn2l\#\#device\#\#\#\#2.0.0/all=3243637314,rzn/fsp/src/bsp/cmsis/Device/RENESAS/Include/system.h
+com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#HAL\ Drivers\#\#all\#\#r_rtc\#\#\#\#2.0.0/libraries=
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#BSP\#\#rzn2l\#\#device\#\#\#\#2.0.0/libraries=
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#BSP\#\#rzn2l\#\#fsp\#\#\#\#2.0.0/all=2989202485,rzn/fsp/src/bsp/mcu/rzn2l/bsp_loader_param.c|1967641730,rzn/fsp/src/bsp/mcu/rzn2l/bsp_feature.h|1508541487,rzn/fsp/src/bsp/mcu/rzn2l/bsp_elc.h|1088535767,rzn/fsp/src/bsp/mcu/rzn2l/bsp_irq_sense.c|1458388275,rzn/fsp/src/bsp/mcu/rzn2l/bsp_override.h|617637586,rzn/fsp/src/bsp/mcu/rzn2l/bsp_mcu_info.h
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#HAL\ Drivers\#\#all\#\#r_sci_uart\#\#\#\#2.0.0/libraries=
-com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#Common\#\#all\#\#fsp_common\#\#\#\#2.0.0/libraries=
com.renesas.cdt.ddsc.packs.componentfiles/Renesas\#\#HAL\ Drivers\#\#all\#\#r_ioport\#\#\#\#2.0.0/all=615913359,rzn/fsp/src/r_ioport/r_ioport.c|3347087544,rzn/fsp/inc/instances/r_ioport.h|250199021,rzn/fsp/inc/api/r_ioport_api.h
diff --git a/bsp/renesas/rzn2l_rsk/SConscript b/bsp/renesas/rzn2l_rsk/SConscript
index 889ba12c85f..db0ef9c0cb5 100644
--- a/bsp/renesas/rzn2l_rsk/SConscript
+++ b/bsp/renesas/rzn2l_rsk/SConscript
@@ -17,8 +17,7 @@ elif rtconfig.PLATFORM in GetGCCLikePLATFORM():
if GetOption('target') != 'mdk5':
CPPPATH = [cwd]
src = Glob('./src/*.c')
-
-group = DefineGroup('Applications', src, depend = [''], CPPPATH = CPPPATH)
+ group = DefineGroup('Applications', src, depend = [''], CPPPATH = CPPPATH)
for d in list:
path = os.path.join(cwd, d)
diff --git a/bsp/renesas/rzn2l_rsk/board/board.h b/bsp/renesas/rzn2l_rsk/board/board.h
index cf53068064e..baa0abb1c41 100644
--- a/bsp/renesas/rzn2l_rsk/board/board.h
+++ b/bsp/renesas/rzn2l_rsk/board/board.h
@@ -19,7 +19,7 @@ extern "C" {
#include
#include
-#define RZ_SRAM_SIZE 512 /* The SRAM size of the chip needs to be modified */
+#define RZ_SRAM_SIZE 1536 /* The SRAM size of the chip needs to be modified */
#define RZ_SRAM_END (0x10000000 + RZ_SRAM_SIZE * 1024 - 1)
#ifdef __ARMCC_VERSION
@@ -29,7 +29,8 @@ extern int Image$$RAM_END$$ZI$$Base;
#pragma section="CSTACK"
#define HEAP_BEGIN (__segment_end("CSTACK"))
#else
-#define HEAP_BEGIN (0x10000000)
+extern int __bss_end__;
+#define HEAP_BEGIN ((void *)&__bss_end__)
#endif
#define HEAP_END RZ_SRAM_END
@@ -37,7 +38,7 @@ extern int Image$$RAM_END$$ZI$$Base;
/***********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
-#define MAX_HANDLERS (512)
+#define MAX_HANDLERS BSP_VECTOR_TABLE_MAX_ENTRIES
#define GIC_IRQ_START 0
#define GIC_ACK_INTID_MASK (0x000003FFU)
/* number of interrupts on board */
diff --git a/bsp/renesas/rzn2l_rsk/rzn/SConscript b/bsp/renesas/rzn2l_rsk/rzn/SConscript
index 41038bee62c..4ff6ec8599e 100644
--- a/bsp/renesas/rzn2l_rsk/rzn/SConscript
+++ b/bsp/renesas/rzn2l_rsk/rzn/SConscript
@@ -12,13 +12,12 @@ if rtconfig.PLATFORM in ['iccarm']:
Return('group')
elif rtconfig.PLATFORM in GetGCCLikePLATFORM():
if GetOption('target') != 'mdk5':
- src += Glob(cwd + '/fsp/src/bsp/mcu/all/*.c')
- src += Glob(cwd + '/fsp/src/bsp/mcu/all/cr/*.c')
- src += Glob(cwd + '/fsp/src/bsp/mcu/r*/*.c')
- src += Glob(cwd + '/fsp/src/r_*/*.c')
- src += Glob(cwd + '/fsp/src/bsp/cmsis/Device/RENESAS/Source/cr/*.c')
- src += [cwd + '/fsp/src/bsp/cmsis/Device/RENESAS/Source/system.c']
- src += [cwd + '/fsp/src/bsp/cmsis/Device/RENESAS/Source/startup.c']
+ src += Glob('./fsp/src/bsp/mcu/all/*.c')
+ src += Glob('./fsp/src/bsp/mcu/all/cr/*.c')
+ src += Glob('./fsp/src/bsp/mcu/r*/*.c')
+ src += Glob('./fsp/src/bsp/cmsis/Device/RENESAS/Source/*.c')
+ src += Glob('./fsp/src/bsp/cmsis/Device/RENESAS/Source/cr/*.c')
+ src += Glob('./fsp/src/r_*/*.c')
CPPPATH = [ cwd + '/arm/CMSIS_5/CMSIS/Core_R/Include',
cwd + '/fsp/inc',
cwd + '/fsp/inc/api',
diff --git a/bsp/renesas/rzn2l_rsk/script/fsp_xspi0_boot.icf b/bsp/renesas/rzn2l_rsk/script/fsp_xspi0_boot.icf
index 2f14001fa05..03db352850b 100644
--- a/bsp/renesas/rzn2l_rsk/script/fsp_xspi0_boot.icf
+++ b/bsp/renesas/rzn2l_rsk/script/fsp_xspi0_boot.icf
@@ -1,684 +1,684 @@
-include "memory_regions.icf";
-
-/* The memory information for each device is done in memory regions file.
- * The starting address and length of memory not defined in memory regions file are defined as 0. */
-
-if (isdefinedsymbol(ATCM_START))
-{
- define symbol ATCM_PRV_START = ATCM_START;
-}
-else
-{
- define symbol ATCM_PRV_START = 0;
-}
-
-if (isdefinedsymbol(ATCM_LENGTH))
-{
- define symbol ATCM_PRV_LENGTH = ATCM_LENGTH;
-}
-else
-{
- define symbol ATCM_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(BTCM_START))
-{
- define symbol BTCM_PRV_START = BTCM_START;
-}
-else
-{
- define symbol BTCM_PRV_START = 0;
-}
-
-if (isdefinedsymbol(BTCM_LENGTH))
-{
- define symbol BTCM_PRV_LENGTH = BTCM_LENGTH;
-}
-else
-{
- define symbol BTCM_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(SYSTEM_RAM_START))
-{
- define symbol SYSTEM_RAM_PRV_START = SYSTEM_RAM_START;
-}
-else
-{
- define symbol SYSTEM_RAM_PRV_START = 0;
-}
-
-if (isdefinedsymbol(SYSTEM_RAM_LENGTH))
-{
- define symbol SYSTEM_RAM_PRV_LENGTH = SYSTEM_RAM_LENGTH;
-}
-else
-{
- define symbol SYSTEM_RAM_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(SYSTEM_RAM_MIRROR_START))
-{
- define symbol SYSTEM_RAM_MIRROR_PRV_START = SYSTEM_RAM_MIRROR_START;
-}
-else
-{
- define symbol SYSTEM_RAM_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(SYSTEM_RAM_MIRROR_LENGTH))
-{
- define symbol SYSTEM_RAM_MIRROR_PRV_LENGTH = SYSTEM_RAM_MIRROR_LENGTH;
-}
-else
-{
- define symbol SYSTEM_RAM_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS0_SPACE_MIRROR_START))
-{
- define symbol xSPI0_CS0_SPACE_MIRROR_PRV_START = xSPI0_CS0_SPACE_MIRROR_START;
-}
-else
-{
- define symbol xSPI0_CS0_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS0_SPACE_MIRROR_LENGTH))
-{
- define symbol xSPI0_CS0_SPACE_MIRROR_PRV_LENGTH = xSPI0_CS0_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol xSPI0_CS0_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS1_SPACE_MIRROR_START))
-{
- define symbol xSPI0_CS1_SPACE_MIRROR_PRV_START = xSPI0_CS1_SPACE_MIRROR_START;
-}
-else
-{
- define symbol xSPI0_CS1_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS1_SPACE_MIRROR_LENGTH))
-{
- define symbol xSPI0_CS1_SPACE_MIRROR_PRV_LENGTH = xSPI0_CS1_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol xSPI0_CS1_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS0_SPACE_MIRROR_START))
-{
- define symbol xSPI1_CS0_SPACE_MIRROR_PRV_START = xSPI1_CS0_SPACE_MIRROR_START;
-}
-else
-{
- define symbol xSPI1_CS0_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS0_SPACE_MIRROR_LENGTH))
-{
- define symbol xSPI1_CS0_SPACE_MIRROR_PRV_LENGTH = xSPI1_CS0_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol xSPI1_CS0_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS1_SPACE_MIRROR_START))
-{
- define symbol xSPI1_CS1_SPACE_MIRROR_PRV_START = xSPI1_CS1_SPACE_MIRROR_START;
-}
-else
-{
- define symbol xSPI1_CS1_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS1_SPACE_MIRROR_LENGTH))
-{
- define symbol xSPI1_CS1_SPACE_MIRROR_PRV_LENGTH = xSPI1_CS1_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol xSPI1_CS1_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS0_SPACE_MIRROR_START))
-{
- define symbol CS0_SPACE_MIRROR_PRV_START = CS0_SPACE_MIRROR_START;
-}
-else
-{
- define symbol CS0_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS0_SPACE_MIRROR_LENGTH))
-{
- define symbol CS0_SPACE_MIRROR_PRV_LENGTH = CS0_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol CS0_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS2_SPACE_MIRROR_START))
-{
- define symbol CS2_SPACE_MIRROR_PRV_START = CS2_SPACE_MIRROR_START;
-}
-else
-{
- define symbol CS2_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS2_SPACE_MIRROR_LENGTH))
-{
- define symbol CS2_SPACE_MIRROR_PRV_LENGTH = CS2_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol CS2_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-
-if (isdefinedsymbol(CS3_SPACE_MIRROR_START))
-{
- define symbol CS3_SPACE_MIRROR_PRV_START = CS3_SPACE_MIRROR_START;
-}
-else
-{
- define symbol CS3_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS3_SPACE_MIRROR_LENGTH))
-{
- define symbol CS3_SPACE_MIRROR_PRV_LENGTH = CS3_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol CS3_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS5_SPACE_MIRROR_START))
-{
- define symbol CS5_SPACE_MIRROR_PRV_START = CS5_SPACE_MIRROR_START;
-}
-else
-{
- define symbol CS5_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS5_SPACE_MIRROR_LENGTH))
-{
- define symbol CS5_SPACE_MIRROR_PRV_LENGTH = CS5_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol CS5_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-
-if (isdefinedsymbol(xSPI0_CS0_SPACE_START))
-{
- define symbol xSPI0_CS0_SPACE_PRV_START = xSPI0_CS0_SPACE_START;
-}
-else
-{
- define symbol xSPI0_CS0_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS0_SPACE_LENGTH))
-{
- define symbol xSPI0_CS0_SPACE_PRV_LENGTH = xSPI0_CS0_SPACE_LENGTH;
-}
-else
-{
- define symbol xSPI0_CS0_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS1_SPACE_START))
-{
- define symbol xSPI0_CS1_SPACE_PRV_START = xSPI0_CS1_SPACE_START;
-}
-else
-{
- define symbol xSPI0_CS1_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS1_SPACE_LENGTH))
-{
- define symbol xSPI0_CS1_SPACE_PRV_LENGTH = xSPI0_CS1_SPACE_LENGTH;
-}
-else
-{
- define symbol xSPI0_CS1_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS0_SPACE_START))
-{
- define symbol xSPI1_CS0_SPACE_PRV_START = xSPI1_CS0_SPACE_START;
-}
-else
-{
- define symbol xSPI1_CS0_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS0_SPACE_LENGTH))
-{
- define symbol xSPI1_CS0_SPACE_PRV_LENGTH = xSPI1_CS0_SPACE_LENGTH;
-}
-else
-{
- define symbol xSPI1_CS0_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS1_SPACE_START))
-{
- define symbol xSPI1_CS1_SPACE_PRV_START = xSPI1_CS1_SPACE_START;
-}
-else
-{
- define symbol xSPI1_CS1_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS1_SPACE_LENGTH))
-{
- define symbol xSPI1_CS1_SPACE_PRV_LENGTH = xSPI1_CS1_SPACE_LENGTH;
-}
-else
-{
- define symbol xSPI1_CS1_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS0_SPACE_START))
-{
- define symbol CS0_SPACE_PRV_START = CS0_SPACE_START;
-}
-else
-{
- define symbol CS0_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS0_SPACE_LENGTH))
-{
- define symbol CS0_SPACE_PRV_LENGTH = CS0_SPACE_LENGTH;
-}
-else
-{
- define symbol CS0_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS2_SPACE_START))
-{
- define symbol CS2_SPACE_PRV_START = CS2_SPACE_START;
-}
-else
-{
- define symbol CS2_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS2_SPACE_LENGTH))
-{
- define symbol CS2_SPACE_PRV_LENGTH = CS2_SPACE_LENGTH;
-}
-else
-{
- define symbol CS2_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS3_SPACE_START))
-{
- define symbol CS3_SPACE_PRV_START = CS3_SPACE_START;
-}
-else
-{
- define symbol CS3_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS3_SPACE_LENGTH))
-{
- define symbol CS3_SPACE_PRV_LENGTH = CS3_SPACE_LENGTH;
-}
-else
-{
- define symbol CS3_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS5_SPACE_START))
-{
- define symbol CS5_SPACE_PRV_START = CS5_SPACE_START;
-}
-else
-{
- define symbol CS5_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS5_SPACE_LENGTH))
-{
- define symbol CS5_SPACE_PRV_LENGTH = CS5_SPACE_LENGTH;
-}
-else
-{
- define symbol CS5_SPACE_PRV_LENGTH = 0;
-}
-
-define symbol SYSTEM_RAM_END_OFFSET = 0x00048000;
-define symbol FLASH_ADDRESS = xSPI0_CS0_SPACE_PRV_START;
-
-define symbol INTVEC_ADDRESS = ATCM_PRV_START;
-define symbol RAM_ADDRESS = (ATCM_PRV_START + 0x100);
-define symbol RAM_END_ADDRESS = (ATCM_PRV_START + ATCM_PRV_LENGTH - 1);
-define symbol LOADER_STACK_ADDRESS = (BTCM_PRV_START + 0x2000);
-define symbol LOADER_STACK_END_ADDRESS = (BTCM_PRV_START + BTCM_PRV_LENGTH - 1);
-define symbol DATA_NONCACHE_OFFSET = 0x00048000;
-define symbol DATA_NONCACHE_END_OFFSET = 0x00044000;
-define symbol DMAC_LINK_MODE_OFFSET = 0x00044000;
-define symbol DMAC_LINK_MODE_END_OFFSET = 0x00040000;
-define symbol NONCACHE_BUFFER_OFFSET = 0x00020000;
-define symbol NONCACHE_BUFFER_END_OFFSET = 0;
-
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\a_v1_0.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = INTVEC_ADDRESS;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_ROM_start__ = FLASH_ADDRESS + 0x20100;
-define symbol __ICFEDIT_region_ROM_end__ = FLASH_ADDRESS + 0x6FFFF;
-define symbol __ICFEDIT_region_RAM_start__ = RAM_ADDRESS;
-define symbol __ICFEDIT_region_RAM_end__ = RAM_END_ADDRESS;
-/**** End of ICF editor section. ###ICF###*/
-
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 0x200;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
-define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
-
-define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
-
-define symbol __region_D_LOADER_STACK_start__ = LOADER_STACK_ADDRESS;
-define symbol __region_D_LOADER_STACK_end__ = LOADER_STACK_END_ADDRESS;
-
-define symbol __region_DATA_NONCACHE_start__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - DATA_NONCACHE_OFFSET;
-define symbol __region_DATA_NONCACHE_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - DATA_NONCACHE_END_OFFSET - 1;
-define symbol __region_DMAC_LINK_MODE_start__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - DMAC_LINK_MODE_OFFSET;
-define symbol __region_DMAC_LINK_MODE_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - DMAC_LINK_MODE_END_OFFSET - 1;
-define symbol __region_SHARED_NONCACHE_BUFFER_start__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - 0x00040000;
-define symbol __region_SHARED_NONCACHE_BUFFER_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - 0x00020000 - 1;
-define symbol __region_NONCACHE_BUFFER_start__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - NONCACHE_BUFFER_OFFSET;
-define symbol __region_NONCACHE_BUFFER_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - NONCACHE_BUFFER_END_OFFSET - 1;
-
-define symbol __region_ATCM_start__ = ATCM_PRV_START;
-define symbol __region_ATCM_end__ = ATCM_PRV_START + ATCM_PRV_LENGTH - 1;
-define symbol __region_BTCM_start__ = BTCM_PRV_START;
-define symbol __region_BTCM_end__ = BTCM_PRV_START + BTCM_PRV_LENGTH - 1;
-define symbol __region_SYSTEM_RAM_start__ = SYSTEM_RAM_PRV_START;
-define symbol __region_SYSTEM_RAM_end__ = SYSTEM_RAM_PRV_START + SYSTEM_RAM_PRV_LENGTH - SYSTEM_RAM_END_OFFSET - 1;
-define symbol __region_SYSTEM_RAM_MIRROR_start__ = SYSTEM_RAM_MIRROR_PRV_START;
-define symbol __region_SYSTEM_RAM_MIRROR_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - SYSTEM_RAM_END_OFFSET - 1;
-
-define symbol __region_XSPI0_CS0_MIRROR_start__ = xSPI0_CS0_SPACE_MIRROR_PRV_START;
-define symbol __region_XSPI0_CS0_MIRROR_end__ = xSPI0_CS0_SPACE_MIRROR_PRV_START + xSPI0_CS0_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_XSPI0_CS1_MIRROR_start__ = xSPI0_CS1_SPACE_MIRROR_PRV_START;
-define symbol __region_XSPI0_CS1_MIRROR_end__ = xSPI0_CS1_SPACE_MIRROR_PRV_START + xSPI0_CS1_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_XSPI1_CS0_MIRROR_start__ = xSPI1_CS0_SPACE_MIRROR_PRV_START;
-define symbol __region_XSPI1_CS0_MIRROR_end__ = xSPI1_CS0_SPACE_MIRROR_PRV_START + xSPI1_CS0_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_XSPI1_CS1_MIRROR_start__ = xSPI1_CS1_SPACE_MIRROR_PRV_START;
-define symbol __region_XSPI1_CS1_MIRROR_end__ = xSPI1_CS1_SPACE_MIRROR_PRV_START + xSPI1_CS1_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_CS0_MIRROR_start__ = CS0_SPACE_MIRROR_PRV_START;
-define symbol __region_CS0_MIRROR_end__ = CS0_SPACE_MIRROR_PRV_START + CS0_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_CS2_MIRROR_start__ = CS2_SPACE_MIRROR_PRV_START;
-define symbol __region_CS2_MIRROR_end__ = CS2_SPACE_MIRROR_PRV_START + CS2_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_CS3_MIRROR_start__ = CS3_SPACE_MIRROR_PRV_START;
-define symbol __region_CS3_MIRROR_end__ = CS3_SPACE_MIRROR_PRV_START + CS3_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_CS5_MIRROR_start__ = CS5_SPACE_MIRROR_PRV_START;
-define symbol __region_CS5_MIRROR_end__ = CS5_SPACE_MIRROR_PRV_START + CS5_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_XSPI0_CS0_start__ = xSPI0_CS0_SPACE_PRV_START;
-define symbol __region_XSPI0_CS0_end__ = xSPI0_CS0_SPACE_PRV_START + xSPI0_CS0_SPACE_PRV_LENGTH - 1;
-define symbol __region_XSPI0_CS1_start__ = xSPI0_CS1_SPACE_PRV_START;
-define symbol __region_XSPI0_CS1_end__ = xSPI0_CS1_SPACE_PRV_START + xSPI0_CS1_SPACE_PRV_LENGTH - 1;
-define symbol __region_XSPI1_CS0_start__ = xSPI1_CS0_SPACE_PRV_START;
-define symbol __region_XSPI1_CS0_end__ = xSPI1_CS0_SPACE_PRV_START + xSPI1_CS0_SPACE_PRV_LENGTH - 1;
-define symbol __region_XSPI1_CS1_start__ = xSPI1_CS1_SPACE_PRV_START;
-define symbol __region_XSPI1_CS1_end__ = xSPI1_CS1_SPACE_PRV_START + xSPI1_CS1_SPACE_PRV_LENGTH - 1;
-define symbol __region_CS0_start__ = CS0_SPACE_PRV_START;
-define symbol __region_CS0_end__ = CS0_SPACE_PRV_START + CS0_SPACE_PRV_LENGTH - 1;
-define symbol __region_CS2_start__ = CS2_SPACE_PRV_START;
-define symbol __region_CS2_end__ = CS2_SPACE_PRV_START + CS2_SPACE_PRV_LENGTH - 1;
-define symbol __region_CS3_start__ = CS3_SPACE_PRV_START;
-define symbol __region_CS3_end__ = CS3_SPACE_PRV_START + CS3_SPACE_PRV_LENGTH - 1;
-define symbol __region_CS5_start__ = CS5_SPACE_PRV_START;
-define symbol __region_CS5_end__ = CS5_SPACE_PRV_START + CS5_SPACE_PRV_LENGTH - 1;
-
-/************** SPI boot mode setting **************/
-define symbol __region_LDR_PARAM_start__ = FLASH_ADDRESS;
-define symbol __region_LDR_PARAM_end__ = FLASH_ADDRESS + 0x0000004B;
-define symbol __region_S_LOADER_STACK_start__ = FLASH_ADDRESS + 0x0000004C;
-define symbol __region_S_LOADER_STACK_end__ = FLASH_ADDRESS + 0x0000804B;
-
-define symbol __region_S_intvec_start__ = FLASH_ADDRESS + 0x20000;
-define symbol __region_S_intvec_end__ = FLASH_ADDRESS + 0x200FF;
-define symbol __region_S_RAM_start__ = FLASH_ADDRESS + 0x70000;
-define symbol __region_S_RAM_end__ = FLASH_ADDRESS + 0x7FFFF;
-/****************************************************/
-
-define region D_LOADER_STACK_region = mem:[from __region_D_LOADER_STACK_start__ to __region_D_LOADER_STACK_end__];
-
-define region LDR_PARAM_region = mem:[from __region_LDR_PARAM_start__ to __region_LDR_PARAM_end__];
-define region S_LOADER_STACK_region = mem:[from __region_S_LOADER_STACK_start__ to __region_S_LOADER_STACK_end__];
-
-define region S_intvec_region = mem:[from __region_S_intvec_start__ to __region_S_intvec_end__];
-define region S_RAM_region = mem:[from __region_S_RAM_start__ to __region_S_RAM_end__];
-
-define region DATA_NONCACHE_region = mem:[from __region_DATA_NONCACHE_start__ to __region_DATA_NONCACHE_end__];
-define region DMAC_LINK_MODE_region = mem:[from __region_DMAC_LINK_MODE_start__ to __region_DMAC_LINK_MODE_end__];
-define region SHARED_NONCACHE_BUFFER_region = mem:[from __region_SHARED_NONCACHE_BUFFER_start__ to __region_SHARED_NONCACHE_BUFFER_end__];
-define region NONCACHE_BUFFER_region = mem:[from __region_NONCACHE_BUFFER_start__ to __region_NONCACHE_BUFFER_end__];
-
-define region ATCM_region = mem:[from __region_ATCM_start__ to __region_ATCM_end__ ];
-define region BTCM_region = mem:[from __region_BTCM_start__ to __region_BTCM_end__ ];
-define region SYSTEM_RAM_region = mem:[from __region_SYSTEM_RAM_start__ to __region_SYSTEM_RAM_end__ ];
-define region SYSTEM_RAM_MIRROR_region = mem:[from __region_SYSTEM_RAM_MIRROR_start__ to __region_SYSTEM_RAM_MIRROR_end__ ];
-define region XSPI0_CS0_MIRROR_region = mem:[from __region_XSPI0_CS0_MIRROR_start__ to __region_XSPI0_CS0_MIRROR_end__ ];
-define region XSPI0_CS1_MIRROR_region = mem:[from __region_XSPI0_CS1_MIRROR_start__ to __region_XSPI0_CS1_MIRROR_end__ ];
-define region XSPI1_CS0_MIRROR_region = mem:[from __region_XSPI1_CS0_MIRROR_start__ to __region_XSPI1_CS0_MIRROR_end__ ];
-define region XSPI1_CS1_MIRROR_region = mem:[from __region_XSPI1_CS1_MIRROR_start__ to __region_XSPI1_CS1_MIRROR_end__ ];
-define region CS0_MIRROR_region = mem:[from __region_CS0_MIRROR_start__ to __region_CS0_MIRROR_end__ ];
-define region CS2_MIRROR_region = mem:[from __region_CS2_MIRROR_start__ to __region_CS2_MIRROR_end__ ];
-define region CS3_MIRROR_region = mem:[from __region_CS3_MIRROR_start__ to __region_CS3_MIRROR_end__ ];
-define region CS5_MIRROR_region = mem:[from __region_CS5_MIRROR_start__ to __region_CS5_MIRROR_end__ ];
-define region XSPI0_CS0_region = mem:[from __region_XSPI0_CS0_start__ to __region_XSPI0_CS0_end__ ];
-define region XSPI0_CS1_region = mem:[from __region_XSPI0_CS1_start__ to __region_XSPI0_CS1_end__ ];
-define region XSPI1_CS0_region = mem:[from __region_XSPI1_CS0_start__ to __region_XSPI1_CS0_end__ ];
-define region XSPI1_CS1_region = mem:[from __region_XSPI1_CS1_start__ to __region_XSPI1_CS1_end__ ];
-define region CS0_region = mem:[from __region_CS0_start__ to __region_CS0_end__ ];
-define region CS2_region = mem:[from __region_CS2_start__ to __region_CS2_end__ ];
-define region CS3_region = mem:[from __region_CS3_start__ to __region_CS3_end__ ];
-define region CS5_region = mem:[from __region_CS5_start__ to __region_CS5_end__ ];
-
-define block LDR_PRG_RBLOCK with fixed order
- { ro code section .loader_text_init object startup_core.o,
- ro code object startup_core.o,
- ro code object system_core.o,
- ro code object startup.o,
- ro code object system.o,
- ro code object bsp_clocks.o,
- ro code object bsp_irq_core.o,
- ro code object bsp_irq.o,
- ro code object bsp_register_protection.o,
- ro code object r_ioport.o,
- ro code object bsp_cache.o,
- ro code section .warm_start_init }
- except { ro code section .intvec_init,
- ro code section .reset_handler_init };
-define block LDR_PRG_WBLOCK with fixed order
- { rw code section .loader_text object startup_core.o,
- rw code object startup_core.o,
- rw code object system_core.o,
- rw code object startup.o,
- rw code object system.o,
- rw code object bsp_clocks.o,
- rw code object bsp_irq_core.o,
- rw code object bsp_irq.o,
- rw code object bsp_register_protection.o,
- rw code object r_ioport.o,
- rw code object bsp_cache.o,
- rw code section .warm_start }
- except { rw code section .intvec,
- rw code section .reset_handler };
-define block LDR_DATA_ZBLOCK with alignment = 4
- { section .bss object startup_core.o,
- section .bss object system_core.o,
- section .bss object startup.o,
- section .bss object system.o,
- section .bss object bsp_clocks.o,
- section .bss object bsp_irq_core.o,
- section .bss object bsp_irq.o,
- section .bss object bsp_register_protection.o,
- section .bss object r_ioport.o,
- section .bss object bsp_cache.o,
- section .bss object bsp_io.o };
-define block LDR_DATA_RBLOCK with fixed order, alignment = 4
- { section .data_init object startup_core.o,
- section .data_init object system_core.o,
- section .data_init object startup.o,
- section .data_init object system.o,
- section .data_init object bsp_clocks.o,
- section .data_init object bsp_irq_core.o,
- section .data_init object bsp_irq.o,
- section .data_init object bsp_register_protection.o,
- section .data_init object r_ioport.o,
- section .data_init object bsp_cache.o,
- section .rodata_init object system_core.o };
-define block LDR_DATA_WBLOCK with fixed order, alignment = 4
- { section .data object startup_core.o,
- section .data object system_core.o,
- section .data object startup.o,
- section .data object system.o,
- section .data object bsp_clocks.o,
- section .data object bsp_irq_core.o,
- section .data object bsp_irq.o,
- section .data object bsp_register_protection.o,
- section .data object r_ioport.o,
- section .data object bsp_cache.o,
- section .rodata object system_core.o };
-
-define block HEAP_BLOCK with alignment = 8 { rw section HEAP };
-define block THREAD_STACK with alignment = 8 { rw section .stack* };
-define block SYS_STACK with alignment = 8 { rw section .sys_stack };
-define block SVC_STACK with alignment = 8 { rw section .svc_stack };
-define block IRQ_STACK with alignment = 8 { rw section .irq_stack };
-define block FIQ_STACK with alignment = 8 { rw section .fiq_stack };
-define block UND_STACK with alignment = 8 { rw section .und_stack };
-define block ABT_STACK with alignment = 8 { rw section .abt_stack };
-
-define block VECTOR_RBLOCK with alignment = 32 { ro code section .intvec_init};
-define block VECTOR_WBLOCK with alignment = 32 { rw code section .intvec};
-define block USER_PRG_RBLOCK with alignment = 4 { ro code };
-define block USER_PRG_WBLOCK with alignment = 4 { rw code };
-define block USER_DATA_ZBLOCK with alignment = 4 { section .bss };
-define block USER_DATA_RBLOCK with fixed order, alignment = 4
- { section .data_init,
- section __DLIB_PERTHREAD_init,
- section .rodata_init,
- section .version_init };
-define block USER_DATA_WBLOCK with fixed order, alignment = 4
- { section .data,
- section __DLIB_PERTHREAD,
- section .rodata,
- section .version };
-define block USER_DATA_NONCACHE_RBLOCK with alignment = 4 { section .data_noncache_init };
-define block USER_DATA_NONCACHE_WBLOCK with alignment = 4 { section .data_noncache };
-define block DMAC_LINK_MODE_ZBLOCK with alignment = 4 { section .dmac_link_mode* };
-define block SHARED_NONCACHE_BUFFER_ZBLOCK with alignment = 32 { section .shared_noncache_buffer* };
-define block NONCACHE_BUFFER_ZBLOCK with alignment = 32 { section .noncache_buffer* };
-
-initialize manually { ro code object startup_core.o,
- ro code object system_core.o,
- ro code object startup.o,
- ro code object system.o,
- ro code object bsp_clocks.o,
- ro code object bsp_irq_core.o,
- ro code object bsp_irq.o,
- ro code object bsp_register_protection.o,
- ro code object r_ioport.o,
- ro code object bsp_cache.o,
- ro code section .intvec,
- ro code section .reset_handler,
- ro code section .warm_start,
- ro code,
- section .data,
- section __DLIB_PERTHREAD,
- section .rodata,
- section .version,
- section .data_noncache };
-
-do not initialize { section .noinit,
- section .bss,
- section .dmac_link_mode*,
- section .shared_noncache_buffer*,
- section .noncache_buffer*,
- rw section HEAP,
- rw section .stack*,
- rw section .sys_stack,
- rw section .svc_stack,
- rw section .irq_stack,
- rw section .fiq_stack,
- rw section .und_stack,
- rw section .abt_stack };
-
-place at address mem: __ICFEDIT_intvec_start__ { block VECTOR_WBLOCK };
-
-place in LDR_PARAM_region { readonly section .loader_param };
-place at start of S_LOADER_STACK_region { block LDR_PRG_RBLOCK };
-place in S_LOADER_STACK_region { section LDR_DATA_RBLOCK, block LDR_DATA_RBLOCK };
-place in S_intvec_region { block VECTOR_RBLOCK };
-place in ROM_region { block USER_PRG_RBLOCK, readonly };
-place in S_RAM_region { block USER_DATA_RBLOCK, block USER_DATA_NONCACHE_RBLOCK };
-
-place at start of D_LOADER_STACK_region { block LDR_PRG_WBLOCK };
-place in D_LOADER_STACK_region { section LDR_DATA_WBLOCK, block LDR_DATA_WBLOCK,
- section LDR_DATA_ZBLOCK, block LDR_DATA_ZBLOCK };
-place in D_LOADER_STACK_region { section SYS_STACK, block SYS_STACK,
- section SVC_STACK, block SVC_STACK,
- section IRQ_STACK, block IRQ_STACK,
- section FIQ_STACK, block FIQ_STACK,
- section UND_STACK, block UND_STACK,
- section ABT_STACK, block ABT_STACK };
-place in RAM_region { block USER_PRG_WBLOCK };
-place in RAM_region { readwrite, last block CSTACK };
-place in RAM_region { block USER_DATA_WBLOCK,
- block USER_DATA_ZBLOCK };
-place in RAM_region { section HEAP_BLOCK, block HEAP_BLOCK,
- section THREAD_STACK, block THREAD_STACK };
-
-place in DATA_NONCACHE_region { block USER_DATA_NONCACHE_WBLOCK };
-place in DMAC_LINK_MODE_region { block DMAC_LINK_MODE_ZBLOCK };
-place in SHARED_NONCACHE_BUFFER_region { block SHARED_NONCACHE_BUFFER_ZBLOCK };
-place in NONCACHE_BUFFER_region { block NONCACHE_BUFFER_ZBLOCK };
-place in ATCM_region { };
-place in BTCM_region { };
-place in SYSTEM_RAM_region { };
-place in SYSTEM_RAM_MIRROR_region { };
-place in XSPI0_CS0_MIRROR_region { };
-place in XSPI0_CS1_MIRROR_region { };
-place in XSPI1_CS0_MIRROR_region { };
-place in XSPI1_CS1_MIRROR_region { };
-place in CS0_MIRROR_region { };
-place in CS2_MIRROR_region { };
-place in CS3_MIRROR_region { };
-place in CS5_MIRROR_region { };
-place in XSPI0_CS0_region { };
-place in XSPI0_CS1_region { };
-place in XSPI1_CS0_region { };
-place in XSPI1_CS1_region { };
-place in CS0_region { };
-place in CS2_region { };
-place in CS3_region { };
-place in CS5_region { };
+include "memory_regions.icf";
+
+/* The memory information for each device is done in memory regions file.
+ * The starting address and length of memory not defined in memory regions file are defined as 0. */
+
+if (isdefinedsymbol(ATCM_START))
+{
+ define symbol ATCM_PRV_START = ATCM_START;
+}
+else
+{
+ define symbol ATCM_PRV_START = 0;
+}
+
+if (isdefinedsymbol(ATCM_LENGTH))
+{
+ define symbol ATCM_PRV_LENGTH = ATCM_LENGTH;
+}
+else
+{
+ define symbol ATCM_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(BTCM_START))
+{
+ define symbol BTCM_PRV_START = BTCM_START;
+}
+else
+{
+ define symbol BTCM_PRV_START = 0;
+}
+
+if (isdefinedsymbol(BTCM_LENGTH))
+{
+ define symbol BTCM_PRV_LENGTH = BTCM_LENGTH;
+}
+else
+{
+ define symbol BTCM_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(SYSTEM_RAM_START))
+{
+ define symbol SYSTEM_RAM_PRV_START = SYSTEM_RAM_START;
+}
+else
+{
+ define symbol SYSTEM_RAM_PRV_START = 0;
+}
+
+if (isdefinedsymbol(SYSTEM_RAM_LENGTH))
+{
+ define symbol SYSTEM_RAM_PRV_LENGTH = SYSTEM_RAM_LENGTH;
+}
+else
+{
+ define symbol SYSTEM_RAM_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(SYSTEM_RAM_MIRROR_START))
+{
+ define symbol SYSTEM_RAM_MIRROR_PRV_START = SYSTEM_RAM_MIRROR_START;
+}
+else
+{
+ define symbol SYSTEM_RAM_MIRROR_PRV_START = 0;
+}
+
+if (isdefinedsymbol(SYSTEM_RAM_MIRROR_LENGTH))
+{
+ define symbol SYSTEM_RAM_MIRROR_PRV_LENGTH = SYSTEM_RAM_MIRROR_LENGTH;
+}
+else
+{
+ define symbol SYSTEM_RAM_MIRROR_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(xSPI0_CS0_SPACE_MIRROR_START))
+{
+ define symbol xSPI0_CS0_SPACE_MIRROR_PRV_START = xSPI0_CS0_SPACE_MIRROR_START;
+}
+else
+{
+ define symbol xSPI0_CS0_SPACE_MIRROR_PRV_START = 0;
+}
+
+if (isdefinedsymbol(xSPI0_CS0_SPACE_MIRROR_LENGTH))
+{
+ define symbol xSPI0_CS0_SPACE_MIRROR_PRV_LENGTH = xSPI0_CS0_SPACE_MIRROR_LENGTH;
+}
+else
+{
+ define symbol xSPI0_CS0_SPACE_MIRROR_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(xSPI0_CS1_SPACE_MIRROR_START))
+{
+ define symbol xSPI0_CS1_SPACE_MIRROR_PRV_START = xSPI0_CS1_SPACE_MIRROR_START;
+}
+else
+{
+ define symbol xSPI0_CS1_SPACE_MIRROR_PRV_START = 0;
+}
+
+if (isdefinedsymbol(xSPI0_CS1_SPACE_MIRROR_LENGTH))
+{
+ define symbol xSPI0_CS1_SPACE_MIRROR_PRV_LENGTH = xSPI0_CS1_SPACE_MIRROR_LENGTH;
+}
+else
+{
+ define symbol xSPI0_CS1_SPACE_MIRROR_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(xSPI1_CS0_SPACE_MIRROR_START))
+{
+ define symbol xSPI1_CS0_SPACE_MIRROR_PRV_START = xSPI1_CS0_SPACE_MIRROR_START;
+}
+else
+{
+ define symbol xSPI1_CS0_SPACE_MIRROR_PRV_START = 0;
+}
+
+if (isdefinedsymbol(xSPI1_CS0_SPACE_MIRROR_LENGTH))
+{
+ define symbol xSPI1_CS0_SPACE_MIRROR_PRV_LENGTH = xSPI1_CS0_SPACE_MIRROR_LENGTH;
+}
+else
+{
+ define symbol xSPI1_CS0_SPACE_MIRROR_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(xSPI1_CS1_SPACE_MIRROR_START))
+{
+ define symbol xSPI1_CS1_SPACE_MIRROR_PRV_START = xSPI1_CS1_SPACE_MIRROR_START;
+}
+else
+{
+ define symbol xSPI1_CS1_SPACE_MIRROR_PRV_START = 0;
+}
+
+if (isdefinedsymbol(xSPI1_CS1_SPACE_MIRROR_LENGTH))
+{
+ define symbol xSPI1_CS1_SPACE_MIRROR_PRV_LENGTH = xSPI1_CS1_SPACE_MIRROR_LENGTH;
+}
+else
+{
+ define symbol xSPI1_CS1_SPACE_MIRROR_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(CS0_SPACE_MIRROR_START))
+{
+ define symbol CS0_SPACE_MIRROR_PRV_START = CS0_SPACE_MIRROR_START;
+}
+else
+{
+ define symbol CS0_SPACE_MIRROR_PRV_START = 0;
+}
+
+if (isdefinedsymbol(CS0_SPACE_MIRROR_LENGTH))
+{
+ define symbol CS0_SPACE_MIRROR_PRV_LENGTH = CS0_SPACE_MIRROR_LENGTH;
+}
+else
+{
+ define symbol CS0_SPACE_MIRROR_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(CS2_SPACE_MIRROR_START))
+{
+ define symbol CS2_SPACE_MIRROR_PRV_START = CS2_SPACE_MIRROR_START;
+}
+else
+{
+ define symbol CS2_SPACE_MIRROR_PRV_START = 0;
+}
+
+if (isdefinedsymbol(CS2_SPACE_MIRROR_LENGTH))
+{
+ define symbol CS2_SPACE_MIRROR_PRV_LENGTH = CS2_SPACE_MIRROR_LENGTH;
+}
+else
+{
+ define symbol CS2_SPACE_MIRROR_PRV_LENGTH = 0;
+}
+
+
+if (isdefinedsymbol(CS3_SPACE_MIRROR_START))
+{
+ define symbol CS3_SPACE_MIRROR_PRV_START = CS3_SPACE_MIRROR_START;
+}
+else
+{
+ define symbol CS3_SPACE_MIRROR_PRV_START = 0;
+}
+
+if (isdefinedsymbol(CS3_SPACE_MIRROR_LENGTH))
+{
+ define symbol CS3_SPACE_MIRROR_PRV_LENGTH = CS3_SPACE_MIRROR_LENGTH;
+}
+else
+{
+ define symbol CS3_SPACE_MIRROR_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(CS5_SPACE_MIRROR_START))
+{
+ define symbol CS5_SPACE_MIRROR_PRV_START = CS5_SPACE_MIRROR_START;
+}
+else
+{
+ define symbol CS5_SPACE_MIRROR_PRV_START = 0;
+}
+
+if (isdefinedsymbol(CS5_SPACE_MIRROR_LENGTH))
+{
+ define symbol CS5_SPACE_MIRROR_PRV_LENGTH = CS5_SPACE_MIRROR_LENGTH;
+}
+else
+{
+ define symbol CS5_SPACE_MIRROR_PRV_LENGTH = 0;
+}
+
+
+if (isdefinedsymbol(xSPI0_CS0_SPACE_START))
+{
+ define symbol xSPI0_CS0_SPACE_PRV_START = xSPI0_CS0_SPACE_START;
+}
+else
+{
+ define symbol xSPI0_CS0_SPACE_PRV_START = 0;
+}
+
+if (isdefinedsymbol(xSPI0_CS0_SPACE_LENGTH))
+{
+ define symbol xSPI0_CS0_SPACE_PRV_LENGTH = xSPI0_CS0_SPACE_LENGTH;
+}
+else
+{
+ define symbol xSPI0_CS0_SPACE_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(xSPI0_CS1_SPACE_START))
+{
+ define symbol xSPI0_CS1_SPACE_PRV_START = xSPI0_CS1_SPACE_START;
+}
+else
+{
+ define symbol xSPI0_CS1_SPACE_PRV_START = 0;
+}
+
+if (isdefinedsymbol(xSPI0_CS1_SPACE_LENGTH))
+{
+ define symbol xSPI0_CS1_SPACE_PRV_LENGTH = xSPI0_CS1_SPACE_LENGTH;
+}
+else
+{
+ define symbol xSPI0_CS1_SPACE_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(xSPI1_CS0_SPACE_START))
+{
+ define symbol xSPI1_CS0_SPACE_PRV_START = xSPI1_CS0_SPACE_START;
+}
+else
+{
+ define symbol xSPI1_CS0_SPACE_PRV_START = 0;
+}
+
+if (isdefinedsymbol(xSPI1_CS0_SPACE_LENGTH))
+{
+ define symbol xSPI1_CS0_SPACE_PRV_LENGTH = xSPI1_CS0_SPACE_LENGTH;
+}
+else
+{
+ define symbol xSPI1_CS0_SPACE_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(xSPI1_CS1_SPACE_START))
+{
+ define symbol xSPI1_CS1_SPACE_PRV_START = xSPI1_CS1_SPACE_START;
+}
+else
+{
+ define symbol xSPI1_CS1_SPACE_PRV_START = 0;
+}
+
+if (isdefinedsymbol(xSPI1_CS1_SPACE_LENGTH))
+{
+ define symbol xSPI1_CS1_SPACE_PRV_LENGTH = xSPI1_CS1_SPACE_LENGTH;
+}
+else
+{
+ define symbol xSPI1_CS1_SPACE_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(CS0_SPACE_START))
+{
+ define symbol CS0_SPACE_PRV_START = CS0_SPACE_START;
+}
+else
+{
+ define symbol CS0_SPACE_PRV_START = 0;
+}
+
+if (isdefinedsymbol(CS0_SPACE_LENGTH))
+{
+ define symbol CS0_SPACE_PRV_LENGTH = CS0_SPACE_LENGTH;
+}
+else
+{
+ define symbol CS0_SPACE_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(CS2_SPACE_START))
+{
+ define symbol CS2_SPACE_PRV_START = CS2_SPACE_START;
+}
+else
+{
+ define symbol CS2_SPACE_PRV_START = 0;
+}
+
+if (isdefinedsymbol(CS2_SPACE_LENGTH))
+{
+ define symbol CS2_SPACE_PRV_LENGTH = CS2_SPACE_LENGTH;
+}
+else
+{
+ define symbol CS2_SPACE_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(CS3_SPACE_START))
+{
+ define symbol CS3_SPACE_PRV_START = CS3_SPACE_START;
+}
+else
+{
+ define symbol CS3_SPACE_PRV_START = 0;
+}
+
+if (isdefinedsymbol(CS3_SPACE_LENGTH))
+{
+ define symbol CS3_SPACE_PRV_LENGTH = CS3_SPACE_LENGTH;
+}
+else
+{
+ define symbol CS3_SPACE_PRV_LENGTH = 0;
+}
+
+if (isdefinedsymbol(CS5_SPACE_START))
+{
+ define symbol CS5_SPACE_PRV_START = CS5_SPACE_START;
+}
+else
+{
+ define symbol CS5_SPACE_PRV_START = 0;
+}
+
+if (isdefinedsymbol(CS5_SPACE_LENGTH))
+{
+ define symbol CS5_SPACE_PRV_LENGTH = CS5_SPACE_LENGTH;
+}
+else
+{
+ define symbol CS5_SPACE_PRV_LENGTH = 0;
+}
+
+define symbol SYSTEM_RAM_END_OFFSET = 0x00048000;
+define symbol FLASH_ADDRESS = xSPI0_CS0_SPACE_PRV_START;
+
+define symbol INTVEC_ADDRESS = ATCM_PRV_START;
+define symbol RAM_ADDRESS = (ATCM_PRV_START + 0x100);
+define symbol RAM_END_ADDRESS = (ATCM_PRV_START + ATCM_PRV_LENGTH - 1);
+define symbol LOADER_STACK_ADDRESS = (BTCM_PRV_START + 0x2000);
+define symbol LOADER_STACK_END_ADDRESS = (BTCM_PRV_START + BTCM_PRV_LENGTH - 1);
+define symbol DATA_NONCACHE_OFFSET = 0x00048000;
+define symbol DATA_NONCACHE_END_OFFSET = 0x00044000;
+define symbol DMAC_LINK_MODE_OFFSET = 0x00044000;
+define symbol DMAC_LINK_MODE_END_OFFSET = 0x00040000;
+define symbol NONCACHE_BUFFER_OFFSET = 0x00020000;
+define symbol NONCACHE_BUFFER_END_OFFSET = 0;
+
+/*###ICF### Section handled by ICF editor, don't touch! ****/
+/*-Editor annotation file-*/
+/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\a_v1_0.xml" */
+/*-Specials-*/
+define symbol __ICFEDIT_intvec_start__ = INTVEC_ADDRESS;
+/*-Memory Regions-*/
+define symbol __ICFEDIT_region_ROM_start__ = FLASH_ADDRESS + 0x20100;
+define symbol __ICFEDIT_region_ROM_end__ = FLASH_ADDRESS + 0x6FFFF;
+define symbol __ICFEDIT_region_RAM_start__ = RAM_ADDRESS;
+define symbol __ICFEDIT_region_RAM_end__ = RAM_END_ADDRESS;
+/**** End of ICF editor section. ###ICF###*/
+
+/*-Sizes-*/
+define symbol __ICFEDIT_size_cstack__ = 0x200;
+/**** End of ICF editor section. ###ICF###*/
+
+define memory mem with size = 4G;
+define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
+define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
+
+define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
+
+define symbol __region_D_LOADER_STACK_start__ = LOADER_STACK_ADDRESS;
+define symbol __region_D_LOADER_STACK_end__ = LOADER_STACK_END_ADDRESS;
+
+define symbol __region_DATA_NONCACHE_start__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - DATA_NONCACHE_OFFSET;
+define symbol __region_DATA_NONCACHE_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - DATA_NONCACHE_END_OFFSET - 1;
+define symbol __region_DMAC_LINK_MODE_start__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - DMAC_LINK_MODE_OFFSET;
+define symbol __region_DMAC_LINK_MODE_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - DMAC_LINK_MODE_END_OFFSET - 1;
+define symbol __region_SHARED_NONCACHE_BUFFER_start__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - 0x00040000;
+define symbol __region_SHARED_NONCACHE_BUFFER_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - 0x00020000 - 1;
+define symbol __region_NONCACHE_BUFFER_start__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - NONCACHE_BUFFER_OFFSET;
+define symbol __region_NONCACHE_BUFFER_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - NONCACHE_BUFFER_END_OFFSET - 1;
+
+define symbol __region_ATCM_start__ = ATCM_PRV_START;
+define symbol __region_ATCM_end__ = ATCM_PRV_START + ATCM_PRV_LENGTH - 1;
+define symbol __region_BTCM_start__ = BTCM_PRV_START;
+define symbol __region_BTCM_end__ = BTCM_PRV_START + BTCM_PRV_LENGTH - 1;
+define symbol __region_SYSTEM_RAM_start__ = SYSTEM_RAM_PRV_START;
+define symbol __region_SYSTEM_RAM_end__ = SYSTEM_RAM_PRV_START + SYSTEM_RAM_PRV_LENGTH - SYSTEM_RAM_END_OFFSET - 1;
+define symbol __region_SYSTEM_RAM_MIRROR_start__ = SYSTEM_RAM_MIRROR_PRV_START;
+define symbol __region_SYSTEM_RAM_MIRROR_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - SYSTEM_RAM_END_OFFSET - 1;
+
+define symbol __region_XSPI0_CS0_MIRROR_start__ = xSPI0_CS0_SPACE_MIRROR_PRV_START;
+define symbol __region_XSPI0_CS0_MIRROR_end__ = xSPI0_CS0_SPACE_MIRROR_PRV_START + xSPI0_CS0_SPACE_MIRROR_PRV_LENGTH - 1;
+define symbol __region_XSPI0_CS1_MIRROR_start__ = xSPI0_CS1_SPACE_MIRROR_PRV_START;
+define symbol __region_XSPI0_CS1_MIRROR_end__ = xSPI0_CS1_SPACE_MIRROR_PRV_START + xSPI0_CS1_SPACE_MIRROR_PRV_LENGTH - 1;
+define symbol __region_XSPI1_CS0_MIRROR_start__ = xSPI1_CS0_SPACE_MIRROR_PRV_START;
+define symbol __region_XSPI1_CS0_MIRROR_end__ = xSPI1_CS0_SPACE_MIRROR_PRV_START + xSPI1_CS0_SPACE_MIRROR_PRV_LENGTH - 1;
+define symbol __region_XSPI1_CS1_MIRROR_start__ = xSPI1_CS1_SPACE_MIRROR_PRV_START;
+define symbol __region_XSPI1_CS1_MIRROR_end__ = xSPI1_CS1_SPACE_MIRROR_PRV_START + xSPI1_CS1_SPACE_MIRROR_PRV_LENGTH - 1;
+define symbol __region_CS0_MIRROR_start__ = CS0_SPACE_MIRROR_PRV_START;
+define symbol __region_CS0_MIRROR_end__ = CS0_SPACE_MIRROR_PRV_START + CS0_SPACE_MIRROR_PRV_LENGTH - 1;
+define symbol __region_CS2_MIRROR_start__ = CS2_SPACE_MIRROR_PRV_START;
+define symbol __region_CS2_MIRROR_end__ = CS2_SPACE_MIRROR_PRV_START + CS2_SPACE_MIRROR_PRV_LENGTH - 1;
+define symbol __region_CS3_MIRROR_start__ = CS3_SPACE_MIRROR_PRV_START;
+define symbol __region_CS3_MIRROR_end__ = CS3_SPACE_MIRROR_PRV_START + CS3_SPACE_MIRROR_PRV_LENGTH - 1;
+define symbol __region_CS5_MIRROR_start__ = CS5_SPACE_MIRROR_PRV_START;
+define symbol __region_CS5_MIRROR_end__ = CS5_SPACE_MIRROR_PRV_START + CS5_SPACE_MIRROR_PRV_LENGTH - 1;
+define symbol __region_XSPI0_CS0_start__ = xSPI0_CS0_SPACE_PRV_START;
+define symbol __region_XSPI0_CS0_end__ = xSPI0_CS0_SPACE_PRV_START + xSPI0_CS0_SPACE_PRV_LENGTH - 1;
+define symbol __region_XSPI0_CS1_start__ = xSPI0_CS1_SPACE_PRV_START;
+define symbol __region_XSPI0_CS1_end__ = xSPI0_CS1_SPACE_PRV_START + xSPI0_CS1_SPACE_PRV_LENGTH - 1;
+define symbol __region_XSPI1_CS0_start__ = xSPI1_CS0_SPACE_PRV_START;
+define symbol __region_XSPI1_CS0_end__ = xSPI1_CS0_SPACE_PRV_START + xSPI1_CS0_SPACE_PRV_LENGTH - 1;
+define symbol __region_XSPI1_CS1_start__ = xSPI1_CS1_SPACE_PRV_START;
+define symbol __region_XSPI1_CS1_end__ = xSPI1_CS1_SPACE_PRV_START + xSPI1_CS1_SPACE_PRV_LENGTH - 1;
+define symbol __region_CS0_start__ = CS0_SPACE_PRV_START;
+define symbol __region_CS0_end__ = CS0_SPACE_PRV_START + CS0_SPACE_PRV_LENGTH - 1;
+define symbol __region_CS2_start__ = CS2_SPACE_PRV_START;
+define symbol __region_CS2_end__ = CS2_SPACE_PRV_START + CS2_SPACE_PRV_LENGTH - 1;
+define symbol __region_CS3_start__ = CS3_SPACE_PRV_START;
+define symbol __region_CS3_end__ = CS3_SPACE_PRV_START + CS3_SPACE_PRV_LENGTH - 1;
+define symbol __region_CS5_start__ = CS5_SPACE_PRV_START;
+define symbol __region_CS5_end__ = CS5_SPACE_PRV_START + CS5_SPACE_PRV_LENGTH - 1;
+
+/************** SPI boot mode setting **************/
+define symbol __region_LDR_PARAM_start__ = FLASH_ADDRESS;
+define symbol __region_LDR_PARAM_end__ = FLASH_ADDRESS + 0x0000004B;
+define symbol __region_S_LOADER_STACK_start__ = FLASH_ADDRESS + 0x0000004C;
+define symbol __region_S_LOADER_STACK_end__ = FLASH_ADDRESS + 0x0000804B;
+
+define symbol __region_S_intvec_start__ = FLASH_ADDRESS + 0x20000;
+define symbol __region_S_intvec_end__ = FLASH_ADDRESS + 0x200FF;
+define symbol __region_S_RAM_start__ = FLASH_ADDRESS + 0x70000;
+define symbol __region_S_RAM_end__ = FLASH_ADDRESS + 0x7FFFF;
+/****************************************************/
+
+define region D_LOADER_STACK_region = mem:[from __region_D_LOADER_STACK_start__ to __region_D_LOADER_STACK_end__];
+
+define region LDR_PARAM_region = mem:[from __region_LDR_PARAM_start__ to __region_LDR_PARAM_end__];
+define region S_LOADER_STACK_region = mem:[from __region_S_LOADER_STACK_start__ to __region_S_LOADER_STACK_end__];
+
+define region S_intvec_region = mem:[from __region_S_intvec_start__ to __region_S_intvec_end__];
+define region S_RAM_region = mem:[from __region_S_RAM_start__ to __region_S_RAM_end__];
+
+define region DATA_NONCACHE_region = mem:[from __region_DATA_NONCACHE_start__ to __region_DATA_NONCACHE_end__];
+define region DMAC_LINK_MODE_region = mem:[from __region_DMAC_LINK_MODE_start__ to __region_DMAC_LINK_MODE_end__];
+define region SHARED_NONCACHE_BUFFER_region = mem:[from __region_SHARED_NONCACHE_BUFFER_start__ to __region_SHARED_NONCACHE_BUFFER_end__];
+define region NONCACHE_BUFFER_region = mem:[from __region_NONCACHE_BUFFER_start__ to __region_NONCACHE_BUFFER_end__];
+
+define region ATCM_region = mem:[from __region_ATCM_start__ to __region_ATCM_end__ ];
+define region BTCM_region = mem:[from __region_BTCM_start__ to __region_BTCM_end__ ];
+define region SYSTEM_RAM_region = mem:[from __region_SYSTEM_RAM_start__ to __region_SYSTEM_RAM_end__ ];
+define region SYSTEM_RAM_MIRROR_region = mem:[from __region_SYSTEM_RAM_MIRROR_start__ to __region_SYSTEM_RAM_MIRROR_end__ ];
+define region XSPI0_CS0_MIRROR_region = mem:[from __region_XSPI0_CS0_MIRROR_start__ to __region_XSPI0_CS0_MIRROR_end__ ];
+define region XSPI0_CS1_MIRROR_region = mem:[from __region_XSPI0_CS1_MIRROR_start__ to __region_XSPI0_CS1_MIRROR_end__ ];
+define region XSPI1_CS0_MIRROR_region = mem:[from __region_XSPI1_CS0_MIRROR_start__ to __region_XSPI1_CS0_MIRROR_end__ ];
+define region XSPI1_CS1_MIRROR_region = mem:[from __region_XSPI1_CS1_MIRROR_start__ to __region_XSPI1_CS1_MIRROR_end__ ];
+define region CS0_MIRROR_region = mem:[from __region_CS0_MIRROR_start__ to __region_CS0_MIRROR_end__ ];
+define region CS2_MIRROR_region = mem:[from __region_CS2_MIRROR_start__ to __region_CS2_MIRROR_end__ ];
+define region CS3_MIRROR_region = mem:[from __region_CS3_MIRROR_start__ to __region_CS3_MIRROR_end__ ];
+define region CS5_MIRROR_region = mem:[from __region_CS5_MIRROR_start__ to __region_CS5_MIRROR_end__ ];
+define region XSPI0_CS0_region = mem:[from __region_XSPI0_CS0_start__ to __region_XSPI0_CS0_end__ ];
+define region XSPI0_CS1_region = mem:[from __region_XSPI0_CS1_start__ to __region_XSPI0_CS1_end__ ];
+define region XSPI1_CS0_region = mem:[from __region_XSPI1_CS0_start__ to __region_XSPI1_CS0_end__ ];
+define region XSPI1_CS1_region = mem:[from __region_XSPI1_CS1_start__ to __region_XSPI1_CS1_end__ ];
+define region CS0_region = mem:[from __region_CS0_start__ to __region_CS0_end__ ];
+define region CS2_region = mem:[from __region_CS2_start__ to __region_CS2_end__ ];
+define region CS3_region = mem:[from __region_CS3_start__ to __region_CS3_end__ ];
+define region CS5_region = mem:[from __region_CS5_start__ to __region_CS5_end__ ];
+
+define block LDR_PRG_RBLOCK with fixed order
+ { ro code section .loader_text_init object startup_core.o,
+ ro code object startup_core.o,
+ ro code object system_core.o,
+ ro code object startup.o,
+ ro code object system.o,
+ ro code object bsp_clocks.o,
+ ro code object bsp_irq_core.o,
+ ro code object bsp_irq.o,
+ ro code object bsp_register_protection.o,
+ ro code object r_ioport.o,
+ ro code object bsp_cache.o,
+ ro code section .warm_start_init }
+ except { ro code section .intvec_init,
+ ro code section .reset_handler_init };
+define block LDR_PRG_WBLOCK with fixed order
+ { rw code section .loader_text object startup_core.o,
+ rw code object startup_core.o,
+ rw code object system_core.o,
+ rw code object startup.o,
+ rw code object system.o,
+ rw code object bsp_clocks.o,
+ rw code object bsp_irq_core.o,
+ rw code object bsp_irq.o,
+ rw code object bsp_register_protection.o,
+ rw code object r_ioport.o,
+ rw code object bsp_cache.o,
+ rw code section .warm_start }
+ except { rw code section .intvec,
+ rw code section .reset_handler };
+define block LDR_DATA_ZBLOCK with alignment = 4
+ { section .bss object startup_core.o,
+ section .bss object system_core.o,
+ section .bss object startup.o,
+ section .bss object system.o,
+ section .bss object bsp_clocks.o,
+ section .bss object bsp_irq_core.o,
+ section .bss object bsp_irq.o,
+ section .bss object bsp_register_protection.o,
+ section .bss object r_ioport.o,
+ section .bss object bsp_cache.o,
+ section .bss object bsp_io.o };
+define block LDR_DATA_RBLOCK with fixed order, alignment = 4
+ { section .data_init object startup_core.o,
+ section .data_init object system_core.o,
+ section .data_init object startup.o,
+ section .data_init object system.o,
+ section .data_init object bsp_clocks.o,
+ section .data_init object bsp_irq_core.o,
+ section .data_init object bsp_irq.o,
+ section .data_init object bsp_register_protection.o,
+ section .data_init object r_ioport.o,
+ section .data_init object bsp_cache.o,
+ section .rodata_init object system_core.o };
+define block LDR_DATA_WBLOCK with fixed order, alignment = 4
+ { section .data object startup_core.o,
+ section .data object system_core.o,
+ section .data object startup.o,
+ section .data object system.o,
+ section .data object bsp_clocks.o,
+ section .data object bsp_irq_core.o,
+ section .data object bsp_irq.o,
+ section .data object bsp_register_protection.o,
+ section .data object r_ioport.o,
+ section .data object bsp_cache.o,
+ section .rodata object system_core.o };
+
+define block HEAP_BLOCK with alignment = 8 { rw section HEAP };
+define block THREAD_STACK with alignment = 8 { rw section .stack* };
+define block SYS_STACK with alignment = 8 { rw section .sys_stack };
+define block SVC_STACK with alignment = 8 { rw section .svc_stack };
+define block IRQ_STACK with alignment = 8 { rw section .irq_stack };
+define block FIQ_STACK with alignment = 8 { rw section .fiq_stack };
+define block UND_STACK with alignment = 8 { rw section .und_stack };
+define block ABT_STACK with alignment = 8 { rw section .abt_stack };
+
+define block VECTOR_RBLOCK with alignment = 32 { ro code section .intvec_init};
+define block VECTOR_WBLOCK with alignment = 32 { rw code section .intvec};
+define block USER_PRG_RBLOCK with alignment = 4 { ro code };
+define block USER_PRG_WBLOCK with alignment = 4 { rw code };
+define block USER_DATA_ZBLOCK with alignment = 4 { section .bss };
+define block USER_DATA_RBLOCK with fixed order, alignment = 4
+ { section .data_init,
+ section __DLIB_PERTHREAD_init,
+ section .rodata_init,
+ section .version_init };
+define block USER_DATA_WBLOCK with fixed order, alignment = 4
+ { section .data,
+ section __DLIB_PERTHREAD,
+ section .rodata,
+ section .version };
+define block USER_DATA_NONCACHE_RBLOCK with alignment = 4 { section .data_noncache_init };
+define block USER_DATA_NONCACHE_WBLOCK with alignment = 4 { section .data_noncache };
+define block DMAC_LINK_MODE_ZBLOCK with alignment = 4 { section .dmac_link_mode* };
+define block SHARED_NONCACHE_BUFFER_ZBLOCK with alignment = 32 { section .shared_noncache_buffer* };
+define block NONCACHE_BUFFER_ZBLOCK with alignment = 32 { section .noncache_buffer* };
+
+initialize manually { ro code object startup_core.o,
+ ro code object system_core.o,
+ ro code object startup.o,
+ ro code object system.o,
+ ro code object bsp_clocks.o,
+ ro code object bsp_irq_core.o,
+ ro code object bsp_irq.o,
+ ro code object bsp_register_protection.o,
+ ro code object r_ioport.o,
+ ro code object bsp_cache.o,
+ ro code section .intvec,
+ ro code section .reset_handler,
+ ro code section .warm_start,
+ ro code,
+ section .data,
+ section __DLIB_PERTHREAD,
+ section .rodata,
+ section .version,
+ section .data_noncache };
+
+do not initialize { section .noinit,
+ section .bss,
+ section .dmac_link_mode*,
+ section .shared_noncache_buffer*,
+ section .noncache_buffer*,
+ rw section HEAP,
+ rw section .stack*,
+ rw section .sys_stack,
+ rw section .svc_stack,
+ rw section .irq_stack,
+ rw section .fiq_stack,
+ rw section .und_stack,
+ rw section .abt_stack };
+
+place at address mem: __ICFEDIT_intvec_start__ { block VECTOR_WBLOCK };
+
+place in LDR_PARAM_region { readonly section .loader_param };
+place at start of S_LOADER_STACK_region { block LDR_PRG_RBLOCK };
+place in S_LOADER_STACK_region { section LDR_DATA_RBLOCK, block LDR_DATA_RBLOCK };
+place in S_intvec_region { block VECTOR_RBLOCK };
+place in ROM_region { block USER_PRG_RBLOCK, readonly };
+place in S_RAM_region { block USER_DATA_RBLOCK, block USER_DATA_NONCACHE_RBLOCK };
+
+place at start of D_LOADER_STACK_region { block LDR_PRG_WBLOCK };
+place in D_LOADER_STACK_region { section LDR_DATA_WBLOCK, block LDR_DATA_WBLOCK,
+ section LDR_DATA_ZBLOCK, block LDR_DATA_ZBLOCK };
+place in D_LOADER_STACK_region { section SYS_STACK, block SYS_STACK,
+ section SVC_STACK, block SVC_STACK,
+ section IRQ_STACK, block IRQ_STACK,
+ section FIQ_STACK, block FIQ_STACK,
+ section UND_STACK, block UND_STACK,
+ section ABT_STACK, block ABT_STACK };
+place in RAM_region { block USER_PRG_WBLOCK };
+place in RAM_region { readwrite, last block CSTACK };
+place in RAM_region { block USER_DATA_WBLOCK,
+ block USER_DATA_ZBLOCK };
+place in RAM_region { section HEAP_BLOCK, block HEAP_BLOCK,
+ section THREAD_STACK, block THREAD_STACK };
+
+place in DATA_NONCACHE_region { block USER_DATA_NONCACHE_WBLOCK };
+place in DMAC_LINK_MODE_region { block DMAC_LINK_MODE_ZBLOCK };
+place in SHARED_NONCACHE_BUFFER_region { block SHARED_NONCACHE_BUFFER_ZBLOCK };
+place in NONCACHE_BUFFER_region { block NONCACHE_BUFFER_ZBLOCK };
+place in ATCM_region { };
+place in BTCM_region { };
+place in SYSTEM_RAM_region { };
+place in SYSTEM_RAM_MIRROR_region { };
+place in XSPI0_CS0_MIRROR_region { };
+place in XSPI0_CS1_MIRROR_region { };
+place in XSPI1_CS0_MIRROR_region { };
+place in XSPI1_CS1_MIRROR_region { };
+place in CS0_MIRROR_region { };
+place in CS2_MIRROR_region { };
+place in CS3_MIRROR_region { };
+place in CS5_MIRROR_region { };
+place in XSPI0_CS0_region { };
+place in XSPI0_CS1_region { };
+place in XSPI1_CS0_region { };
+place in XSPI1_CS1_region { };
+place in CS0_region { };
+place in CS2_region { };
+place in CS3_region { };
+place in CS5_region { };
diff --git a/bsp/renesas/rzn2l_rsk/script/fsp_xspi0_boot.ld b/bsp/renesas/rzn2l_rsk/script/fsp_xspi0_boot.ld
index d0ee38a6586..ef2a35fc4c4 100644
--- a/bsp/renesas/rzn2l_rsk/script/fsp_xspi0_boot.ld
+++ b/bsp/renesas/rzn2l_rsk/script/fsp_xspi0_boot.ld
@@ -1,12 +1,47 @@
/*
Linker File for Renesas RZ/N2L FSP
*/
-
-INCLUDE memory_regions.ld
-
/* The memory information for each device is done in memory regions file.
* The starting address and length of memory not defined in memory regions file are defined as 0. */
+/* generated memory regions file - do not edit */
+ATCM_START = 0x00000000;
+ATCM_LENGTH = 0x20000;
+BTCM_START = 0x00100000;
+BTCM_LENGTH = 0x20000;
+SYSTEM_RAM_START = 0x10000000;
+SYSTEM_RAM_LENGTH = 0x180000;
+SYSTEM_RAM_MIRROR_START = 0x30000000;
+SYSTEM_RAM_MIRROR_LENGTH = 0x180000;
+xSPI0_CS0_SPACE_MIRROR_START = 0x40000000;
+xSPI0_CS0_SPACE_MIRROR_LENGTH = 0x4000000;
+xSPI0_CS1_SPACE_MIRROR_START = 0x44000000;
+xSPI0_CS1_SPACE_MIRROR_LENGTH = 0x4000000;
+xSPI1_CS0_SPACE_MIRROR_START = 0x48000000;
+xSPI1_CS0_SPACE_MIRROR_LENGTH = 0x4000000;
+CS0_SPACE_MIRROR_START = 0x50000000;
+CS0_SPACE_MIRROR_LENGTH = 0x4000000;
+CS2_SPACE_MIRROR_START = 0x54000000;
+CS2_SPACE_MIRROR_LENGTH = 0x4000000;
+CS3_SPACE_MIRROR_START = 0x58000000;
+CS3_SPACE_MIRROR_LENGTH = 0x4000000;
+CS5_SPACE_MIRROR_START = 0x5C000000;
+CS5_SPACE_MIRROR_LENGTH = 0x4000000;
+xSPI0_CS0_SPACE_START = 0x60000000;
+xSPI0_CS0_SPACE_LENGTH = 0x4000000;
+xSPI0_CS1_SPACE_START = 0x64000000;
+xSPI0_CS1_SPACE_LENGTH = 0x4000000;
+xSPI1_CS0_SPACE_START = 0x68000000;
+xSPI1_CS0_SPACE_LENGTH = 0x4000000;
+CS0_SPACE_START = 0x70000000;
+CS0_SPACE_LENGTH = 0x4000000;
+CS2_SPACE_START = 0x74000000;
+CS2_SPACE_LENGTH = 0x4000000;
+CS3_SPACE_START = 0x78000000;
+CS3_SPACE_LENGTH = 0x4000000;
+CS5_SPACE_START = 0x7C000000;
+CS5_SPACE_LENGTH = 0x4000000;
+
ATCM_PRV_START = DEFINED(ATCM_START) ? ATCM_START : 0;
ATCM_PRV_LENGTH = DEFINED(ATCM_LENGTH) ? ATCM_LENGTH : 0;
BTCM_PRV_START = DEFINED(BTCM_START) ? BTCM_START : 0;
@@ -51,13 +86,13 @@ CS5_SPACE_PRV_LENGTH = DEFINED(CS5_SPACE_LENGTH) ? CS5_SPACE_LENGTH : 0;
LOADER_PARAM_ADDRESS = xSPI0_CS0_SPACE_PRV_START;
FLASH_CONTENTS_ADDRESS = LOADER_PARAM_ADDRESS + 0x0000004C;
LOADER_TEXT_ADDRESS = 0x00102000;
-INTVEC_ADDRESS = 0x00000000;
-TEXT_ADDRESS = 0x00000100;
+INTVEC_ADDRESS = 0x10000000;
+TEXT_ADDRESS = 0x10020000;
NONCACHE_BUFFER_OFFSET = 0x00020000;
DMAC_LINK_MODE_OFFSET = 0x00044000;
DATA_NONCACHE_OFFSET = 0x00048000;
-RAM_START = ATCM_PRV_START;
-RAM_LENGTH = ATCM_PRV_LENGTH;
+RAM_START = SYSTEM_RAM_PRV_START;
+RAM_LENGTH = SYSTEM_RAM_PRV_LENGTH;
LOADER_START = BTCM_PRV_START;
LOADER_LENGTH = BTCM_PRV_LENGTH;
@@ -205,22 +240,37 @@ SECTIONS
*(.dtors)
_dtor_end = .;
+ /* section information for utest */
+ . = ALIGN(4);
+ __rt_utest_tc_tab_start = .;
+ KEEP(*(UtestTcTab))
+ __rt_utest_tc_tab_end = .;
- /* section information for finsh shell */
- . = ALIGN(4);
- __fsymtab_start = .;
- KEEP(*(FSymTab))
- __fsymtab_end = .;
-
- . = ALIGN(4);
- __vsymtab_start = .;
- KEEP(*(VSymTab))
- __vsymtab_end = .;
-
-
-
- . = ALIGN(4);
- KEEP(*(FalPartTable))
+ /* section information for finsh shell */
+ . = ALIGN(4);
+ __fsymtab_start = .;
+ KEEP(*(FSymTab))
+ __fsymtab_end = .;
+
+ . = ALIGN(4);
+ __vsymtab_start = .;
+ KEEP(*(VSymTab))
+ __vsymtab_end = .;
+
+ /* section information for initial. */
+ . = ALIGN(4);
+ __rt_init_start = .;
+ KEEP(*(SORT(.rti_fn*)))
+ __rt_init_end = .;
+
+ /* new GCC version uses .init_array */
+ PROVIDE(__ctors_start__ = .);
+ KEEP (*(SORT(.init_array.*)))
+ KEEP (*(.init_array))
+ PROVIDE(__ctors_end__ = .);
+
+ . = ALIGN(4);
+ KEEP(*(FalPartTable))
KEEP(*(.eh_frame*))
} > RAM
@@ -310,7 +360,7 @@ SECTIONS
/* Place the STD heap here. */
KEEP(*(.heap))
__HeapLimit = .;
- } > ATCM
+ } > RAM
.thread_stack (NOLOAD):
{
. = ALIGN(8);
diff --git a/bsp/renesas/rzn2l_rsk/script/fsp_xspi0_boot_systemRAM.icf b/bsp/renesas/rzn2l_rsk/script/fsp_xspi0_boot_systemRAM.icf
deleted file mode 100644
index 0e3f984c5f9..00000000000
--- a/bsp/renesas/rzn2l_rsk/script/fsp_xspi0_boot_systemRAM.icf
+++ /dev/null
@@ -1,699 +0,0 @@
-include "memory_regions.icf";
-
-/* The memory information for each device is done in memory regions file.
- * The starting address and length of memory not defined in memory regions file are defined as 0. */
-
-if (isdefinedsymbol(ATCM_START))
-{
- define symbol ATCM_PRV_START = ATCM_START;
-}
-else
-{
- define symbol ATCM_PRV_START = 0;
-}
-
-if (isdefinedsymbol(ATCM_LENGTH))
-{
- define symbol ATCM_PRV_LENGTH = ATCM_LENGTH;
-}
-else
-{
- define symbol ATCM_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(BTCM_START))
-{
- define symbol BTCM_PRV_START = BTCM_START;
-}
-else
-{
- define symbol BTCM_PRV_START = 0;
-}
-
-if (isdefinedsymbol(BTCM_LENGTH))
-{
- define symbol BTCM_PRV_LENGTH = BTCM_LENGTH;
-}
-else
-{
- define symbol BTCM_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(SYSTEM_RAM_START))
-{
- define symbol SYSTEM_RAM_PRV_START = SYSTEM_RAM_START;
-}
-else
-{
- define symbol SYSTEM_RAM_PRV_START = 0;
-}
-
-if (isdefinedsymbol(SYSTEM_RAM_LENGTH))
-{
- define symbol SYSTEM_RAM_PRV_LENGTH = SYSTEM_RAM_LENGTH;
-}
-else
-{
- define symbol SYSTEM_RAM_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(SYSTEM_RAM_MIRROR_START))
-{
- define symbol SYSTEM_RAM_MIRROR_PRV_START = SYSTEM_RAM_MIRROR_START;
-}
-else
-{
- define symbol SYSTEM_RAM_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(SYSTEM_RAM_MIRROR_LENGTH))
-{
- define symbol SYSTEM_RAM_MIRROR_PRV_LENGTH = SYSTEM_RAM_MIRROR_LENGTH;
-}
-else
-{
- define symbol SYSTEM_RAM_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS0_SPACE_MIRROR_START))
-{
- define symbol xSPI0_CS0_SPACE_MIRROR_PRV_START = xSPI0_CS0_SPACE_MIRROR_START;
-}
-else
-{
- define symbol xSPI0_CS0_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS0_SPACE_MIRROR_LENGTH))
-{
- define symbol xSPI0_CS0_SPACE_MIRROR_PRV_LENGTH = xSPI0_CS0_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol xSPI0_CS0_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS1_SPACE_MIRROR_START))
-{
- define symbol xSPI0_CS1_SPACE_MIRROR_PRV_START = xSPI0_CS1_SPACE_MIRROR_START;
-}
-else
-{
- define symbol xSPI0_CS1_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS1_SPACE_MIRROR_LENGTH))
-{
- define symbol xSPI0_CS1_SPACE_MIRROR_PRV_LENGTH = xSPI0_CS1_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol xSPI0_CS1_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS0_SPACE_MIRROR_START))
-{
- define symbol xSPI1_CS0_SPACE_MIRROR_PRV_START = xSPI1_CS0_SPACE_MIRROR_START;
-}
-else
-{
- define symbol xSPI1_CS0_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS0_SPACE_MIRROR_LENGTH))
-{
- define symbol xSPI1_CS0_SPACE_MIRROR_PRV_LENGTH = xSPI1_CS0_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol xSPI1_CS0_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS1_SPACE_MIRROR_START))
-{
- define symbol xSPI1_CS1_SPACE_MIRROR_PRV_START = xSPI1_CS1_SPACE_MIRROR_START;
-}
-else
-{
- define symbol xSPI1_CS1_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS1_SPACE_MIRROR_LENGTH))
-{
- define symbol xSPI1_CS1_SPACE_MIRROR_PRV_LENGTH = xSPI1_CS1_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol xSPI1_CS1_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS0_SPACE_MIRROR_START))
-{
- define symbol CS0_SPACE_MIRROR_PRV_START = CS0_SPACE_MIRROR_START;
-}
-else
-{
- define symbol CS0_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS0_SPACE_MIRROR_LENGTH))
-{
- define symbol CS0_SPACE_MIRROR_PRV_LENGTH = CS0_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol CS0_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS2_SPACE_MIRROR_START))
-{
- define symbol CS2_SPACE_MIRROR_PRV_START = CS2_SPACE_MIRROR_START;
-}
-else
-{
- define symbol CS2_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS2_SPACE_MIRROR_LENGTH))
-{
- define symbol CS2_SPACE_MIRROR_PRV_LENGTH = CS2_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol CS2_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-
-if (isdefinedsymbol(CS3_SPACE_MIRROR_START))
-{
- define symbol CS3_SPACE_MIRROR_PRV_START = CS3_SPACE_MIRROR_START;
-}
-else
-{
- define symbol CS3_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS3_SPACE_MIRROR_LENGTH))
-{
- define symbol CS3_SPACE_MIRROR_PRV_LENGTH = CS3_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol CS3_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS5_SPACE_MIRROR_START))
-{
- define symbol CS5_SPACE_MIRROR_PRV_START = CS5_SPACE_MIRROR_START;
-}
-else
-{
- define symbol CS5_SPACE_MIRROR_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS5_SPACE_MIRROR_LENGTH))
-{
- define symbol CS5_SPACE_MIRROR_PRV_LENGTH = CS5_SPACE_MIRROR_LENGTH;
-}
-else
-{
- define symbol CS5_SPACE_MIRROR_PRV_LENGTH = 0;
-}
-
-
-if (isdefinedsymbol(xSPI0_CS0_SPACE_START))
-{
- define symbol xSPI0_CS0_SPACE_PRV_START = xSPI0_CS0_SPACE_START;
-}
-else
-{
- define symbol xSPI0_CS0_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS0_SPACE_LENGTH))
-{
- define symbol xSPI0_CS0_SPACE_PRV_LENGTH = xSPI0_CS0_SPACE_LENGTH;
-}
-else
-{
- define symbol xSPI0_CS0_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS1_SPACE_START))
-{
- define symbol xSPI0_CS1_SPACE_PRV_START = xSPI0_CS1_SPACE_START;
-}
-else
-{
- define symbol xSPI0_CS1_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI0_CS1_SPACE_LENGTH))
-{
- define symbol xSPI0_CS1_SPACE_PRV_LENGTH = xSPI0_CS1_SPACE_LENGTH;
-}
-else
-{
- define symbol xSPI0_CS1_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS0_SPACE_START))
-{
- define symbol xSPI1_CS0_SPACE_PRV_START = xSPI1_CS0_SPACE_START;
-}
-else
-{
- define symbol xSPI1_CS0_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS0_SPACE_LENGTH))
-{
- define symbol xSPI1_CS0_SPACE_PRV_LENGTH = xSPI1_CS0_SPACE_LENGTH;
-}
-else
-{
- define symbol xSPI1_CS0_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS1_SPACE_START))
-{
- define symbol xSPI1_CS1_SPACE_PRV_START = xSPI1_CS1_SPACE_START;
-}
-else
-{
- define symbol xSPI1_CS1_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(xSPI1_CS1_SPACE_LENGTH))
-{
- define symbol xSPI1_CS1_SPACE_PRV_LENGTH = xSPI1_CS1_SPACE_LENGTH;
-}
-else
-{
- define symbol xSPI1_CS1_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS0_SPACE_START))
-{
- define symbol CS0_SPACE_PRV_START = CS0_SPACE_START;
-}
-else
-{
- define symbol CS0_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS0_SPACE_LENGTH))
-{
- define symbol CS0_SPACE_PRV_LENGTH = CS0_SPACE_LENGTH;
-}
-else
-{
- define symbol CS0_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS2_SPACE_START))
-{
- define symbol CS2_SPACE_PRV_START = CS2_SPACE_START;
-}
-else
-{
- define symbol CS2_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS2_SPACE_LENGTH))
-{
- define symbol CS2_SPACE_PRV_LENGTH = CS2_SPACE_LENGTH;
-}
-else
-{
- define symbol CS2_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS3_SPACE_START))
-{
- define symbol CS3_SPACE_PRV_START = CS3_SPACE_START;
-}
-else
-{
- define symbol CS3_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS3_SPACE_LENGTH))
-{
- define symbol CS3_SPACE_PRV_LENGTH = CS3_SPACE_LENGTH;
-}
-else
-{
- define symbol CS3_SPACE_PRV_LENGTH = 0;
-}
-
-if (isdefinedsymbol(CS5_SPACE_START))
-{
- define symbol CS5_SPACE_PRV_START = CS5_SPACE_START;
-}
-else
-{
- define symbol CS5_SPACE_PRV_START = 0;
-}
-
-if (isdefinedsymbol(CS5_SPACE_LENGTH))
-{
- define symbol CS5_SPACE_PRV_LENGTH = CS5_SPACE_LENGTH;
-}
-else
-{
- define symbol CS5_SPACE_PRV_LENGTH = 0;
-}
-
-define symbol SYSTEM_RAM_END_OFFSET = 0x00048000;
-define symbol FLASH_ADDRESS = xSPI0_CS0_SPACE_PRV_START;
-
-/*
-define symbol INTVEC_ADDRESS = ATCM_PRV_START;
-define symbol RAM_ADDRESS = (ATCM_PRV_START + 0x100);
-define symbol RAM_END_ADDRESS = (ATCM_PRV_START + ATCM_PRV_LENGTH - 1);
-define symbol LOADER_STACK_ADDRESS = (BTCM_PRV_START + 0x2000);
-define symbol LOADER_STACK_END_ADDRESS = (BTCM_PRV_START + BTCM_PRV_LENGTH - 1);
-define symbol DATA_NONCACHE_OFFSET = 0x00048000;
-define symbol DATA_NONCACHE_END_OFFSET = 0x00044000;
-define symbol DMAC_LINK_MODE_OFFSET = 0x00044000;
-define symbol DMAC_LINK_MODE_END_OFFSET = 0x00040000;
-define symbol NONCACHE_BUFFER_OFFSET = 0x00020000;
-define symbol NONCACHE_BUFFER_END_OFFSET = 0;
-*/
-/************* Override define symbol to place EtherCAT protocol into SystemRAM ************/
-define symbol INTVEC_ADDRESS = SYSTEM_RAM_PRV_START;
-define symbol RAM_ADDRESS = (SYSTEM_RAM_PRV_START + 0x100);
-define symbol RAM_END_ADDRESS = (SYSTEM_RAM_PRV_START + SYSTEM_RAM_PRV_LENGTH - 1);
-define symbol LOADER_STACK_ADDRESS = (BTCM_PRV_START + 0x2000);
-define symbol LOADER_STACK_END_ADDRESS = (BTCM_PRV_START + BTCM_PRV_LENGTH - 1);
-define symbol DATA_NONCACHE_OFFSET = 0x00048000;
-define symbol DATA_NONCACHE_END_OFFSET = 0x00044000;
-define symbol DMAC_LINK_MODE_OFFSET = 0x00044000;
-define symbol DMAC_LINK_MODE_END_OFFSET = 0x00040000;
-define symbol NONCACHE_BUFFER_OFFSET = 0x00020000;
-define symbol NONCACHE_BUFFER_END_OFFSET = 0;
-/*********************************************************************************************/
-
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\a_v1_0.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = INTVEC_ADDRESS;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_ROM_start__ = FLASH_ADDRESS + 0x20100;
-define symbol __ICFEDIT_region_ROM_end__ = FLASH_ADDRESS + 0x6FFFF;
-define symbol __ICFEDIT_region_RAM_start__ = RAM_ADDRESS;
-define symbol __ICFEDIT_region_RAM_end__ = RAM_END_ADDRESS;
-/**** End of ICF editor section. ###ICF###*/
-
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 0x200;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
-define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
-
-define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
-
-define symbol __region_D_LOADER_STACK_start__ = LOADER_STACK_ADDRESS;
-define symbol __region_D_LOADER_STACK_end__ = LOADER_STACK_END_ADDRESS;
-
-define symbol __region_DATA_NONCACHE_start__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - DATA_NONCACHE_OFFSET;
-define symbol __region_DATA_NONCACHE_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - DATA_NONCACHE_END_OFFSET - 1;
-define symbol __region_DMAC_LINK_MODE_start__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - DMAC_LINK_MODE_OFFSET;
-define symbol __region_DMAC_LINK_MODE_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - DMAC_LINK_MODE_END_OFFSET - 1;
-define symbol __region_SHARED_NONCACHE_BUFFER_start__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - 0x00040000;
-define symbol __region_SHARED_NONCACHE_BUFFER_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - 0x00020000 - 1;
-define symbol __region_NONCACHE_BUFFER_start__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - NONCACHE_BUFFER_OFFSET;
-define symbol __region_NONCACHE_BUFFER_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - NONCACHE_BUFFER_END_OFFSET - 1;
-
-define symbol __region_ATCM_start__ = ATCM_PRV_START;
-define symbol __region_ATCM_end__ = ATCM_PRV_START + ATCM_PRV_LENGTH - 1;
-define symbol __region_BTCM_start__ = BTCM_PRV_START;
-define symbol __region_BTCM_end__ = BTCM_PRV_START + BTCM_PRV_LENGTH - 1;
-define symbol __region_SYSTEM_RAM_start__ = SYSTEM_RAM_PRV_START;
-define symbol __region_SYSTEM_RAM_end__ = SYSTEM_RAM_PRV_START + SYSTEM_RAM_PRV_LENGTH - SYSTEM_RAM_END_OFFSET - 1;
-define symbol __region_SYSTEM_RAM_MIRROR_start__ = SYSTEM_RAM_MIRROR_PRV_START;
-define symbol __region_SYSTEM_RAM_MIRROR_end__ = SYSTEM_RAM_MIRROR_PRV_START + SYSTEM_RAM_MIRROR_PRV_LENGTH - SYSTEM_RAM_END_OFFSET - 1;
-
-define symbol __region_XSPI0_CS0_MIRROR_start__ = xSPI0_CS0_SPACE_MIRROR_PRV_START;
-define symbol __region_XSPI0_CS0_MIRROR_end__ = xSPI0_CS0_SPACE_MIRROR_PRV_START + xSPI0_CS0_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_XSPI0_CS1_MIRROR_start__ = xSPI0_CS1_SPACE_MIRROR_PRV_START;
-define symbol __region_XSPI0_CS1_MIRROR_end__ = xSPI0_CS1_SPACE_MIRROR_PRV_START + xSPI0_CS1_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_XSPI1_CS0_MIRROR_start__ = xSPI1_CS0_SPACE_MIRROR_PRV_START;
-define symbol __region_XSPI1_CS0_MIRROR_end__ = xSPI1_CS0_SPACE_MIRROR_PRV_START + xSPI1_CS0_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_XSPI1_CS1_MIRROR_start__ = xSPI1_CS1_SPACE_MIRROR_PRV_START;
-define symbol __region_XSPI1_CS1_MIRROR_end__ = xSPI1_CS1_SPACE_MIRROR_PRV_START + xSPI1_CS1_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_CS0_MIRROR_start__ = CS0_SPACE_MIRROR_PRV_START;
-define symbol __region_CS0_MIRROR_end__ = CS0_SPACE_MIRROR_PRV_START + CS0_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_CS2_MIRROR_start__ = CS2_SPACE_MIRROR_PRV_START;
-define symbol __region_CS2_MIRROR_end__ = CS2_SPACE_MIRROR_PRV_START + CS2_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_CS3_MIRROR_start__ = CS3_SPACE_MIRROR_PRV_START;
-define symbol __region_CS3_MIRROR_end__ = CS3_SPACE_MIRROR_PRV_START + CS3_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_CS5_MIRROR_start__ = CS5_SPACE_MIRROR_PRV_START;
-define symbol __region_CS5_MIRROR_end__ = CS5_SPACE_MIRROR_PRV_START + CS5_SPACE_MIRROR_PRV_LENGTH - 1;
-define symbol __region_XSPI0_CS0_start__ = xSPI0_CS0_SPACE_PRV_START;
-define symbol __region_XSPI0_CS0_end__ = xSPI0_CS0_SPACE_PRV_START + xSPI0_CS0_SPACE_PRV_LENGTH - 1;
-define symbol __region_XSPI0_CS1_start__ = xSPI0_CS1_SPACE_PRV_START;
-define symbol __region_XSPI0_CS1_end__ = xSPI0_CS1_SPACE_PRV_START + xSPI0_CS1_SPACE_PRV_LENGTH - 1;
-define symbol __region_XSPI1_CS0_start__ = xSPI1_CS0_SPACE_PRV_START;
-define symbol __region_XSPI1_CS0_end__ = xSPI1_CS0_SPACE_PRV_START + xSPI1_CS0_SPACE_PRV_LENGTH - 1;
-define symbol __region_XSPI1_CS1_start__ = xSPI1_CS1_SPACE_PRV_START;
-define symbol __region_XSPI1_CS1_end__ = xSPI1_CS1_SPACE_PRV_START + xSPI1_CS1_SPACE_PRV_LENGTH - 1;
-define symbol __region_CS0_start__ = CS0_SPACE_PRV_START;
-define symbol __region_CS0_end__ = CS0_SPACE_PRV_START + CS0_SPACE_PRV_LENGTH - 1;
-define symbol __region_CS2_start__ = CS2_SPACE_PRV_START;
-define symbol __region_CS2_end__ = CS2_SPACE_PRV_START + CS2_SPACE_PRV_LENGTH - 1;
-define symbol __region_CS3_start__ = CS3_SPACE_PRV_START;
-define symbol __region_CS3_end__ = CS3_SPACE_PRV_START + CS3_SPACE_PRV_LENGTH - 1;
-define symbol __region_CS5_start__ = CS5_SPACE_PRV_START;
-define symbol __region_CS5_end__ = CS5_SPACE_PRV_START + CS5_SPACE_PRV_LENGTH - 1;
-
-/************** SPI boot mode setting **************/
-define symbol __region_LDR_PARAM_start__ = FLASH_ADDRESS;
-define symbol __region_LDR_PARAM_end__ = FLASH_ADDRESS + 0x0000004B;
-define symbol __region_S_LOADER_STACK_start__ = FLASH_ADDRESS + 0x0000004C;
-define symbol __region_S_LOADER_STACK_end__ = FLASH_ADDRESS + 0x0000804B;
-
-define symbol __region_S_intvec_start__ = FLASH_ADDRESS + 0x20000;
-define symbol __region_S_intvec_end__ = FLASH_ADDRESS + 0x200FF;
-define symbol __region_S_RAM_start__ = FLASH_ADDRESS + 0x70000;
-define symbol __region_S_RAM_end__ = FLASH_ADDRESS + 0x7FFFF;
-/****************************************************/
-
-define region D_LOADER_STACK_region = mem:[from __region_D_LOADER_STACK_start__ to __region_D_LOADER_STACK_end__];
-
-define region LDR_PARAM_region = mem:[from __region_LDR_PARAM_start__ to __region_LDR_PARAM_end__];
-define region S_LOADER_STACK_region = mem:[from __region_S_LOADER_STACK_start__ to __region_S_LOADER_STACK_end__];
-
-define region S_intvec_region = mem:[from __region_S_intvec_start__ to __region_S_intvec_end__];
-define region S_RAM_region = mem:[from __region_S_RAM_start__ to __region_S_RAM_end__];
-
-define region DATA_NONCACHE_region = mem:[from __region_DATA_NONCACHE_start__ to __region_DATA_NONCACHE_end__];
-define region DMAC_LINK_MODE_region = mem:[from __region_DMAC_LINK_MODE_start__ to __region_DMAC_LINK_MODE_end__];
-define region SHARED_NONCACHE_BUFFER_region = mem:[from __region_SHARED_NONCACHE_BUFFER_start__ to __region_SHARED_NONCACHE_BUFFER_end__];
-define region NONCACHE_BUFFER_region = mem:[from __region_NONCACHE_BUFFER_start__ to __region_NONCACHE_BUFFER_end__];
-
-define region ATCM_region = mem:[from __region_ATCM_start__ to __region_ATCM_end__ ];
-define region BTCM_region = mem:[from __region_BTCM_start__ to __region_BTCM_end__ ];
-define region SYSTEM_RAM_region = mem:[from __region_SYSTEM_RAM_start__ to __region_SYSTEM_RAM_end__ ];
-define region SYSTEM_RAM_MIRROR_region = mem:[from __region_SYSTEM_RAM_MIRROR_start__ to __region_SYSTEM_RAM_MIRROR_end__ ];
-define region XSPI0_CS0_MIRROR_region = mem:[from __region_XSPI0_CS0_MIRROR_start__ to __region_XSPI0_CS0_MIRROR_end__ ];
-define region XSPI0_CS1_MIRROR_region = mem:[from __region_XSPI0_CS1_MIRROR_start__ to __region_XSPI0_CS1_MIRROR_end__ ];
-define region XSPI1_CS0_MIRROR_region = mem:[from __region_XSPI1_CS0_MIRROR_start__ to __region_XSPI1_CS0_MIRROR_end__ ];
-define region XSPI1_CS1_MIRROR_region = mem:[from __region_XSPI1_CS1_MIRROR_start__ to __region_XSPI1_CS1_MIRROR_end__ ];
-define region CS0_MIRROR_region = mem:[from __region_CS0_MIRROR_start__ to __region_CS0_MIRROR_end__ ];
-define region CS2_MIRROR_region = mem:[from __region_CS2_MIRROR_start__ to __region_CS2_MIRROR_end__ ];
-define region CS3_MIRROR_region = mem:[from __region_CS3_MIRROR_start__ to __region_CS3_MIRROR_end__ ];
-define region CS5_MIRROR_region = mem:[from __region_CS5_MIRROR_start__ to __region_CS5_MIRROR_end__ ];
-define region XSPI0_CS0_region = mem:[from __region_XSPI0_CS0_start__ to __region_XSPI0_CS0_end__ ];
-define region XSPI0_CS1_region = mem:[from __region_XSPI0_CS1_start__ to __region_XSPI0_CS1_end__ ];
-define region XSPI1_CS0_region = mem:[from __region_XSPI1_CS0_start__ to __region_XSPI1_CS0_end__ ];
-define region XSPI1_CS1_region = mem:[from __region_XSPI1_CS1_start__ to __region_XSPI1_CS1_end__ ];
-define region CS0_region = mem:[from __region_CS0_start__ to __region_CS0_end__ ];
-define region CS2_region = mem:[from __region_CS2_start__ to __region_CS2_end__ ];
-define region CS3_region = mem:[from __region_CS3_start__ to __region_CS3_end__ ];
-define region CS5_region = mem:[from __region_CS5_start__ to __region_CS5_end__ ];
-
-define block LDR_PRG_RBLOCK with fixed order
- { ro code section .loader_text_init object startup_core.o,
- ro code object startup_core.o,
- ro code object system_core.o,
- ro code object startup.o,
- ro code object system.o,
- ro code object bsp_clocks.o,
- ro code object bsp_irq_core.o,
- ro code object bsp_irq.o,
- ro code object bsp_register_protection.o,
- ro code object r_ioport.o,
- ro code object bsp_cache.o,
- ro code section .warm_start_init }
- except { ro code section .intvec_init,
- ro code section .reset_handler_init };
-define block LDR_PRG_WBLOCK with fixed order
- { rw code section .loader_text object startup_core.o,
- rw code object startup_core.o,
- rw code object system_core.o,
- rw code object startup.o,
- rw code object system.o,
- rw code object bsp_clocks.o,
- rw code object bsp_irq_core.o,
- rw code object bsp_irq.o,
- rw code object bsp_register_protection.o,
- rw code object r_ioport.o,
- rw code object bsp_cache.o,
- rw code section .warm_start }
- except { rw code section .intvec,
- rw code section .reset_handler };
-define block LDR_DATA_ZBLOCK with alignment = 4
- { section .bss object startup_core.o,
- section .bss object system_core.o,
- section .bss object startup.o,
- section .bss object system.o,
- section .bss object bsp_clocks.o,
- section .bss object bsp_irq_core.o,
- section .bss object bsp_irq.o,
- section .bss object bsp_register_protection.o,
- section .bss object r_ioport.o,
- section .bss object bsp_cache.o,
- section .bss object bsp_io.o };
-define block LDR_DATA_RBLOCK with fixed order, alignment = 4
- { section .data_init object startup_core.o,
- section .data_init object system_core.o,
- section .data_init object startup.o,
- section .data_init object system.o,
- section .data_init object bsp_clocks.o,
- section .data_init object bsp_irq_core.o,
- section .data_init object bsp_irq.o,
- section .data_init object bsp_register_protection.o,
- section .data_init object r_ioport.o,
- section .data_init object bsp_cache.o,
- section .rodata_init object system_core.o };
-define block LDR_DATA_WBLOCK with fixed order, alignment = 4
- { section .data object startup_core.o,
- section .data object system_core.o,
- section .data object startup.o,
- section .data object system.o,
- section .data object bsp_clocks.o,
- section .data object bsp_irq_core.o,
- section .data object bsp_irq.o,
- section .data object bsp_register_protection.o,
- section .data object r_ioport.o,
- section .data object bsp_cache.o,
- section .rodata object system_core.o };
-
-define block HEAP_BLOCK with alignment = 8 { rw section HEAP };
-define block THREAD_STACK with alignment = 8 { rw section .stack* };
-define block SYS_STACK with alignment = 8 { rw section .sys_stack };
-define block SVC_STACK with alignment = 8 { rw section .svc_stack };
-define block IRQ_STACK with alignment = 8 { rw section .irq_stack };
-define block FIQ_STACK with alignment = 8 { rw section .fiq_stack };
-define block UND_STACK with alignment = 8 { rw section .und_stack };
-define block ABT_STACK with alignment = 8 { rw section .abt_stack };
-
-define block VECTOR_RBLOCK with alignment = 32 { ro code section .intvec_init};
-define block VECTOR_WBLOCK with alignment = 32 { rw code section .intvec};
-define block USER_PRG_RBLOCK with alignment = 4 { ro code };
-define block USER_PRG_WBLOCK with alignment = 4 { rw code };
-define block USER_DATA_ZBLOCK with alignment = 4 { section .bss };
-define block USER_DATA_RBLOCK with fixed order, alignment = 4
- { section .data_init,
- section __DLIB_PERTHREAD_init,
- section .rodata_init,
- section .version_init };
-define block USER_DATA_WBLOCK with fixed order, alignment = 4
- { section .data,
- section __DLIB_PERTHREAD,
- section .rodata,
- section .version };
-define block USER_DATA_NONCACHE_RBLOCK with alignment = 4 { section .data_noncache_init };
-define block USER_DATA_NONCACHE_WBLOCK with alignment = 4 { section .data_noncache };
-define block DMAC_LINK_MODE_ZBLOCK with alignment = 4 { section .dmac_link_mode* };
-define block SHARED_NONCACHE_BUFFER_ZBLOCK with alignment = 32 { section .shared_noncache_buffer* };
-define block NONCACHE_BUFFER_ZBLOCK with alignment = 32 { section .noncache_buffer* };
-
-initialize manually { ro code object startup_core.o,
- ro code object system_core.o,
- ro code object startup.o,
- ro code object system.o,
- ro code object bsp_clocks.o,
- ro code object bsp_irq_core.o,
- ro code object bsp_irq.o,
- ro code object bsp_register_protection.o,
- ro code object r_ioport.o,
- ro code object bsp_cache.o,
- ro code section .intvec,
- ro code section .reset_handler,
- ro code section .warm_start,
- ro code,
- section .data,
- section __DLIB_PERTHREAD,
- section .rodata,
- section .version,
- section .data_noncache };
-
-do not initialize { section .noinit,
- section .bss,
- section .dmac_link_mode*,
- section .shared_noncache_buffer*,
- section .noncache_buffer*,
- rw section HEAP,
- rw section .stack*,
- rw section .sys_stack,
- rw section .svc_stack,
- rw section .irq_stack,
- rw section .fiq_stack,
- rw section .und_stack,
- rw section .abt_stack };
-
-place at address mem: __ICFEDIT_intvec_start__ { block VECTOR_WBLOCK };
-
-place in LDR_PARAM_region { readonly section .loader_param };
-place at start of S_LOADER_STACK_region { block LDR_PRG_RBLOCK };
-place in S_LOADER_STACK_region { section LDR_DATA_RBLOCK, block LDR_DATA_RBLOCK };
-place in S_intvec_region { block VECTOR_RBLOCK };
-place in ROM_region { block USER_PRG_RBLOCK, readonly };
-place in S_RAM_region { block USER_DATA_RBLOCK, block USER_DATA_NONCACHE_RBLOCK };
-
-place at start of D_LOADER_STACK_region { block LDR_PRG_WBLOCK };
-place in D_LOADER_STACK_region { section LDR_DATA_WBLOCK, block LDR_DATA_WBLOCK,
- section LDR_DATA_ZBLOCK, block LDR_DATA_ZBLOCK };
-place in D_LOADER_STACK_region { section SYS_STACK, block SYS_STACK,
- section SVC_STACK, block SVC_STACK,
- section IRQ_STACK, block IRQ_STACK,
- section FIQ_STACK, block FIQ_STACK,
- section UND_STACK, block UND_STACK,
- section ABT_STACK, block ABT_STACK };
-place in RAM_region { block USER_PRG_WBLOCK };
-place in RAM_region { readwrite, last block CSTACK };
-place in RAM_region { block USER_DATA_WBLOCK,
- block USER_DATA_ZBLOCK };
-place in RAM_region { section HEAP_BLOCK, block HEAP_BLOCK,
- section THREAD_STACK, block THREAD_STACK };
-
-place in DATA_NONCACHE_region { block USER_DATA_NONCACHE_WBLOCK };
-place in DMAC_LINK_MODE_region { block DMAC_LINK_MODE_ZBLOCK };
-place in SHARED_NONCACHE_BUFFER_region { block SHARED_NONCACHE_BUFFER_ZBLOCK };
-place in NONCACHE_BUFFER_region { block NONCACHE_BUFFER_ZBLOCK };
-place in ATCM_region { };
-place in BTCM_region { };
-place in SYSTEM_RAM_region { };
-place in SYSTEM_RAM_MIRROR_region { };
-place in XSPI0_CS0_MIRROR_region { };
-place in XSPI0_CS1_MIRROR_region { };
-place in XSPI1_CS0_MIRROR_region { };
-place in XSPI1_CS1_MIRROR_region { };
-place in CS0_MIRROR_region { };
-place in CS2_MIRROR_region { };
-place in CS3_MIRROR_region { };
-place in CS5_MIRROR_region { };
-place in XSPI0_CS0_region { };
-place in XSPI0_CS1_region { };
-place in XSPI1_CS0_region { };
-place in XSPI1_CS1_region { };
-place in CS0_region { };
-place in CS2_region { };
-place in CS3_region { };
-place in CS5_region { };
diff --git a/bsp/renesas/rzn2l_rsk/script/memory_regions.ld b/bsp/renesas/rzn2l_rsk/script/memory_regions.ld
deleted file mode 100644
index 227ab3ebb17..00000000000
--- a/bsp/renesas/rzn2l_rsk/script/memory_regions.ld
+++ /dev/null
@@ -1,38 +0,0 @@
-
- /* generated memory regions file - do not edit */
- ATCM_START = 0x00000000;
- ATCM_LENGTH = 0x20000;
- BTCM_START = 0x00100000;
- BTCM_LENGTH = 0x20000;
- SYSTEM_RAM_START = 0x10000000;
- SYSTEM_RAM_LENGTH = 0x180000;
- SYSTEM_RAM_MIRROR_START = 0x30000000;
- SYSTEM_RAM_MIRROR_LENGTH = 0x180000;
- xSPI0_CS0_SPACE_MIRROR_START = 0x40000000;
- xSPI0_CS0_SPACE_MIRROR_LENGTH = 0x4000000;
- xSPI0_CS1_SPACE_MIRROR_START = 0x44000000;
- xSPI0_CS1_SPACE_MIRROR_LENGTH = 0x4000000;
- xSPI1_CS0_SPACE_MIRROR_START = 0x48000000;
- xSPI1_CS0_SPACE_MIRROR_LENGTH = 0x4000000;
- CS0_SPACE_MIRROR_START = 0x50000000;
- CS0_SPACE_MIRROR_LENGTH = 0x4000000;
- CS2_SPACE_MIRROR_START = 0x54000000;
- CS2_SPACE_MIRROR_LENGTH = 0x4000000;
- CS3_SPACE_MIRROR_START = 0x58000000;
- CS3_SPACE_MIRROR_LENGTH = 0x4000000;
- CS5_SPACE_MIRROR_START = 0x5C000000;
- CS5_SPACE_MIRROR_LENGTH = 0x4000000;
- xSPI0_CS0_SPACE_START = 0x60000000;
- xSPI0_CS0_SPACE_LENGTH = 0x4000000;
- xSPI0_CS1_SPACE_START = 0x64000000;
- xSPI0_CS1_SPACE_LENGTH = 0x4000000;
- xSPI1_CS0_SPACE_START = 0x68000000;
- xSPI1_CS0_SPACE_LENGTH = 0x4000000;
- CS0_SPACE_START = 0x70000000;
- CS0_SPACE_LENGTH = 0x4000000;
- CS2_SPACE_START = 0x74000000;
- CS2_SPACE_LENGTH = 0x4000000;
- CS3_SPACE_START = 0x78000000;
- CS3_SPACE_LENGTH = 0x4000000;
- CS5_SPACE_START = 0x7C000000;
- CS5_SPACE_LENGTH = 0x4000000;
diff --git a/components/drivers/rtc/dev_alarm.c b/components/drivers/rtc/dev_alarm.c
index e17f34462c9..ae619bf59af 100644
--- a/components/drivers/rtc/dev_alarm.c
+++ b/components/drivers/rtc/dev_alarm.c
@@ -52,7 +52,11 @@ static rt_err_t alarm_set(struct rt_alarm *alarm)
struct rt_rtc_wkalarm wkalarm;
rt_err_t ret;
+#ifdef RT_USING_SOFT_RTC
+ device = rt_device_find("sw_rtc");
+#else
device = rt_device_find("rtc");
+#endif
if (device == RT_NULL)
{
diff --git a/components/drivers/rtc/dev_soft_rtc.c b/components/drivers/rtc/dev_soft_rtc.c
index 0eab72ebe5a..dcd4721409f 100644
--- a/components/drivers/rtc/dev_soft_rtc.c
+++ b/components/drivers/rtc/dev_soft_rtc.c
@@ -226,8 +226,8 @@ static int rt_soft_rtc_init(void)
{
return 0;
}
- /* make sure only one 'rtc' device */
- RT_ASSERT(!rt_device_find("rtc"));
+ /* make sure only one 'sw_rtc' device */
+ RT_ASSERT(!rt_device_find("sw_rtc"));
#ifdef RT_USING_ALARM
rt_timer_init(&alarm_time,
@@ -258,7 +258,9 @@ static int rt_soft_rtc_init(void)
/* no private */
soft_rtc_dev.user_data = RT_NULL;
- rt_device_register(&soft_rtc_dev, "rtc", RT_DEVICE_FLAG_RDWR);
+ rt_device_register(&soft_rtc_dev, "sw_rtc", RT_DEVICE_FLAG_RDWR);
+
+ source_device = &soft_rtc_dev;
init_ok = RT_TRUE;
@@ -317,7 +319,7 @@ static void cmd_rtc_sync(int argc, char **argv)
rt_kprintf("local time: %.*s", 25, ctime(&now));
rt_kprintf("timestamps: %ld\n", (long)tv.tv_sec);
}
-MSH_CMD_EXPORT_ALIAS(cmd_rtc_sync, rtc_sync, Update time by real rtc);
+MSH_CMD_EXPORT_ALIAS(cmd_rtc_sync, rtc_sync, Update time by soft rtc);
#endif
#endif /* RT_USING_SYSTEM_WORKQUEUE */
diff --git a/libcpu/arm/cortex-r52/context_gcc.S b/libcpu/arm/cortex-r52/context_gcc.S
index e95c631eefb..1bd581e9ee2 100644
--- a/libcpu/arm/cortex-r52/context_gcc.S
+++ b/libcpu/arm/cortex-r52/context_gcc.S
@@ -8,7 +8,6 @@
* 2024-03-01 Wangyuqiang first version
*/
-#include "rtconfig.h"
.syntax unified
.text
diff --git a/libcpu/arm/cortex-r52/start_gcc.S b/libcpu/arm/cortex-r52/start_gcc.S
index 787d3e44fbb..73d70a63b9d 100644
--- a/libcpu/arm/cortex-r52/start_gcc.S
+++ b/libcpu/arm/cortex-r52/start_gcc.S
@@ -12,8 +12,6 @@
@ (c) Texas Instruments 2009-2013, All rights reserved.
@
-//#include
-
.equ Mode_USR, 0x10
.equ Mode_FIQ, 0x11
.equ Mode_IRQ, 0x12
@@ -47,7 +45,7 @@ stack_top:
.text
.arm
- .globl _c_int00
+ .globl entry
.globl _reset
_reset:
@@ -122,7 +120,7 @@ next2:
next3:
bl next4
next4:
- ldr lr, =_c_int00
+ ldr lr, =entry
bx lr
.globl data_init
@@ -479,26 +477,38 @@ turnon_VFP:
str lr, [r0, #14*4] @/* Save calling PC */
.endm
- .globl vector_svc
-vector_svc:
- push_svc_reg
- bl rt_hw_trap_svc
- b .
-
- .globl vector_pabort
-vector_pabort:
- push_svc_reg
- bl rt_hw_trap_pabt
- b .
-
- .globl vector_dabort
-vector_dabort:
- push_svc_reg
- bl rt_hw_trap_dabt
- b .
-
- .globl vector_resv
-vector_resv:
- push_svc_reg
- bl rt_hw_trap_resv
- b .
+.globl SWI_Handler
+SWI_Handler:
+ push_svc_reg
+ bl rt_hw_trap_swi
+ b .
+
+.globl Undefined_Handler
+Undefined_Handler:
+ push_svc_reg
+ bl rt_hw_trap_undef
+ b .
+
+.globl SVC_Handler
+SVC_Handler:
+ push_svc_reg
+ b rt_hw_trap_svc
+ b .
+
+.globl Prefetch_Handler
+Prefetch_Handler:
+ push_svc_reg
+ b rt_hw_trap_pabt
+ b .
+
+.globl Abort_Handler
+Abort_Handler:
+ push_svc_reg
+ b rt_hw_trap_dabt
+ b .
+
+.globl Reserved_Handler
+Reserved_Handler:
+ push_svc_reg
+ b rt_hw_trap_resv
+ b .
diff --git a/libcpu/arm/cortex-r52/start_iar.S b/libcpu/arm/cortex-r52/start_iar.S
index 9e110dd1525..ec096d5c01f 100644
--- a/libcpu/arm/cortex-r52/start_iar.S
+++ b/libcpu/arm/cortex-r52/start_iar.S
@@ -31,11 +31,13 @@ ABT_Stack_Size EQU 0x00000000
FIQ_Stack_Size EQU 0x00001000
IRQ_Stack_Size EQU 0x00001000
- IMPORT _c_int00
+ IMPORT entry
IMPORT rt_hw_trap_svc
IMPORT rt_hw_trap_pabt
IMPORT rt_hw_trap_dabt
IMPORT rt_hw_trap_resv
+ IMPORT rt_hw_trap_swi
+ IMPORT rt_hw_trap_undef
IMPORT system_init
IMPORT __iar_program_start
@@ -308,6 +310,18 @@ turnon_VFP:
str lr, [r0, #14*4] ;@/* Save calling PC */
endm
+ EXPORT SWI_Handler
+SWI_Handler:
+ push_svc_reg
+ bl rt_hw_trap_swi
+ b .
+
+ EXPORT Undefined_Handler
+Undefined_Handler:
+ push_svc_reg
+ bl rt_hw_trap_undef
+ b .
+
EXPORT SVC_Handler
SVC_Handler:
push_svc_reg
diff --git a/libcpu/arm/cortex-r52/vector_gcc.S b/libcpu/arm/cortex-r52/vector_gcc.S
index a0421d535ea..85686ede069 100644
--- a/libcpu/arm/cortex-r52/vector_gcc.S
+++ b/libcpu/arm/cortex-r52/vector_gcc.S
@@ -19,7 +19,8 @@
@ import reference for interrupt routines
.globl Reset_Handler
- .globl turnon_VFP
+ .globl Undefined_Handler
+ .globl SWI_Handler
.globl SVC_Handler
.globl Prefetch_Handler
.globl Abort_Handler
@@ -28,10 +29,11 @@
.globl FIQ_Handler
-.globl system_vectors
-system_vectors:
+.globl system_vector
+system_vector:
b Reset_Handler
- b turnon_VFP
+ b Undefined_Handler
+ b SWI_Handler
b SVC_Handler
b Prefetch_Handler
b Abort_Handler
diff --git a/libcpu/arm/cortex-r52/vector_iar.S b/libcpu/arm/cortex-r52/vector_iar.S
index 916e44d6a50..57de4e8f838 100644
--- a/libcpu/arm/cortex-r52/vector_iar.S
+++ b/libcpu/arm/cortex-r52/vector_iar.S
@@ -20,6 +20,7 @@
IMPORT Reset_Handler
IMPORT Undefined_Handler
+ IMPORT SWI_Handler
IMPORT SVC_Handler
IMPORT Prefetch_Handler
IMPORT Abort_Handler
@@ -35,6 +36,7 @@
system_vectors:
b Reset_Handler
b Undefined_Handler
+ b SWI_Handler
b SVC_Handler
b Prefetch_Handler
b Abort_Handler