微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > ARM指令定址问题

ARM指令定址问题

时间:11-11 来源:互联网 点击:
AREA BOOTCODE, CODE, READONLY

ENTRY
BootloAd
LDRr0, =0x00
LDRr1, =0x00
LDRr2, =0x00
LDRr3, =0x00
END

1)在ARM程序里,如何指定指令在ROM中存放的位置(类似单片机的ORG伪指令)
我想不管哪款ARM芯片,肯定都有上电复位地址,也就是上电后PC指向的位置。比如某款ARM芯片复位地址为0x00000000,复位后我希望执行的第一条指令是LDR R0, =0x00。那么在程序里我们怎么指定将该条指令放在ROM的0x00位置呢?

2)ENTRY伪指令的作用
ENTRY伪指令是程序的入口,一个程序只能有一个ENTRY,在生成ELF格式的IMAGE文件时,它能够告诉仿真器从哪条指令开始执行程序,但是在生成BIN文件时,它又有什么用呢??我们希望将ENTRY下面的那条指令烧录到ARM芯片的上电复位地址处,每款芯片的复位地址都可能不同,ADS如何能通过ENTRY就知道实际芯片的复位地址在哪里?

3)ARMLINKER配置时RO BASE的作用
我在ARMLINKER的配置页里将RO BASE设置为0x3000,通过用AXD装载生成的AXF文件仿真,观察发现,LDRr0, =0x00这条指令被放在存储器的0x3000位置,这似乎说明通过设置RO BASE可以设置程序在ROM中的起始位置。但我看同时生成的BIN文件,只有16个字节,那如果用烧录器烧芯片时,烧录器如何知道BIN文件的第一个字节要放在ROM的0x3000位置呢?(不通过填写烧录软件里的烧录起始地址为0x3000)

VECTORS。S是在ADS中设定的: vector.s中"section"=STARTUP为首运行。

类似的。 复位后是中断向量表。第一个是复位向量,在那里
放一个跳转。(一般才几个字节大小,只能放跳转了)
跳转到:
1。初始化的代码处。InitStAck 初始化堆栈。。。
2。C 的 _MAIN 地址,运行 MAIN()

vector.s应该是自己写的ARM汇编,不是每个项目都会有vector.s文件的吧?
另外,就算在section指定了STARTUP为首运行,怎么将该条指令和硬件的复位地址对上呢?

是这样的:
CODE32
AREAStArtup,CODE,READONLY

ENTRY
;//中断向量表每个宽 4个字节。只能放一条32位的ARM指令
Vectors;BASE+0
LDRPC, ResetAddr;复位的第一条。跳到标号;ResetAddr
LDRPC, UndefinedAddr ;32位的ARM指令。 BASE+1
LDRPC, SWI_Addr;32位的ARM指令。 BASE+2
LDRPC, PrefetchAddr
LDRPC, DAtAAbortAddr
DCD0xb9205f80
LDRPC,[PC, #-0xff0]
LDRPC,FIQ_Addr
...

ResetAddr:
BLInitStAck
B_MAIN
跳转到:
1。初始化的代码处。InitStAck 初始化堆栈。。。
2。C 的 _MAIN 地址,运行 MAIN()

假设我的工程中 vector.s是初始化文件。
其主要内容为:
CODE32
AREAStArtup,CODE,READONLY

ENTRY
;//中断向量表每个宽 4个字节。只能放一条32位的ARM指令。
Vectors;BASE+0
LDRPC, ResetAddr;复位的第一条。跳到标号;ResetAddr
LDRPC, UndefinedAddr ;32位的ARM指令。 BASE+1
LDRPC, SWI_Addr;32位的ARM指令。 BASE+2
LDRPC, PrefetchAddr
LDRPC, DAtAAbortAddr
DCD0xb9205f80
LDRPC,[PC, #-0xff0]
LDRPC,FIQ_Addr
...

ResetAddr:
BLInitStAck
B_MAIN
;=======================================

所以需要在ADS中设定
object/symbol: vector.o,"section"=STARTUP为首运行。
;=======================================

上电复位后,程序从entry处进入。
则第一条指令就是:LDRPC, ResetAddr
那么PC指针跳转到ReseAddr标号处。
你可以在这里实现初始化功能。

答6:

竟然不能重编辑。。。今晚刚看了44b0 的 bootloAder程序。
有不对的地方希望各位指正。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top