如何使用ALU,RAM,寄存器打造一个CPU 2

电子说

1.3w人已加入

描述

解码阶段

现在我们拿到了指令, 「前四位是操作码」 对应的是指令表中的LOAD A指令。对应的描述是**「将RAM的值放入寄存器A」**

「后四位1110是RAM的内存地址」 ,转成十进制就是14.

控制单元

指令通过”控制单元“进行 「解码」 。解码的作用就是判断这个操作码对应的操作是什么(通过少量的逻辑门即可判断)

针对不同的操作码有对应的指令判断威廉希尔官方网站 从而执行不同的操作。例如下面这个就是检查操作码是不是LOADA(0010)指令。

cpu

执行阶段

指令寄存器拿到数据DATA后通过控制单元进行解码,现在我们知道了这个是LOADA指令,就可以进行执行阶段了

  1. 「打开RAM允许读取线」 :我们将检查LOADA指令的威廉希尔官方网站 连接到RAM的READ ENBALE中( 「如果LOADA输输出为1那么READN ENANLE也是1因此就会打开RAM的允许读取线」 ),「并把地址14传入过去。」
  2. 「读取RAM 对应地址的值」 :RAM拿到地址14上的值,0000 0001也就是十进制的三
  3. 「RAM DATA线连接所有的寄存器」 :LOAD_A指令代表这个值存储在A寄存器中并不影响其他寄存器。因此需要将RAM读出来的值给到寄存器,所以**「RAM的DATA数据线需要将所有的寄存器都连接起来(DATA线既可以用来做输入又可以用来做输出使用)。」**
  4. 「打开指定寄存器的允许输入线」 :用检查“是否为LOADA指令的威廉希尔官方网站 ” 「打开寄存器A的允许写入线」 (因为是LOADA指令,所以需要将A寄存器的允许写入打开),这样就将RAM中地址为14的值输出保存到了寄存器A中。

cpu

  1. 「取下一条指令指令地址寄存器+1」 :执行阶段结束。开始下一个取指令阶段(读取0001的RAM地址到指令寄存器中,然后在解码执行........之后一直重复这个过程)

抽象--控制单元

上面解释的只是一个LOADA指令,「不同的指令由不同的逻辑威廉希尔官方网站 解码,这些逻辑威廉希尔官方网站 会配置CPU内的组件来执行对应操作。这些逻辑威廉希尔官方网站 太复杂我们可以把整个逻辑威廉希尔官方网站 封装为上面所说的控制单元。」

小结

也就是下图中的线路。可以看到控制单元 「链接了所有的寄存器」 (用于存放和读取数字),和RAM链接的是 「允许读取和允许输入线」 (READ ENABLE WRITE ENABLE),还有一条线是**「ADDRESS INPUT」** ,这条线是用来告知使用的是16个地址空间中的哪个地址(比如之前的14)

cpu

上面解释了指令表中的LOADA指令,LOADB指令和LOADA原理一致,包括STOREB也是只不过是相反过来 「打开寄存器的允许读取和RAM的允许写入传入地址最后将寄存器的值通过DATA线给到RAM对应地址」 。但是ADD指令有些不同,我们看下这个操作码是如何做处理的。

参考资料

[1]https://juejin.cn/post/7134166674160222221/:https://juejin.cn/post/7134166674160222221/

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分