您的位置 首页 FPGA

根据ARM硬件初始化的一些细节问题的解说

ARM硬件启动程序的工作一般包括:1.分配中断向量表;2.初始化存储器系统;3.初始化各工作模式下的堆栈;4.初始化有特殊要求的硬件…

ARM硬件发动程序的作业一般包含:

1.分配中断向量表;

2.初始化存储器体系;

3.初始化各作业形式下的仓库;

4.初始化有特殊要求的硬件模块;

5.初始化用户程序的履行环境;

6.切换处理器的作业形式;

7.调用主应用程序;

这儿首要解说写初始化应用程序履行环境:

一个典型的可履行程序的映像结构一般如表所列。

可履行程序映像的结构

分区 阐明
ZI(初始化为0的可读/写数据) 只界说了变量名的全局变量
RW(可读/写数据) 界说了带初始值的全局变量
RO(代码和只读数据) 编译后的程序

映像一开端总是存储在ROM/Flash中的,其RO部分既能够在ROM/Flash中履行,也能够转移到速度更快的RAM中履行;而RW和ZI这两部分有必要转移到可写的RAM中。所谓应用程序履行环境的初始化,便是有必要完结必要的从ROM到RAM的数据传输和内容清空。

下面是在ADS集成开发环境中,一种常用存储器模型的直接完成。

LDR     R0,=|Image$$RO$$Limit|LDR     R1,=|Image$$RW$$Base|LDR     R3,=|Image$$ZI$$Base|CMP	  R0,R1BEQ   %F10	CMP   R1,R3LDRCC R2,[R0],#4STRCC R2,[R1],#4BCC   %B01       LDR   R1,=|Image$$ZI$$Limit|MOV   R2,#02CMP     R3,R1STRCC   R2,[R3],#4BCC     %B2 

程序完成了RW数据的和ZI区域的清空。其间引用到的4个符号是由链接器界说的。

|Image$$RO$$Limit|:表明RO区末地址后边的地址,即RW数据源的开端地址。|Image$$RW$$Base|:RW区在RAM里的履行区开端地址,也便是编译器选项RW_Base指定的地址;程序中是RW数据的意图地址。|Image$$ZI$$Base|:ZI区在RAM中的开端地址。|Image$$ZI$$Limit|:ZI区在RAM中的完毕地址后边的一个地址。

程序先把ROM中|Image$$RO$$Limit|地址开端的RW初始数据到RAM中|Image$$RW$$Base|开端的地址,当RAM这边的方针地址抵达|Image$$ZI$$Base|后,
就表明RW区的完毕和ZI区的开端,然后就对这片Zi区进行清零操作,直到遇到完毕地址|Image$$ZI$$Limit|。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/fangan/fpga/276121.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部