【五级流水线CPU】—— 7. 协处理器访问指令(2条)

本文介绍了MIPS32架构中CP0协处理器的设计与实现,重点关注了count、Compare、Status、Cause、EPC、PRId和Config这7个关键寄存器的功能。CP0与硬件中断如int_i、timer_int_o等交互,用于处理器计数、定时中断管理和处理器状态控制。文章还展示了如何通过mfc0指令读取Status寄存器的值。
摘要由CSDN通过智能技术生成

1. 协处理器CP0

image-20210620152036129

对于MIPS32架构的4个协处理器,只进行CP0的实现

CP0内部只实现比较有用的7个寄存器

  • count(Register9) :处理器计数周期
  • Compare(Register11):定时中断控制
  • Status(Register12):处理器状态和控制寄存器
  • Cause(Register13):保存上一次异常原因
  • EPC(Register14):保存上一次异常的程序计数器
  • PRId(Register15):处理器标志和版本
  • Config(Register16):配置寄存器,设置CPU的参数

2. CP0的实现

image-20210620153019343

  • int_i:6个外部硬件中断输入
  • count_o:Count寄存器的值
    ……
  • timer_int_o:是否有定时中断发生

image-20210620160753425

image-20210620170414567

CP0的连接类似HILO的处理

image-20210620170739756

image-20210620171659310

  • count每时钟周期加1
  • compare和status的结果
  • timer,定时器的中断
  • mfc0指令读取Status寄存器的值,存到$2,是0x10000401
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值