蜂鸟E203学习笔记(六)——交付

1.1 处理器中指令的交付、取消、冲刷

1.1.1 指令交付、取消和冲刷

影响指令交付的因素:

  • 中断、异常以及分支预测指令造成流水线冲刷
  • ARM中存在条件码,只会取消自己不会造成流水线冲刷

交付的位置

  • 执行阶段()完成分支预测之后
  • 写回阶段(有的指令需要多个周期才可以写回)
  • 重排序交付队列。对于高性能的超标量处理器指令往往乱序执行乱序写回,写回往往会使用ROB或者纯物理存储器。相应处理器往往会配备一个较深的重排序交付队列用来花村乱序执行的指令。

RISC-V没有条件码,也没有异常指令不用担心硬件实现上的异常。
只需要处理以下两种情形。

  • 分支预测指令错误预测造成的后续指令流消失
  • 中断和异常造成的后续指令流取消。

1.1.2 分支预测指令的处理

IFU中主要是处理以下几种带条件的跳转指令。

  • beq:若两个整数操作数相等则跳转。
  • bne:若两个整数不相等则跳转。
  • blt:若第一个有符号数小于第二个有符号数,则跳转
  • bltu:若第一个无符号数小于第二个无符号数,则跳转
  • bge
  • bgeu
    E203都使用了**静态预测,即向后跳转预测为跳转,向前跳转预测为不跳转。**是否真的跳转需要ALU计算得到。如果预测的结果和真实的结果相同则交付,否则会进行流水线冲刷。

1.1.3 多周期执行的指令的交付

交付在执行阶段可以完成,写回需要在后续的周期内写回

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

kelinnn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值