Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1054048
  • 博文数量: 178
  • 博客积分: 10222
  • 博客等级: 上将
  • 技术积分: 2215
  • 用 户 组: 普通用户
  • 注册时间: 2008-01-03 11:27
个人简介

有所追求

文章分类

全部博文(178)

文章存档

2012年(1)

2011年(5)

2010年(3)

2009年(78)

2008年(91)

我的朋友

分类:

2009-03-15 20:49:37

谢谢您的推荐

这是一位用户的问题,这里转发一下答复(也是摘自北航书“44binit.s初始化程序研究”一节中的一部分内容)

一个简易的映像文件包括以下几个部分:
○ 一个只读(RO)区域;
○ 一个读写(RW)区域;
○ 一个被0初始化(ZI)的区域。
我们采用如下的方法,在链接器中指定每个区域在执行时的定位地址:
-RO-base   exec_address1    指示链接器将只读(RO)区域定位在exec_address1地址处(例如,定位在ROM空间的起始地址上);
-RW-base   exec_address2   指示链接器将读写(RW)区域定位在exec_address2地址处。
在RW(数据)区域中,也可能含有程序代码,这是因为程序有时候需要自我修改(或产生新的代码),类似的,RO(代码)区域中可能包含只读的数据(例如字符串,常数等)。
链接器在创建上述区域的同时产生相应的“符号”并把地址信息传递给这些符号,从而允许将区域从它的加载地址拷贝到执行地址。这些符号描述了每个区域的起始地址和大小限制。这些符号的列举和定义,请参考附图。

在这里,exec_address1是RO区域的执行地址,它与RO区域在代码加载时的地址相同。exec_address2是RW的代码执行地址,它与RW区在加载时的地址是不一样的,RW在加载时是紧接在R0区域后面的,因此在C程序执行之前,它必须被移到正确的地址上去。同时,ZI区域也必须重新创建(因为在加载阶段,不存在ZI区域)。

在一个简单的image里面:
Image$$RO$$Base:是RO段的执行地址开始和装载地址开始,由-RO-BASE这个参数指定的
Image$$RO$$Limit:是RO段的装载地址结束的后一个地址,也就是RW的装载地址的开始。(在一个simple image里面,装载的时候,RO段被装载在-RO-BASE指定的地址,后面紧跟着的是RW的数据,注意,在simple image执行的时候,因为ro段的装载地址和执行地址相同,所以不需要移动,而RW的执行地址是由-RW-BASE指定的,所以需要移动!)
Image$$RW$$Base:是rw段的执行地址,由-rw-base这个参数指定!
总结一下:
没运行前:flash中的ro段是ro-base指定的地址开始,等ro段完了(也就是Image$$RO$$Base~Image$$RO$$limit-1),后面紧接着就是rw段(也就是Image$$RO$$limit~。。。)!
运行时:flash中的ro段地址没有动,还是Image$$RO$$Base~Image$$RO$$limit-1,原来flash中的rw段移到了sdram中,地址为Image$$RW$$Base~Image$$ZI$$Base,然后又初始化了一段ZI区!
呵呵!写点这个就当和我一样的弱人共勉吧!如有不对之处,请大家指正!共同进步

阅读(1192) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~