该文是基于博主之前一篇博客http://www.cnblogs.com/wsine/p/4661147.html所增加的Cache,相同的内容就不重复写了,可点击链接查看之前的博客。

Cache结构

verilog简易实现CPU的Cache设计

采用的是2-way,循环5遍的测试方式,和书本上一致,4个set

Cache设计

首先在PCPU模块里面增加寄存器

verilog简易实现CPU的Cache设计

在流水线MEM那一阶段如果是STROE或者LOAD指令更新cache

verilog简易实现CPU的Cache设计

采取的替换策略是FIFO策略,在cache上面增加了一个位U

整个cache的控制部分如下:

verilog简易实现CPU的Cache设计
verilog简易实现CPU的Cache设计

如果读取时没有hit,则会成memory中取值并存到cache里面

verilog简易实现CPU的Cache设计
verilog简易实现CPU的Cache设计

书本和ppt上的样例,初始化了datamemory的值

仿真结果

从仿真器可以比较容易观察数据的变化,特别是hit0和hit1的变化

verilog简易实现CPU的Cache设计
verilog简易实现CPU的Cache设计
verilog简易实现CPU的Cache设计

从仿真文本来看,gr1和gr2的load结果也是成功的。没有出现不能错误读取的xxxx结果

传送门:

  • CPU2_Cache

点击这里

相关文章:

  • 2021-11-23
  • 2021-11-23
  • 2022-12-23
  • 2022-12-23
  • 2021-07-14
  • 2021-07-23
  • 2021-11-23
  • 2021-11-23
猜你喜欢
  • 2022-12-23
  • 2021-05-22
  • 2021-11-23
  • 2021-12-22
  • 2021-09-11
  • 2021-11-21
  • 2021-10-25
相关资源
相似解决方案