2024-01-09 21:56:37 +08:00
|
|
|
/***************************************************************************//**
|
|
|
|
* \file HC32F4A0.icf
|
|
|
|
* \version 1.0
|
|
|
|
*
|
|
|
|
* \brief Linker file for the IAR compiler.
|
|
|
|
*
|
|
|
|
********************************************************************************
|
|
|
|
* \copyright
|
|
|
|
* Copyright (C) 2022-2023, Xiaohua Semiconductor Co., Ltd. All rights reserved.
|
|
|
|
*
|
|
|
|
* This software component is licensed by XHSC under BSD 3-Clause license
|
|
|
|
* (the "License"); You may not use this file except in compliance with the
|
|
|
|
* License. You may obtain a copy of the License at:
|
|
|
|
* opensource.org/licenses/BSD-3-Clause
|
|
|
|
*******************************************************************************/
|
|
|
|
/*###ICF### Section handled by ICF editor, don't touch! *****/
|
2022-05-06 09:28:21 +08:00
|
|
|
/*-Editor annotation file-*/
|
|
|
|
/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_4.xml" */
|
2024-01-09 21:56:37 +08:00
|
|
|
// Check that necessary symbols have been passed to linker via command line interface
|
|
|
|
if((!isdefinedsymbol(_LINK_RAM_)) && (!isdefinedsymbol(_LINK_FLASH_))) {
|
|
|
|
error "Link location not defined or not supported!";
|
|
|
|
}
|
|
|
|
if((!isdefinedsymbol(_HC32F4A0_2M_)) && (!isdefinedsymbol(_HC32F4A0_1M_SINGLE_)) && (!isdefinedsymbol(_HC32F4A0_1M_DUAL_))) {
|
|
|
|
error "Mcu type or size not defined or not supported!";
|
|
|
|
}
|
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
* Memory address and size definitions
|
|
|
|
******************************************************************************/
|
|
|
|
define symbol ram1_base_address = 0x1FFE0000;
|
|
|
|
define symbol ram1_end_address = 0x2005FFFF;
|
|
|
|
|
|
|
|
if(isdefinedsymbol(_LINK_RAM_)) {
|
|
|
|
define symbol ram_start_reserve = 0x20000;
|
|
|
|
define symbol rom1_base_address = ram1_base_address;
|
|
|
|
define symbol rom1_end_address = rom1_base_address + ram_start_reserve - 0x01;
|
|
|
|
define symbol rom2_base_address = 0x0;
|
|
|
|
define symbol rom2_end_address = 0x0;
|
|
|
|
define symbol rom3_base_address = 0x0;
|
|
|
|
define symbol rom3_end_address = 0x0;
|
|
|
|
} else {
|
|
|
|
define symbol ram_start_reserve = 0x0;
|
|
|
|
define symbol rom1_base_address = 0x0;
|
|
|
|
define symbol rom3_base_address = 0x03000000;
|
|
|
|
define symbol rom3_end_address = 0x030017FF;
|
|
|
|
if (isdefinedsymbol(_HC32F4A0_2M_)) {
|
|
|
|
define symbol rom1_end_address = 0x001FFFFF;
|
|
|
|
define symbol rom2_base_address = 0x0;
|
|
|
|
define symbol rom2_end_address = 0x0;
|
|
|
|
} else if (isdefinedsymbol(_HC32F4A0_1M_SINGLE_)) {
|
|
|
|
define symbol rom1_end_address = 0x000FFFFF;
|
|
|
|
define symbol rom2_base_address = 0x0;
|
|
|
|
define symbol rom2_end_address = 0x0;
|
|
|
|
} else if (isdefinedsymbol(_HC32F4A0_1M_DUAL_)) {
|
|
|
|
define symbol rom1_end_address = 0x0007FFFF;
|
|
|
|
define symbol rom2_base_address = 0x00100000;
|
|
|
|
define symbol rom2_end_address = 0x0017FFFF;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-06 09:28:21 +08:00
|
|
|
/*-Specials-*/
|
2024-01-09 21:56:37 +08:00
|
|
|
define symbol __ICFEDIT_intvec_start__ = rom1_base_address;
|
2022-05-06 09:28:21 +08:00
|
|
|
/*-Memory Regions-*/
|
2024-01-09 21:56:37 +08:00
|
|
|
define symbol __ICFEDIT_region_IROM1_start__ = rom1_base_address;
|
|
|
|
define symbol __ICFEDIT_region_IROM1_end__ = rom1_end_address;
|
|
|
|
define symbol __ICFEDIT_region_IROM2_start__ = rom2_base_address;
|
|
|
|
define symbol __ICFEDIT_region_IROM2_end__ = rom2_end_address;
|
|
|
|
define symbol __ICFEDIT_region_IROM3_start__ = rom3_base_address;
|
|
|
|
define symbol __ICFEDIT_region_IROM3_end__ = rom3_end_address;
|
2022-05-06 09:28:21 +08:00
|
|
|
define symbol __ICFEDIT_region_EROM1_start__ = 0x0;
|
|
|
|
define symbol __ICFEDIT_region_EROM1_end__ = 0x0;
|
|
|
|
define symbol __ICFEDIT_region_EROM2_start__ = 0x0;
|
|
|
|
define symbol __ICFEDIT_region_EROM2_end__ = 0x0;
|
|
|
|
define symbol __ICFEDIT_region_EROM3_start__ = 0x0;
|
|
|
|
define symbol __ICFEDIT_region_EROM3_end__ = 0x0;
|
2024-01-09 21:56:37 +08:00
|
|
|
define symbol __ICFEDIT_region_IRAM1_start__ = ram1_base_address + ram_start_reserve;
|
|
|
|
define symbol __ICFEDIT_region_IRAM1_end__ = ram1_end_address;
|
2022-05-06 09:28:21 +08:00
|
|
|
define symbol __ICFEDIT_region_IRAM2_start__ = 0x200F0000;
|
|
|
|
define symbol __ICFEDIT_region_IRAM2_end__ = 0x200F0FFF;
|
|
|
|
define symbol __ICFEDIT_region_ERAM1_start__ = 0x0;
|
|
|
|
define symbol __ICFEDIT_region_ERAM1_end__ = 0x0;
|
|
|
|
define symbol __ICFEDIT_region_ERAM2_start__ = 0x0;
|
|
|
|
define symbol __ICFEDIT_region_ERAM2_end__ = 0x0;
|
|
|
|
define symbol __ICFEDIT_region_ERAM3_start__ = 0x0;
|
|
|
|
define symbol __ICFEDIT_region_ERAM3_end__ = 0x0;
|
|
|
|
|
|
|
|
|
|
|
|
/*-Sizes-*/
|
2024-01-09 21:56:37 +08:00
|
|
|
define symbol __ICFEDIT_size_cstack__ = 0x2000;
|
2022-05-06 09:28:21 +08:00
|
|
|
define symbol __ICFEDIT_size_proc_stack__ = 0x0;
|
2024-01-09 21:56:37 +08:00
|
|
|
define symbol __ICFEDIT_size_heap__ = 0x2000;
|
2022-05-06 09:28:21 +08:00
|
|
|
/**** End of ICF editor section. ###ICF###*/
|
|
|
|
|
2024-01-09 21:56:37 +08:00
|
|
|
/*******************************************************************************
|
|
|
|
* Memory definitions
|
|
|
|
******************************************************************************/
|
2022-05-06 09:28:21 +08:00
|
|
|
define memory mem with size = 4G;
|
|
|
|
define region ROM_region = mem:[from __ICFEDIT_region_IROM1_start__ to __ICFEDIT_region_IROM1_end__]
|
|
|
|
| mem:[from __ICFEDIT_region_IROM2_start__ to __ICFEDIT_region_IROM2_end__];
|
2024-01-09 21:56:37 +08:00
|
|
|
define region OTP_region = mem:[from __ICFEDIT_region_IROM3_start__ to __ICFEDIT_region_IROM3_end__];
|
2022-05-06 09:28:21 +08:00
|
|
|
define region RAM_region = mem:[from __ICFEDIT_region_IRAM1_start__ to __ICFEDIT_region_IRAM1_end__]
|
|
|
|
| mem:[from __ICFEDIT_region_IRAM2_start__ to __ICFEDIT_region_IRAM2_end__];
|
|
|
|
|
|
|
|
define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
|
|
|
|
define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
|
|
|
|
|
|
|
|
initialize by copy { readwrite };
|
|
|
|
do not initialize { section .noinit };
|
|
|
|
|
|
|
|
place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
|
|
|
|
|
|
|
|
place in ROM_region { readonly };
|
2024-01-09 21:56:37 +08:00
|
|
|
place in OTP_region { readonly section .otp_data };
|
2022-05-06 09:28:21 +08:00
|
|
|
place in RAM_region { readwrite,
|
|
|
|
block CSTACK, block HEAP };
|