【上海大学计算机组成原理实验报告】四、指令系统实验

news/2025/1/3 9:45:19/

一、实验目的

  1. 了解指令结构、PC寄存器的功能和指令系统的基本工作原理。

  2. 学习设计指令的方法。

二、实验原理

  1. 根据实验指导书的相关内容,对于部分使用频率很高,且只用几条微指令即可完成的简单操作,可以把这部分简单操作的微指令序列固定下来,存放在一个快速存储器中。之后我们就可以用不同的指令来调用不同的微程序,以达到完成不同指令的功能。

  2. 本实验所用的实验箱的指令系统中,每条指令均由4条微指令组成。当实际需要的微指令数量不足4条时,可用无效微指令FFFFFFH补足,但最后一条有效微指令一定是CBFFFFH微指令,表示本条指令执行完毕,取下一条指令。

  3. 指令系统的工作原理: 

    1. 指令获取:从存储器中获取下一条指令,通过地址总线传递给存储器。

    2. 指令解码:将获取的指令二进制通过指令总线传递给微程序计数器,高6位作为微程序入口地址,低2位分别作为SASB

    3. 微程序执行:根据微程序入口地址访问微程序存储器,将控制信号输出到控制总线,执行当前微指令功能。uPC1,输出下一条微指令,重复执行,直到“取下一条指令”微指令。

    4. 取下一条指令:PC1,开始执行下一条指令。

三、实验内容

实验任务一:分析并验证指令功能

观察机器指令码为66H的各微指令信号,验证该指令的功能。假设A=03HR2=77H77地址单元存放06H数据。

实验任务二:设计指令,完成相应功能

修改机器指令码为E8H的功能,使其完成“输出A+W的结果右移一位的值送OUT输出”操作。

**注意:**两个任务连起来做。

(1) 实验步骤

  1. 注释仪器,打开电源,手不要远离电源开关,随时准备关闭电源,注意各数码管、发光管的稳定性,静待10秒,确信仪器稳定、无焦糊味。

  2. 按Reset键初始化系统,并设置实验箱进入EM模式。设置Adr=00,按下NX,设置DB=66;而后按下NX,设置DB=E8;最后设置Adr=77,按下NX,设置DB=06

  3. 设置实验箱进入uEM模式。设置Adr=E8,按下NX,设置E8=FF DE B8H;而后按下NX,设置E9=CB FF FFH;最后按相同的方式将EAEB设置为FF FF FFH

  4. 设置实验箱进入uPC模式。设置uPC=00PC=00A=03;按NX三次,设置R2=77,按下STEP键,观察实验结果。

  5. 记录实验结果,关闭实验箱电源。

(2) 实验现象

  1. 第一次按下STEP键时,发现uPC显示64PC显示01

  2. 第二次按下STEP键时,发现uPc显示65MAR显示77

  3. 第三次按下STEP键时,发现uPC显示66W显示06

  4. 第四次按下STEP键时,发现uPC显示67A显示07

  5. 第五次按下STEP键时,发现uPC显示E8

  6. 第六次按下STEP键时,发现uPC显示E9OUT显示06

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

(3)实验结论

  1. 由第二次按下STEP键发现MAR显示77,可知指令码为66H的含义是将R2寄存器中的内容读出并写入MAR寄存器。

  2. 通过一系列正确的设计,我们成功地完成了“输出A+W的结果右移一位的值送OUT输出”操作功能的实现。

四、建议

  1. 在分析66H处的指令时,可以将其与例子中的指令进行比较观察在二进制格式下有哪些位不同。

  2. 在编制指令时,要确定好“A+W”运算、“右移一位”和“送OUT”输出分别对应微指令在二进制格式下的哪些位置。

五、体会

通过此次实验,加深了我对计算机体系结构中PC寄存器和指令系统的理解,同时也让我学会了如何设计指令,还让我能将理论知识应用到实际情景中,为进行下一次实验打下了扎实基础。

六、思考题

在微指令结构的计算机中,一条指令从启动到产生功能经过哪些环节?

  1. 指令获取。

  2. 指令解码。

  3. 微指令执行。

  4. uPC更新。

  5. 取下一条指令。


http://www.ppmy.cn/news/1434604.html

相关文章

扩散卷积模型 笔记

1 Title Diffusion Convolutional Neural Networks(James Atwood and Don Towsley)【NeurIPS 2016】 2 Conclusion This paper presents diffusion-convolutional neural networks (DCNNs), a new model for graph-structured data. Through the introd…

13个Java基础面试题

Hi,大家好,我是王二蛋。 金三银四求职季,特地为大家整理出13个 Java 基础面试题,希望能为正在准备或即将参与面试的小伙伴们提供些许帮助。 后续还会整理关于线程、IO、JUC等Java相关面试题,敬请各位持续关注。 这1…

python常见语法

变量赋值: my_var 10 基本数据类型: 整数(int)、浮点数(float)、字符串(str)、布尔值(bool)、列表(list)、元组(tuple&…

myql 获取二维数组字符串的最后一个值

继续《mysql 存储过程和函数》的实战: 要分离字符串:[["1","1007","1007012"],["5","5005"],["6","6002","6002005"],["7","7003"],["8&quo…

零基础入门学习Python第一阶10图形用户界面和游戏开发

图形用户界面和游戏开发 基于tkinter模块的GUI GUI是图形用户界面的缩写,图形化的用户界面对使用过计算机的人来说应该都不陌生,在此也无需进行赘述。Python默认的GUI开发模块是tkinter(在Python 3以前的版本中名为Tkinter)&…

Python-VBA函数之旅-getattr函数

目录 一、getattr函数的常见应用场景: 二、getattr函数使用注意事项: 1、getattr函数: 1-1、Python: 1-2、VBA: 2、推荐阅读: 个人主页:https://blog.csdn.net/ygb_1024?spm1010.21…

Linux进程详解三:进程状态

文章目录 进程状态Linux下的进程状态运行态-R阻塞态浅度休眠-S深度睡眠-D暂停状态-T暂停状态-t 终止态僵尸-Z死亡-X 孤儿进程 进程状态 进程的状态,本质上就是一个整型变量,在task_struct中的一个整型变量。 状态的存在决定了你的后续行为动作。 Linu…

【Linux】日志分析与管理

作为一个运维,如果不会看日志,就好比是冬天刚刚用热水泡完了脚,接着就立马让人把水喝掉。 目录 一、Inode介绍 1.1 什么是inode 1.2 inode表内容 1.3 查看inode号的方式 二、日志分析 2.1 日志的用途 2.2 日志的分类 2.3 日志级别 2…