zhangcc530 2018-09-19 15:16 采纳率: 50%
浏览 456
已采纳

ARM的启动代码,为什么会存在位置相关码,求解?

ResetHandler
ldr r0,=WTCON ;watch dog disable
ldr r1,=0x0
str r1,[r0]
ldr r0,=INTMSK

以上代码是复位后,开始执行的,ldr r0,=WTCON 和 ldr r0,=INTMSK,都使用的ldr的伪指令,应该是属于位置相关码,下图贴出了反汇编的代码,一个链接地址0,另一个链接地址0X30000000,可以看到ldr r0,=INTMSK这条指令被反汇编成为位置相关码的指令,取0x33f802b4的地址,现在复位阶段,PC指向0开始的啊,这对吗?哪里有问题?![![图片说明](https://img-ask.csdn.net/upload/201809/19/1537369946_818235.png)图片说明](https://img-ask.csdn.net/upload/201809/19/1537369939_375447.png)图片说明

  • 写回答

1条回答 默认 最新

  • dabocaiqq 2018-09-19 16:22
    关注
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名
  • ¥65 汇编语言除法溢出问题