您的位置 首页 汽车

关于ARM加载时、运行时地址的了解

只是这样理解,对于一些过程而言,就能够说得通了,也与一些资料上说的情况吻合了。scatter文件中的下载时地址和运行时地址是在编译和链接…

仅仅这样了解,关于一些进程而言,就可以说得通了,也与一些材料上说的状况符合了。

scatter文件中的下载时地址和运转时地址是在编译和链接阶段用的。
比方有下面的scatter文件,以从汇编中跳转到c文件为例。
LOAD 0x0
{
JMAIN +0
{
jmain.o(jmain,+first)
}
TEST 0x200
{
test.o
*(+RO,+RW,+ZI)
}
}
jmain.s中仅仅一个跳转,
b __main,
main在test.c中界说.
void main(){}

scatter文件中LOAD处的0x0表明的是下载时地址,它表明的是整个工程文件中生成的一切.o文件在编译的

时分都是从0x0,早年到后顺次排开(jmian.o在0x0开端,test.o紧跟着jmain.o),当然也或许中心有些处

理,但总的来说是这样的。关于比方而言,可以了解为,生成的.bin文件中从0x0开端,jmain.o和test.o

及其他.他们之间并没有什么空隙.

而scatter中的运转时地址,如0x200,是用来辅导编译器编译指令的,有这种状况:
假如将0x200改成0x100,检查编译的二进制码,指令为:0xea00003e,在为0x200时,指令为0xea00007e

这儿面的不同阐明编译器依据了运转时地址来生成指令的二进制码.

所以,我以为可以将下载时地址看成是一段内存的首地址,以该地址开端寄存的指令在详细编译,生成二进

制码的时分需求运转时地址的介入.

到了详细运转的时分,比方运转0xea00007e,那么cpu便会跳转,去运转0x200处的指令了.这样,就和一般的

材料上讲的运转时和下载时地址符合了.

可是还有一个问题,仍以上面的比方,假如将.bin文件下载到板子的0x0地址.cpu在从0x0开端运转后,便会

运转0xea00007e,但此刻0x200处并没有咱们想要运转的指令,比方main().一切,有一个复制的进程需求在

跳转到main()之前进行.

在编译链接的时分,linker会将0x200这个地址保存到某个地址处,在b __main之后,就会从该地址处取出

0x200,将test.o以及后边的东东从下载时的地址(在jmain.o后边,也便是前面说到的顺次排开的地址)经过

loop复制到0x200这个地址的当地,并顺次排开.在copy往后,跳转到0x200处,即运转0xea00007e才会正常.

这个copy的进程可以有编译器做,也可以咱们自己写代码完结.

回到ads中的ro base设置,它是scatter中的下载时地址=root region的运转时地址.在ads中,设置ro

base=0x10000,并将生成的.bin下载到板子的ram上,如mx 0x8000,g 0x8000,程序能正常运转.这是因

为.bin在板子上是被放在0x8000处的,从0x8000开端运转是因为cpu的pc总是+4的运转,在跳转之前的指令

都没有触及到肯定地址,相对地址这些,他们的二进制码也不会触及这些地址.所以能正常运转.当运转到b

__main的时分,使用ads主动生成的loop等完结copy.在copy中才触及到了0x10000.正是这个copy,以及这以后

的b __rt_entry,使程序可以正常运转.

这样看来,scatter文件中的加载时地址就并不那么重要了.

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

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

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

微信扫一扫关注我们

返回顶部