zoukankan      html  css  js  c++  java
  • ARM IMPORT |Image$$RO$$Limit| 的含义

    http://blog.21ic.com/user1/4218/archives/2008/48399.html 
     
    IMPORT |Image$$RO$$Base| ; Base of ROM code
    IMPORT |Image$$RO$$Limit| ; End of ROM code (=start of ROM data)
    IMPORT |Image$$RW$$Base|   ; Base of RAM to initialise
    IMPORT |Image$$ZI$$Base|   ; Base and limit of area
    IMPORT |Image$$ZI$$Limit| ; to zero initialise

    IMPORT MMU_SetAsyncBusMode
    IMPORT MMU_SetFastBusMode ;

    IMPORT Main    ; The main entry of mon program

    ............

    对于刚学习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

  • 相关阅读:
    SpringBoot 之基础学习篇.
    Java 反射机制
    第二十二节,TensorFlow中的图片分类模型库slim的使用、数据集处理
    第二十一节,条件变分自编码
    第二十节,变分自编码
    第十九节,去噪自编码和栈式自编码
    使用webdriver+urllib爬取网页数据(模拟登陆,过验证码)
    第十八节,自编码网络介绍及代码实现
    第十七节,受限玻尔兹曼机网络及代码实现
    第二十二节,TensorFlow中RNN实现一些其它知识补充
  • 原文地址:https://www.cnblogs.com/nufangrensheng/p/3017918.html
Copyright © 2011-2022 走看看