查看: 1554|回复: 0

【A2系列】 SAM4S 之1—IAR.icf

[复制链接]

该用户从未签到

发表于 2015-12-8 09:19:10 | 显示全部楼层 |阅读模式
分享到:
1.什么是iar.icf文件:
   简言之iar.icf文件就是传说中的链接器的配置文件。

2.iar.icf文件的基本作用:
    定义了芯片存储空间的大小。
    定义ROM的大小和起始、结束地址。
    定义RAM的大小和起始、结束地址。
  
3.iar.icf文件内容,即:
(1)可编址的存储空间(memory);
(2)不同的存储地址区域(region);
(3)不同的地址块(block);
(4)section(段)的初始化与否;
(5)section(段)在存储空间的放置。
4.iar.icf文件的常用命令:(认真学习会受益匪浅)
(1)define [ exported ] symbol name = expr;
    作用:指定某个符号的值。
    参数:
   exported 导出该symbol,使其对可执行镜像可用
    name 符号名
    expr 符号值
    举例:
    define symbol RAM_START_ADDRESS = 0x40000000; /* 定义 RAM 起始地址 */
    define symbol RAM_END_ADDRESS = 0x4000FFFF; /* 定义 RAM 结束地址 */
---------------------------------------------------------------------------------------------
(2)define memory name with size = expr [, unit-size];
    作用:
    定义一个可编址的存储地址空间(memory)。
    参数:
    name memory的名称
    expr 地址空间的大小
    unit-size expr的单位,可以是位(unitbitsize),缺省是字节(unitbytesize)
    举例:
    define memory MEM with size = 4G;
---------------------------------------------------------------------------------------------
(3)define region name = region-expr;
    作用:
    定义一个存储地址区域(region)。一个区域可由一个或多个范围组成,每个范围内地址必须连续,但几个范围之间不必是连续的。
    参数:
    name region的名称
    region-expr memory:[from expr { to expr | size expr}],可以定义起止范围,也可以定义起始地址和region的大小
    举例:
    define region ROM = MEM:[from 0x0 size 0x10000];
    /* 定义 ROM region,位于地址空间MEM 中,起始地址为0x0,大小为0x10000 字节 */
    define region ROM = MEM:[from 0x0 to 0xFFFF];
    /* 定义 ROM region,位于地址空间MEM 中,起始地址为0x0,结束地址为0xFFFF */
---------------------------------------------------------------------------------------------
(4)define block name [ with param, param... ]
    {
       extended-selectors
    };
    作用:   定义一个地址块(block);它可以是个只保留指定大小的地址空间的空块,比如栈、堆;也可以包含一系列的sections,由extended-selectors 选择。
    参数:
    name   block 的名称
    param   可以是:     size = expr      (块的大小)
                  maximum size = expr (块大小的上限)
                  alignment = expr   (最小对齐字节数)
                  fixed order     (按照固定顺序放置sections)
    extended-selector [ first | last ] { section-selector | block name | overlay name }
    first       最先存放
    last         最后存放
    section-selector [ section-attribute ][ section sectionname ][object filename ]
    section-attribute [ readonly [ code | data ] | readwrite [ code | data ] | zeroinit ]
    sectionname     section的名称
    filename       目标文件的名称
    name         block或overlay的名称
    注:这里可以按照section的属性,名称及其所在目标文件这三个过滤条件中,任意选取一个条件或多个条件进行组合,来圈定所要求的sections。
   举例:
    define block HEAP with size = 0x1000, alignment = 4 { };
    /* 定义 HEAP block,大小为0x1000,4 字节对齐,没有内容 */
    define block MYBLOCK1 = { section mysection1, section mysection2, readwrite };
    /* 定义 MYBLOCK1 block,含有mysection1,mysection2,以及所有readwrite 属性的sections */
    define block MYBLOCK2 = { readwrite object myfile2.o };
    /* 定义 MYBLOCK2 block,含有目标文件myfile2.o 中所有readwrite 属性的sections */
    define block MYBLOCK3 = { readonly code object myfile3.o };
    /* 定义 MYBLOCK3 block,含有目标文件myfile3.o 中所有readonly 属性的code sections */
---------------------------------------------------------------------------------------------
(5)initialize { by copy | manually } [ with param, param... ]
    {
    section-selectors
    };
    作用:         初始化sections
    参数:
    by copy        在程序启动时自动执行初始化
    manually       在程序启动时不自动执行初始化
    param         可以是:       packing = { none | compress1 | compress2 | auto } copy routine = functionname
                 packing表示是否压缩数据,缺省是auto
                 functionname表示是否使用自己的拷贝函数来取代缺省的拷贝函数
    section-selector 同上
    举例:
    initialize by copy { readwrite }; /* 在启动时初始化所有属性为 readwrite 的sections */
---------------------------------------------------------------------------------------------
(6)do not initialize
    {
       section-selectors
    };
    作用:           规定在程序启动时不需要初始化的sections;一般用于__no_init 声明的变量段(.noinit)
    参数:
    section-selector 同上
    举例:
    do not initialize { .noinit }; /* 在启动时不要初始化.noinit section */
---------------------------------------------------------------------------------------------
(7)place at { address memory [:expr] | start of region_expr | end of region_expr }
    {
       extended-selectors
    };
    作用:              把section 或 block 放置在某个具体的起始地址处,或者一个 region 的开始或结束处
    参数:
    memory            memory 的名称
    expr             地址值,该地址必须在 memory 所定义的范围内
    region_expr       region 的名称
    extended-selector     同上
    举例:
    place at end of ROM { section .checksum };            /* 把.checksum 放在 ROM region 的最后 */
    place at address MEM:0x0 { section .intvec };          /* 把.intvec 放在地址 0x0 */
    place at address MEM:0x1000 { section .text object myfile.o }; /* the .text section of myfile.o */
    place at address MEM:0x1000 { readonly object myfile.o };     /* all read-only sections of myfile.o */
    place at address MEM:0x1000 { readonly data object myfile.o }; /* all read-only data sections of myfile.o */
---------------------------------------------------------------------------------------------
(8)place in region-expr
    {
       extended-selectors
    };
    作用:              把section 或 block (按任意顺序)放置在某个region 中
    参数:
    region-expr       region 的名称
    extended-selector     同上
    举例:
    place in ROM { readonly };           /* all readonly sections */
    place in RAM { readwrite };         /* all readwrite sections */
    place in RAM { block HEAP, block CSTACK, block IRQ_STACK }; /* heap and stacks */
    place in ROM { section .text object myfile.o }; /* the .text section of myfile.o */
    place in ROM { readonly object myfile.o }; /* all read-only sections of myfile.o */
    place in ROM { readonly data object myfile.o }; /* all read-only data sections myfile.o */
    下面为系统预定义(即你是找不到其定义的,所以不要浪费时间去找了,呵呵)的section和block描述,上图:
   

5.如何添加iar.icf文件:
   打开IAR项目的Option属性,然后设置linker-->Linker configuration file这项里面的内容为:
6.具体分析iar.icf文件(基于SAM4SD32C-SAM4S Xplained Pro)

  • <font face="新宋体" color="#2f4f4f">
  • </font>
复制代码

/*###ICF### Section handled by ICF editor, don't touch! ****/
/*-Editor annotation file-*/
/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */

/*-Specials-*/
define symbol __ICFEDIT_intvec_start__ = 0x00400000;      //SAM4S 向量表起始地址

/*-Memory Regions-*/
define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; //SAM4S RAM 起始位置,共160K
define symbol __ICFEDIT_region_RAM_end__    = 0x20027FFF;
define symbol __ICFEDIT_region_ROM_start__ = 0x00400000; //SAM4S ROM 起始位置,共2M
define symbol __ICFEDIT_region_ROM_end__    = 0x005FFFFF;

/*-Sizes-*/
// 定义栈的大小
if (!isdefinedsymbol(__ICFEDIT_size_cstack__)) {
define symbol __ICFEDIT_size_cstack__     = 0x2000;
}
// 定义堆的大小
if (!isdefinedsymbol(__ICFEDIT_size_heap__)) {
define symbol __ICFEDIT_size_heap__        = 0x200;
}
/**** End of ICF editor section. ###ICF###*/

// 定义存储空间大小,32位地址总线选址4G空间
define memory mem with size   = 4G;

// 定义RAM和ROM
define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];

//定义堆和栈的大小,8字节对齐
define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { };
define block HEAP     with alignment = 8, size = __ICFEDIT_size_heap__   { };

//启动时将RW数据搬移到RAM中,完成RW数据的初始化
initialize by copy { readwrite };

//不初始化 有.noinit属性的快
do not initialize { section .noinit };

//放置.intvec,即向量表 到 0x00400000
place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };

//在ROM中放置 只读数据和代码
place in ROM_region        { readonly };

//在RAM中放置 可读写数据 和 堆与栈
place in RAM_region        { readwrite, block CSTACK, block HEAP };

7.SAM4SD32C 地址映射

回复

使用道具 举报

您需要登录后才可以回帖 注册/登录

本版积分规则

关闭

站长推荐上一条 /2 下一条

手机版|小黑屋|与非网

GMT+8, 2024-4-27 12:21 , Processed in 0.117256 second(s), 18 queries , MemCache On.

ICP经营许可证 苏B2-20140176  苏ICP备14012660号-2   苏州灵动帧格网络科技有限公司 版权所有.

苏公网安备 32059002001037号

Powered by Discuz! X3.4

Copyright © 2001-2024, Tencent Cloud.