1.首先说说什么是icf文件(即ILINK链接器的配置文件)的作用,其实在IAR5.x之前,IAR是采用的叫XLINK的链接器(它相应的配置文件为xcl文件),5.x之后才采用了新版ILINK链接器,所以咱们开发Kinetis的IAR6.x自然也采用的是ILINK链接器,配置文件为icf文件,咳咳,如果有人问什么是链接器,先谷歌一下补补,我这里就引用IAR官方手册里的一句话简要说明一下什么是链接器及其相应配置文件的作用吧:

”EWARM 5.xx 中的链接器称为ILINK。ILINK 可以从 ELF/DWARF 格式的目标文件中提取代码和数据, 并生成可执行的输出镜像。对于 ELF/DWARF 格式而言,基本的链接单元是section,section 的类型有code和data,属性可以是readonly (ro),readwrite (rw)和zeroinit (zi)。ILINK 根据 ILINK Configuration File(*.icf)来分配和定位这些sections。“

2.简单的概括icf的文件,其主要包括以下几个内容,即:

(1)可编址的存储空间(memory);

(2)不同的存储地址区域(region);

(3)不同的地址块(block);

(4)section的初始化与否;

(5)section在存储空间的放置。

上面几点内容,如果你对照实际icf文件都会找得到,建议大家尝试下,会让你受益匪浅的。

3.对于icf文件使用的常用命令,在网上早已有人贴出来了,随意即可搜到,这里省去麻烦,我也贴出来自己学的时候记下来的命令用法,建议通读一遍:

(1)define [ exported ] symbol name = expr;
作用:指定某个符号的值。
参数:

exported 导出该symbol,使其对可执行镜像可用
name 符号名
expr 符号值
举例:

define symbol RAM_START_ADDRESS = 0x40000000;

define symbol RAM_END_ADDRESS  = 0x4000FFFF;

-------------------------------------------------------------------
(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];

define region ROM = MEM:[from 0x0 to 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 { };

define block MYBLOCK1 = { section mysection1, section mysection2, readwrite };

define block MYBLOCK2 = { readwrite object myfile2.o };

define block MYBLOCK3 = { readonly code object myfile3.o };

(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 };

--------------------------------------------------------------

(6)

do not initialize

{

section-selectors

};

作用:   规定在程序启动时不需要初始化的sections;一般用于__no_init 声明的变量段(.noinit)

参数:

section-selector  同上

举例:

do not initialize { .noinit };

(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 };

place at address MEM:0x0 { section .intvec };

place at address MEM:0x1000 { section .text object myfile.o };

place at address MEM:0x1000 { readonly object myfile.o };

place at address MEM:0x1000 { readonly data object myfile.o };

(8)

place in region-expr

{

extended-selectors

};

作用:   把section 或 block  (按任意顺序)放置在某个region 中

参数:

region-expr   region 的名称

extended-selector   同上

举例:

place in ROM { readonly };

place in RAM { readwrite };

place in RAM { block HEAP, block CSTACK, block IRQ_STACK };

place in ROM { section .text object myfile.o };

place in ROM { readonly object myfile.o };

place in ROM { readonly data object myfile.o };

下面为系统预定义(即你是找不到其定义的,所以不要浪费时间去找了,呵呵)的section和block描述,上图:

4.相关命令知晓了,也就是大好基础了,下面就俺就根据上面个的指令独家解析下飞思卡尔提供的Kinetis例程包里自带的icf配置文件,以512KB_Pflash.icf为例介绍一下(当初自己上传的开发框架代码里没有作相关注释,这里就算是补充了吧,哈哈):

(1)首先找到该文件,打开(咳咳,虽然这步算是废话,不过为了严谨,还是不能少的,呵呵),采用从上到下的顺序解读;

(2)

先定义了一些可读性的符号,包括异常向量表的起始地址,ROM、RAM 的起止地址和堆、栈的大小等(该地址分配我们可以在Kinetis的datasheet里找到),以前缀__ICFEDIT_开头的符号是由图形化编辑工具 ICF Editor自动定义的,可能会有些人不懂,其实上面部分代码是体现在IAR的Options->Linker选项里的(自己去探索一下即可发现)。

(3)

这部分仍然是定义一些符号,由Kinetis的内存映射可以知道,其实其内部是由两部分RAM块组成的,所以第一步出现RAM_start这一步出现了 RAM2_start,另外也定义了中断向量表在ROM中的地址和在RAM中的地址。code_start定义为0x00000410是紧邻前面向量表的,也就是说向量表占用了0x00000410大小的空间。

(4)

到了这一步就设计到具体操作内容了,32位地址总线选址4G空间,然后定义了kinetis(512k型号的哈)的ROM区的地址范围和RAM区(含 RAM1和RAM2)的地址范围。接着下面定义了堆和栈的属性,8字节对齐方式,大小为前面定义的大小即分别为0x1000和0x200。

(5)

对属性为readwrite的sections,.data和.textrw的sections不自动初始化,对.noinit属性的 sections(即用__no_init修饰的全局和静态变量),定义重定位代码区为.textrw_init,定义重定位RAM区为.textrw。

(6)

对所有的sections 和 blocks 在地址空间中所处的位置进行了配置。首先将只读的异常向量表.intvec放置在_intvec_start地址处(前面已定义),然后将余下的只读 sections以任意顺序存放在ROM_region中,将可读写的sections和栈、堆这些blocks以任意顺序存放在RAM_region 中。

参考:IAR中xcl及icf文件详解(百度文库)

IAR编译环境之:ILINK链接器的.ICF文件编写相关推荐

  1. 【转贴】解析IAR的ILINK链接器icf配置文件

    五一来了,三天小假期终于可以让大家歇一歇了(估计好多人都已经在规划着五一出行计划了或者已经在旅途中了),校园里一下子冷清了不少.记得去年12月份曾经写过一篇"写在圣诞节之简单破解飞思卡尔HC ...

  2. 【转】解析IAR的ILINK链接器icf配置文件

    原文:http://blog.chinaaet.com/jihceng0622/p/27024 介绍介绍IAR的icf配置文件,其实这算是一篇知识深入扩展,初手在用IAR简单开发一款片子的时候很少有人 ...

  3. 解析IAR的ILINK链接器icf配置文件

    五一来了,三天小假期终于可以让大家歇一歇了(估计好多人都已经在规划着五一出行计划了或者已经在旅途中了),校园里一下子冷清了不少.记得去年12月份曾经写过一篇"写在圣诞节之简单破解飞思卡尔HC ...

  4. 解析IAR的ILINK链接器icf文件(转)

    解析IAR的ILINK链接器icf文件 转载于:https://www.cnblogs.com/LittleTiger/p/5534582.html

  5. STM32高级开发(8)-链接器与启动文件

    最近休息了一下,中间断断续续在虚拟机上靠着记忆恢复了原来崩溃的虚拟机上80%的工作成果,还算过得去吧,完全丢失的也就是些不大重要的资料.今天新买的机械键盘也到货了,不得不说顺丰的工作人员好评,给过年假 ...

  6. IAR编译提示could not open file lnkstm8s003f3.icf

    这个问题一般出现在把工程的位置移动之后. 把工程中的icf文件再次定下位即可解决."Project"-"Options"-"Linker", ...

  7. IAR ILINK 链接脚本

    sections在地址空间中的存放是由ILINK链接器来实现的,而ILINK链接器是按照用户在ICF文件中的规定来放置sections的,所以理 解ICF文件的内容尤其重要. 一个标准的ICF文件可包 ...

  8. Linux调试私房菜(四)揭开链接器的面纱、汇编语言的内嵌编程

    七.揭开链接器的面纱(上) 1. 问题 源文件被编译后生成目标文件,这些目标文件如何生存最终的可执行程序? 2. 链接器的意义 链接器的主要作用是把各个模块之间相互引用的部分处理好,使得各个模块之间能 ...

  9. 自己动手构造编译系统:编译、汇编与链接

    "自己动手系列" 自己动手构造编译系统 编译.汇编与链接 范志东  张琼声  著 图书在版编目(CIP)数据 自己动手构造编译系统:编译.汇编与链接 / 范志东,张琼声著. -北京 ...

最新文章

  1. origin做主成分分析图_如何用SPSS做主成分分析?学习资料集锦
  2. python装饰器类-python装饰器2:类装饰器
  3. 自定义起始时间的时间戳计算(个人代码记录)
  4. 根据对方提供的URL获取返回的数据流并保存为XML
  5. 【电子信息复试】考研复试常考问题——软件工程
  6. 美团在Redis上踩过的一些坑-1.客户端周期性出现connect timeout
  7. 使用 idea 创建第一个 springboot 项目
  8. 聊聊安卓折叠屏给交互设计和开发带来的变化
  9. mongodb or and 条件拼凑 Query.And Query.Or
  10. POJ1734无向图求最小环
  11. dubbo 分组后,dubbo-admin 看不到服务
  12. 记录一次通过抓包解决Zabbix no active checks on server
  13. avast6.0网络安全软件破解至2050年_avast激活码_avast有效激活
  14. 2021数学建模E题
  15. Axure RP 9.0.0.3687 正式版
  16. 公司专利技术交底书撰写及申请完全流程
  17. win10豆沙绿设置
  18. vivo手机可以升级鸿蒙系统,什么手机可以刷鸿蒙系统?vivo、OPPO、三星手机刷鸿蒙系统教程...
  19. C语言 输出出生日期
  20. 2020-10-17

热门文章

  1. NWERC 2017(English Restaurant-期望)
  2. 如何免费使用WPS的PDF拆分和PDF提取
  3. 安装.net35报错0x800F0954
  4. 羊毛党大揭秘:一亿手机黑卡在手 半年撸垮上市公司
  5. 2016蓝桥杯省赛 抽签(填空)
  6. 计算机设置位蓝牙播放xp,winxp系统电脑连接蓝牙耳机听音乐的方法
  7. Si8621AB-B-IS兼容品2Pai荣湃π122M30 3.0kV10Mbps 双通道数字隔离器
  8. 自救与救他,一家餐饮企业的生死240小时
  9. [elasticsearch笔记]Managing the index lifecycle
  10. String literals in formulas can’t be bigger than 255 characters ASCII