ARM技术论坛
直播中

郑成枝

7年用户 1273经验值
私信 关注
[问答]

关于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为例我来介绍一下情况,代码过几天补上,这几天开题,比较忙~
首先看一个经典的


上面形容的是程序加载到0x08000000的flash处,区间长度为0x10000,读写,初始化为0的数据放在0x200000000为首地址,区间长度为0x5000的sram处。

加入我们想要程序全部运行在sram里面怎么办呢

end

回帖(1)

刘波

2022-4-26 11:13:51
看看
举报

更多回帖

发帖
×
20
完善资料,
赚取积分