您好,欢迎来到61ic! | [登录] [注册] 忘记密码 | 设为首页 帮助
 . 网站首页 . 业界新闻 . 设计中心 . 移动技术 . TI专栏 . ADI专栏 . FPGA专栏 . 代码工厂 . 官方商城 . 
 . 活动专区 . 新品快递 . 解决方案 . 前沿科技 . TI资源 . ADI资源 . FPGA资源 . 下载中心 . 产品展示 . 
加入收藏
付款方式
联系我们
您现在的位置: 61IC电子在线 >> 设计中心 >> 嵌入式系统 >> 正文
  [组图]ARM你必须知道的事儿——为啥“PC = PC + 8”?           ★★★ 【字体:
ARM你必须知道的事儿——为啥“PC = PC + 8”?
作者:61IC    文章来源:61IC    点击数:    更新时间:2015-5-15    

为啥是“PC = PC + 8”;

“PC = PC + 8”其实这样写容易让人蒙了。“PC = PC + 8”真正含义应该是:

执行处代码地址 = PC - 8;

也就是说,”PC指向的地址“领先“执行处代码地址”8个字节;

也就是说“PC = PC + 8”中的第二个PC,其实表示是“执行处代码地址”

然后,理解为啥是8?

首先,arm的地址宽度是4个字节,所以每执行一条指令,PC就会自加4.

而一条指令要完全被arm吸收,需要多个步骤,拿arm7举例它采用了3级流水线技术。

wps13E1.tmp

流水线,对于我们这种玩FPGA的再熟悉不过了,以3级流水线来说,就是把一件事情分成3个步骤,每个步骤同时处理,

前两个周期为潜伏期,无法出结果,之后结果会源源不断的输出。

 

想象一下,一条条指令,就像一个个等待加工的产品,奔跑在传送带上,而“FETCH”,“DECODE”,“EXECUTE”,就是3道加工工序。

wps1401.tmp

1、在第一个周期,PC指向第一条程序指令,进行取值(FETCH),DECODE,和EXECUTE步骤“扑空”

2、在第二个周期,接着PC + 4,PC指向第二条程序指令进行取值(FETCH),DECODE处理了在一个周期,FETCH到的指令,EXECUTE再次扑空。

3、在第三个周期,依然PC + 4,PC指向第三条程序指令进行取值(FETCH),DECODE处理了在二个周期,FETCH到的指令,

EXECUTE这时,处理在一个周期FETCH到的指令,这个指令同时也就是在第二个周期DECODE的指令。

4、之后每个时钟周期,EXECUTE都能处理到经过两次加工的code,不过PC始终领先于它,也就是:执行处代码地址 = PC - 8;

 

     而ARM9通过增加流水线级数,简化了流水线的各级逻辑,进一步提高了处理器的性能。采用5级流水线技术,但是同样是“PC = PC + 8”,

这是为什么呢?我们来看看图:

wps1402.tmp

我们发现EXECUTE仍然在第三个步骤,及符合:执行处代码地址 = PC - 8;只要理解这一点阅读代码也就够了。

文章录入:admin    责任编辑:admin 
  • 上一篇文章:

  • 下一篇文章: 没有了
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    最新热点 最新推荐 相关文章
    ARM常用汇编指令
    ARM-Linux一移植必杀技
    ARM处理器内核列表
    binutils工具集,软件开发利…
    基于ARM的微波频率自动测量系…
    基于ARM的Linux系统移植研究…
    关于ARM的22个常用概念介绍
    对ARM加载域和运行域的理解
    ARM-LINUX-2.6.36-LDD3-scul…
    ARM真的是扮演了Intel的“掘…
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    站长:61 湘ICP备13001086号-2