计算机工作过程-取数指令
一些说明
M
:主存中某存储单元ACC, MQ, X, MAR, MDR,...
:相应寄存器M(MAR)
:取存储单元中的数据(ACC)...
:取相应寄存器中的数据- 指令:操作码+地址码
OP(IR)
:取操作码Ad(IR)
:取地址码
说明
取数指令:将指令地址码指示的存储单元中的操作数取出后送至运算器的ACC中
描述:
- 首先,从程序计数器(PC)里面取出欲执行的指令的地址传入地址寄存器(MAR);
- 然后根据地址寄存器(MAR)中存放的地址,去存储体中找到这条指令对应的存储单元;
- 把从存储体中取到的数据存放到数据寄存器(MDR)中,这个数据就是指令;
- 然后地址寄存器(MDR)把得到的指令传到指令寄存器(IR)
- 指令寄存器(IR)得到指令,取指令结束。
- 指令寄存器(IR)分析指令,将操作码传到控制单元(CU)
- 控制单元(CU)分析指令,然后发出各种微操作的命令序列,分析指令结束
- 指令寄存器(IR)分析指令,将地址码传到地址寄存器(MAR)
- 根据地址寄存器(MAR)中的数据,去存储体中找到对应的操作数
- 然后存储体将操作数传入数据寄存器(MDR)
- 然后地址寄存器(MAR)将得到的数据传送给累加器(ACC),执行取数指令结束
符号表示:
(PC)
-->MAR
M(MAR)
-->MDR
(MDR)
-->IR
- 取指令结束
OP(IR)
-->CU
- 分析指令结束
Ad(IR)
-->MAR
- M(MAR)
-->MDR
(MDR)
-->ACC
- 执行指令结束
相关问题
指令和数据以同等地位存储在存储器中,CPU如何区分指令和数据?
答:是通过指令周期的不同阶段来区分的。取指阶段:指令;取数阶段:数据
————————————————
版权声明:本文为CSDN博主「duganlx」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_40626497/article/details/105183452