ARM代码重定位分析

关于位置有关码和无关码

前言

问题来源,NOR FLASH虽然可以XIP执行,但是像全局变量/静态全局变量这种需要进行修改的话,NOR FLASH便不是一个很好的方案,只能在RAM里面修改,代码以及常量在NOR里面读取,数据在RAM里面,首先我们讲一下相关概念

开始

1、位置有关码
当前的指令访问绝对物理位置,如:ldr pc ,#0X100000 mov pc , #0x10000
这里位置0x10000绝对固定
这样代码数据或者指令位置变动对代码有毁灭性的影响
2、位置无关码
当前指令访问相对位置,如 b [pc,#4],根据当前的相对位置来确定数据
3、运行地址
当前pc的地址
4、链接地址
makefile使用ld文件中内存分布描述地址情况
以STM32为例我来介绍一下情况,代码过几天补上,这几天开题,比较忙~
首先看一个经典的的

; *************************************************************
; *** Scatter-Loading Description File generated by uVision ***
; *************************************************************

LR_IROM1 0x08000000 0x00010000  {    ; load region size_region
  ER_IROM1 0x08000000 0x00010000  {  ; load address = execution address
   *.o (RESET, +First)
   *(InRoot$$Sections)
   .ANY (+RO)
  }
  RW_IRAM1 0x20000000 0x00005000  {  ; RW data
   .ANY (+RW +ZI)
  }
}

上面形容的是程序加载到0x08000000的flash处,区间长度为0x10000,读写,初始化为0的数据放在0x200000000为首地址,区间长度为0x5000的sram处。
加入我们想要程序全部运行在sram里面怎么办呢

end

修改链接文件,后面开完题再写吧,老师催了

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值