搜索
bottom↓
回复: 6

请教有关ARM寄存器R15存放偏移量计算的问题

[复制链接]

出0入0汤圆

发表于 2012-6-24 10:22:09 | 显示全部楼层 |阅读模式
程序计数器PC(R15):由于ARM采用流水线机制,PC值为当前指令地址值加8字节,ARM指令集中,PC指向当前指令的下两条指令的地址,由于ARM指令是字对齐的,PC值的bit0位和bit1位的值总为0,即PC值为4的倍数。

     当使用STR/STM指令保存R15时,保存的可能是当前指令地址加8字节或12字节,具体采用哪种方式取决于具体的芯片设计方式。同一芯片只能采用一种方式,如下代码可测试出芯片采用的地址偏移量:

      SUB R1, PC, #4            ;R1中存放下面STR指令的地址
      STR PC, [R0]                ;将PC=STR地址+offset保存到R0中
      LDR R0, [R0]                ;
      SUB R0, R0, R1            ;将offset=PC-STR地址保存到R0中  

在这个问题中,8字节和12字节是根据什么决定的?

阿莫论坛20周年了!感谢大家的支持与爱护!!

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……

出0入0汤圆

 楼主| 发表于 2012-6-25 06:01:59 | 显示全部楼层
自己up一下

出0入0汤圆

 楼主| 发表于 2012-6-25 06:05:39 | 显示全部楼层
由于采用流水线结构,pc中的值为当前执行指令的地址加上偏移量8个字节,这个很好理解,但是,在什么情况下会加12字节呢?有哪些芯片是加12字节呢?烦请熟悉的朋友指点一下

出0入0汤圆

 楼主| 发表于 2012-6-25 06:14:39 | 显示全部楼层
我是这么理解的,假设是顺序执行,没有跳转分支,本来pc的值是等于当前执行指令地址+8字节的地址,即指向当前指令的下2条指令地址。但是当使用STR/STM这个命令将PC的值保存到RAM或其他寄存器时,这个过程的实现在不同的芯片上有不同的设计,有的芯片实现这个功能时保留了原来的偏移量,即8个字节,但是有的芯片设计时出于某种结构上或性能上或其他方面的考虑,将原来的8个字节不得不改成了12个字节。所以导致了在使用STR/STM保存PC的值时出现了两种不同的偏移量。
我开始是将使用STR/STM保存时的偏移量与PC自己的偏移量弄混了。
以上是我的臆想,欢迎各位拍砖

出0入0汤圆

 楼主| 发表于 2012-6-25 06:24:38 | 显示全部楼层
      SUB R1, PC, #4            ;R1中存放下面STR指令的地址
      STR PC, [R0]                ;将PC=STR地址+offset保存到R0中
      LDR R0, [R0]                ;
      SUB R0, R0, R1            ;将offset=PC-STR地址保存到R0中  

由此来说,测试使用STR/STM的偏移量的过程应该是这样的:
(1)首先将PC的值减4,即执行SUB R1,PC,#4时,PC应该指向当前地址的下2条地址,也就是指向了LDR R0,[R0],但是PC-4后就指向了STR PC,[R0]这个地址;
(2)将PC中的地址值,使用STR这个命令保存到R0寄存器中存放的那个值指向的地址中去,注意,此时的保存起来的这个值就是不确定的那个值,要么是当前的PC值+8,要么是当前的PC+12,谁让使用了STR了呢。
(3)将这个值取回放进R0寄存器里,为了下一步的减法计算用;
(4)用R0中的值减去R1中的值就是那个不确定的偏移量的值,然后再给他保存在R0中,谁爱用谁去用。

出0入0汤圆

发表于 2012-6-28 18:57:24 | 显示全部楼层
winterw 发表于 2012-6-25 06:24
SUB R1, PC, #4            ;R1中存放下面STR指令的地址
      STR PC, [R0]                ;将PC=S ...

   看蒙了。。。。

出0入0汤圆

发表于 2012-7-6 13:36:42 | 显示全部楼层
本帖最后由 s200661524 于 2012-7-6 13:37 编辑

加多少字节不是芯片制造厂说得算,是arm公司设计内核的时候规定的,另外你所说的保存pc指针是在异常返回的时候才需要考虑调整pc值的,函数调用等等不需要,直接mov pc,lr,关于加减8或者12就那么几种,数据终止加12,要看为什么就去arm公司下载文档研究吧

加几个字节跟具体芯片无关,大家都一样
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-8-26 13:13

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表