ARM芯片学习(S5PV210开发)——代码重定位

发布者:光速思考最新更新时间:2022-08-02 来源: csdn关键字:ARM芯片  代码重定位 手机看文章 扫描二维码
随时随地手机看文章

什么是代码重定位

代码重定位就是代码的复制或者说搬移,把在A地址存放的代码复制一份到B地址,至于A、B地址,程序员是事先知道的,可以通过芯片的数据手册查询得知。并且由于某些条件的限制,有时候不能直接将代码下载到B地址,只能先下载到A地址,然后运行代码,将代码复制到B地址接着运行。


为什么要代码重定位

重定位不是为了优化性能,而是由于硬件的限制,不得不进行重定位。试想一下,我们拿到一台设备,只要上电就可以运行代码,那代码必定要先保存在设备的存储介质中,并且是掉电不丢失的存储介质,具有掉电不丢失性质的存储介质有磁盘、flash等,但是这些都不能用作内存,内存都是RAM。这就矛盾了,内存是掉电丢失,必然不能用于存储代码,但是代码又必须在内存里运行。所以就只能先把代码下载到磁盘、flash等掉电不丢失的存储介质中,在启动后通过重定位将代码重定位到内存中。


代码重定位的相关概念

芯片的启动过程、位置有关码和位置无关码、链接地址和下载地址、链接脚本、程序段的概念、ldr和adr加载标号地址时的区别。

1.对SOC启动过程不熟悉的可以参考博客《S5PV210的启动过程详解》。

2.位置有关码和位置无关码可以参考博客《位置有关码和位置无关码》。

3.链接地址和下载地址可以参考博客《嵌入式开发中的链接地址、运行地址、加载地址、存储地址、实际运行地址的区别》。

4.ldr和adr加载标号地址时的区别可以参考博客《ARM伪指令常用知识点讲解》。


重定位步骤:

1.重定位的思路

在编译链接程序时,通过链接脚本指定链接地址,当下载地址和链接地址不相等时就要代码重定位。重定位思路就是通过先执行一段位置无关码,将代码复制一份到链接地址处,接着执行后续代码。


2.链接脚本

SECTIONS

{

. = 0xd0024000;

.text : {

start.o

* (.text)

}

   

.data : {

* (.data)

}

bss_start = .; 

.bss : {

* (.bss)

}

bss_end  = .;

}


汇编代码

/*

 * 文件名: led.s

 * 作者: 朱老师

 * 描述: 演示重定位(在SRAM内部重定位)

 */

 

#define WTCON 0xE2700000

#define SVC_STACK 0xd0037d80


.global _start // 把_start链接属性改为外部,这样其他文件就可以看见_start了

_start:

// 第1步:关看门狗(向WTCON的bit5写入0即可)

ldr r0, =WTCON

ldr r1, =0x0

str r1, [r0]

// 第2步:设置SVC栈

ldr sp, =SVC_STACK

// 第3步:开/关icache

mrc p15,0,r0,c1,c0,0; // 读出cp15的c1到r0中

//bic r0, r0, #(1<<12) // bit12 置0  关icache

orr r0, r0, #(1<<12) // bit12 置1  开icache

mcr p15,0,r0,c1,c0,0;

// 第4步:重定位

// adr指令用于加载_start当前运行地址

adr r0, _start  // adr加载时就叫短加载

// ldr指令用于加载_start的链接地址:0xd0024000

ldr r1, =_start // ldr加载时如果目标寄存器是pc就叫长跳转,如果目标寄存器是r1等就叫长加载

// bss段的起始地址

ldr r2, =bss_start // 就是我们重定位代码的结束地址,重定位只需重定位代码段和数据段即可

cmp r0, r1 // 比较_start的运行时地址和链接地址是否相等

beq clean_bss // 如果相等说明不需要重定位,所以跳过copy_loop,直接到clean_bss

// 如果不相等说明需要重定位,那么直接执行下面的copy_loop进行重定位

// 重定位完成后继续执行clean_bss。


// 用汇编来实现的一个while循环

copy_loop:

ldr r3, [r0], #4    // 源

str r3, [r1], #4 // 目的   这两句代码就完成了4个字节内容的拷贝

cmp r1, r2 // r1和r2都是用ldr加载的,都是链接地址,所以r1不断+4总能等于r2

bne copy_loop


// 清bss段,其实就是在链接地址处把bss段全部清零

clean_bss:

ldr r0, =bss_start

ldr r1, =bss_end

cmp r0, r1 // 如果r0等于r1,说明bss段为空,直接下去

beq run_on_dram // 清除bss完之后的地址

mov r2, #0

clear_loop:

str r2, [r0], #4 // 先将r2中的值放入r0所指向的内存地址(r0中的值作为内存地址),

cmp r0, r1 // 然后r0 = r0 + 4

bne clear_loop


run_on_dram:

// 长跳转到led_blink开始第二阶段

ldr pc, =led_blink // ldr指令实现长跳转

// 从这里之后就可以开始调用C程序了

//bl led_blink // bl指令实现短跳转

// 汇编最后的这个死循环不能丢

b .

关键字:ARM芯片  代码重定位 引用地址:ARM芯片学习(S5PV210开发)——代码重定位

上一篇:嵌入式开发(S5PV210)——ADC和触摸屏
下一篇:ARM芯片开发学习(S5PV210)——icache、dcache介绍和如何开关icache

推荐阅读最新更新时间:2024-11-12 11:05

tiny4412 裸机程序 七、定位代码到DRAM
一、关于DRAM 上一章我们讲解了如何对代码进行重定位,但是将代码重定位到只有256K IRAM中作用不大。 正确的做法是将代码重定位到容量更大的主存中,即DRAM。Exynos4412中有两个独立的DRAM控制器,分别叫DMC0和DMC1。DMC0和DMC1分别支持最大1.5G的DRAM,它们都支持DDR2/DDR3和LPDDR2等,512 Mb, 1 Gb, 2 Gb, 4 Gb and 8 Gbit的内存设备,支持16/32bit的位宽。DRAM0 对应的地址是0x4000_0000~0xAFFF_FFF共1.5GB,DRAM1 对应的地址是0xA000_000~0x0000_0000共1.5GB。 图7-1、DRAM
[单片机]
tiny4412 裸机程序 七、<font color='red'>重</font><font color='red'>定位</font><font color='red'>代码</font>到DRAM
孙正义:20年内ARM芯片年产量可达1万亿片
    软银集团股份有限公司(SoftBank Group Corp., 9984.TO)首席执行长孙正义(Masayoshi Son)周四表示,预计未来20年内ARM Holdings PLC (ARM.LN)芯片的年产量将达到1万亿片。此前软银宣布将收购这家英国芯片设计商。 孙正义在东京的一个软银活动上发表演讲时称,20年内,ARM架构将分布在全球各地的1万亿片芯片中,这些芯片用于迅速收集所有的实时数据。 孙正义表示,去年ARM芯片约150亿片,意味着全世界平均每个人拥有2片ARM芯片。 孙正义周四称,软银专注于三大领域:人工智能、智能机器人和“物联网”。 孙正义周四还宣布,软银和本田汽车(Honda Motor
[手机便携]
Intel 10nm代工 LG两款ARM芯片现身
苹果最新推出的A11芯片再次证明,只有自主把控芯片才能让设备发挥最大的价值。而除了苹果之外,三星,华为等也在研发自家的芯片,很多人对此可能并不陌生,但可能有些读者可能不曾了解的是,LG也拥有自家的芯片——NUCLUN,尽管最终以失败告终。 现据最新消息,LG似乎正在研发两款全新的处理器。 根据欧盟知识产权局的申请文件,LG提交了两份商标申请文件,分别是“LG KROMAX Processor" 和 "LG EPIK Processor”。LG称它们指的是“芯片 ,多处理器芯片”。 当然,目前还并没有充分的证据表明这两款芯片会运用于智能手机,它们也有可能用于物联网设备。 不过联系到去年Recode的报道,Intel证实他们将为LG
[半导体设计/制造]
S5PV210开发 -- 开发板配置
硬件电路设计部分其实本该现在讲的,但是一来时间有限,二来后面项目开发时会涉及。所以现在只简单的看一下。 硬件参数:
[单片机]
<font color='red'>S5PV210</font><font color='red'>开发</font> -- <font color='red'>开发</font>板配置
Cortex-A8开发板,选择S5PV210还是AM335X?
随着手机和平板等移动市场的持续火爆,ARM低功耗高效率内核技术越来越受重视,国内各大企业相继卷入移动平台,华为、联想、小米、魅族、阿里巴巴等,都已经和ARM有了深度的合作。 图1 据ARM中国代理商米尔科技统计,2009年,ARM在纳斯达克股票均价6.04美元,2013年,ARM纳斯达克股票均价已经升到了44.54美元,四年之间涨了将近八倍。 而作为ARM的一个关键转型产品,Cortex-A8备受瞩目,因其可在Android、Linux和WinCE系统之间切换,所以在手机、平板、工控三大领域得到了大量的应用。 接下来就Cortex-A8的发展过程做一个简要叙述,看看这个关键的过渡技术有怎样的历史。 Cortex-A8
[单片机]
Cortex-A8<font color='red'>开发</font>板,选择<font color='red'>S5PV210</font>还是AM335X?
S5PV210开发 -- USB 你知道多少?(一)
USB接口也是经常用到的,这一篇还是从它的基础知识讲起。 一、USB介绍 通用串行总线(英语:Universal Serial Bus,缩写:USB)是连接计算机系统与外部设备的一种串口总线标准,也是一种输入输出接口的技术规范,被广泛地应用于个人电脑和移动设备等信息通讯产品,并扩展至摄影器材、数字电视(机顶盒)、游戏机等其它相关领域。最新一代是USB 3.1,传输速度为10Gbit/s,三段式电压5V/12V/20V,最大供电100W ,新型Type C插型不再分正反。 二、USB版本
[单片机]
<font color='red'>S5PV210</font><font color='red'>开发</font> -- USB 你知道多少?(一)
除了海思麒麟 华为在ARM芯片上还有哪些成就?
    在麒麟950的发布会上,华为宣布用于服务器的自主芯片正在紧锣密鼓的研发中。其实,正在开发ARM服务器芯片的远远不止华为,国防科大、高通、AMD等IC设计单位或公司都已经设计出或正在设计ARM服务器芯片。   相对于ARM的32位指令集授权上的谨慎,ARM对其的64位指令集授权则显得非常大方,除了拉拢ARM阵营IC设计公司冲击服务器芯片市场外,也有ARM的64位指令集自身的原因。      其实,当初的ARM的64位指令和32位指令不是一回事,两者无法像MIPS64和MIPS32,X86 64和X86 32那样完全兼容。ARM的64位指令某种程度上是重新定义过的,在软件上与ARM 32位指令无法兼容,只有
[手机便携]
s3c2440代码定位和段的引入——学以致用,综合Makefile的锻炼
对于2440而言,nand启动,nand的前4k内容由硬件复制到sram。 nor flash,可以像内存一样读,但是不能像内存一样写,执行写操作需要特殊的操作。 程序中包含有需要写的全局或者静态变量,它们在bin文件中,写在nor flash上,直接修改这样的变量是无效的。 到底什么意思呢?还是看例子比较有说服力。 在学习C语言的过程中,我们或多或少知道一些东西,c/c++可执行文件需要预处理,编译,汇编,连接。 程序有text段,data段,bss段,rodata段等等,今天,就和它们来个亲密接触吧。 还是先说上面的问题吧,看例子: 在之前的程序代码基础上,启动代码增加自动识别是nand还是nor启
[单片机]
s3c2440<font color='red'>代码</font><font color='red'>重</font><font color='red'>定位</font>和段的引入——学以致用,综合Makefile的锻炼
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
  • 学习ARM开发(16)
    ARM有很多东西要学习,那么中断,就肯定是需要学习的东西。自从CPU引入中断以来,才真正地进入多任务系统工作,并且大大提高了工作效率。采 ...
  • 学习ARM开发(17)
    因为嵌入式系统里全部要使用中断的,那么我的S3C44B0怎么样中断流程呢?那我就需要了解整个流程了。要深入了解,最好的方法,就是去写程序 ...
  • 学习ARM开发(18)
    上一次已经了解ARM的中断处理过程,并且可以设置中断函数,那么它这样就可以工作了吗?答案是否定的。因为S3C44B0还有好几个寄存器是控制中 ...
  • 嵌入式系统调试仿真工具
    嵌入式硬件系统设计出来后就要进行调试,不管是硬件调试还是软件调试或者程序固化,都需要用到调试仿真工具。 随着处理器新品种、新 ...
  • 最近困扰在心中的一个小疑问终于解惑了~~
    最近在驱动方面一直在概念上不能很好的理解 有时候结合别人写的一点usb的例子能有点感觉,但是因为arm体系里面没有像单片机那样直接讲解引脚 ...
  • 学习ARM开发(1)
  • 学习ARM开发(2)
  • 学习ARM开发(4)
  • 学习ARM开发(6)
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved