对于刚学习 ARM 的人来说,如果分析它的启动代码,往往不明白下面几个变量的含义: |Image$$RO$$Limit| 、 |Image$$RW$$Base| 、 |Image$$ZI$$Base| 。
首先申明我使用的调试软件为 ADS1.2 ,当我们把程序编写好以后,就要进行编译和链接了,在 ADS1.2 中选择 MAKE 按钮,会出现一个 Errors and Warnings 的对话框,在该栏中显示编译和链接的结果,如果没有错误,在文件的最后应该能看到 Image component sizes ,后面紧跟的依次是 Code , RO Data , RW Data , ZI Data , Debug 各个项目的字节数,最后会有他们的一个统计数据:
Code 163632 , RO Data 20939 , RW Data 53 , ZI Data 17028
Tatal RO size (Code+ RO Data) 184571 (180.25kB)
Tatal RW size(RW Data+ ZI Data) 17081(16.68 kB)
Tatal ROM size(Code+ RO Data+ RW Data) 184624(180.30 kB)
后面的字节数是根据用户不同的程序而来的,下面就以上面的数据为例来介绍那几个变量的计算。
在 ADS 的 Debug Settings 中有一栏是 Linker/ARM Linker ,在 output 选项中有一个 RO base 选项,下面应该有一个地址,我这里是 0x0c100000 ,后面的 RW base 地址是 0x0c200000 ,然后在 Options 选项中有 Image entry point ,是一个初始程序的入口地址,我这里是 0x0c100000 。
有了上面这些信息我们就可以完全知道这几个变量是怎么来的了:
|Image$$RO$$Base| = Image entry point = 0x0c100000 ; 表示程序代码存放的起始地址
|Image$$RO$$Limit|= 程序代码起始地址 + 代码长度 +1=0x0c100000+Tatal RO size+1
= 0x0c100000 + 184571 + 1 = 0x0c100000 +0x2D0FB + 1
= 0x0c12d0fc
|Image$$RW$$Base| = 0x0c200000 ; 由 RW base 地址指定
|Image$$RW$$Limit| =|Image$$RW$$Base|+ RW Data 53 = 0x0c200000+0x37 ( 4 的倍数,0 到55 ,共56 个单元)
=0x0c200037
|Image$$ZI$$Base| = |Image$$RW$$Limit| + 1 =0x0c200038
|Image$$ZI$$Limit| = |Image$$ZI$$Base| + ZI Data 17028
=0x0c200038 + 0x4284
=0x0c2042bc
也可以由此计算:
|Image$$ZI$$Limit| = |Image$$RW$$Base| +TatalRWsize(RWData+ZIData) 17081
=0x0c200000+0x42b9+3 (要满足 4 的倍数)
=0x0c2042bc