计算机组成原理 - 实验报告四(含答案)

更新时间:2023-09-14 22:09:01 阅读量: 资格考试认证 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

湖南科技学院

电子与信息工程学院

实验报告

课程名称: 姓名: 学号: 专业: 班级:

指导老师:

实验四微程序控制组成实验

一、实验目的及要求

1.将微程序控制器同执行部件(整个数据通路)联机,组成一台模型计算机。 2.用微程序控制器控制模型计算机的数据通路。

3.执行给定的简单程序,掌握机器指令与微指令的关系,牢固建立计算机的整机概念。

二、实验电路

本次实验将前面几个实验中的所模块,包括运算器、存储器、通用寄存器堆等同微程序控制器组合在一起,构成一台简单的模型机。这是最复杂的一个实验,也将是最有收获的一个实验。

在前面的实验中,实验者本身作为“控制器”,完成了对数据通路的控制。而在本次实验中,数据通路的控制将交由微程序控制器来完成。实验机器从内存中取出一条机器指令到执行指令结束的一个指令周期,是由微程序完成的,即一条机器指令对应一个微程序序列。

实验电路大致如下面框图所示。其中控制器是控制部件,数据通路是执行部件,时序发生器是时序部件。需使用导线将各个部件控制信号与控制器相连。

三、实验主要仪器设备

1. TEC-5计算机组成实验系统1台

2. 逻辑测试笔一支(在TEC-5实验台上)

四、实验任务

1. 对机器指令组成的简单程序进行译码。将下表的程序按机器指令格式手工汇编成二进制机器代码,

此项任务请在预习时完成。

内存地址 机器指令 30H 31H 32H 33H ADD R1, R2 OUT R1 STP 机器代码(二进制表示) LDA R1, [R0] 2. 完成实验连线。 3. 使用控制台命令将寄存器内容初始化为:R0=11H,R1=22H,R2=0AAH。

4. 使用控制台命令将任务1中的程序代码存入内存中(注意起始地址为30H),以及将内存地址为

11H的单元内容设置为0AAH。 5. 用单拍(DP)方式执行一遍程序,执行时注意观察各个指示灯的显示并做好记录(完成实验表格),

从而跟踪程序执行的详细过程(可观察到每一条微指令的执行过程)。 6. 用连续方式再次执行程序。这种情况相当于计算机正常的工作。程序执行到STP指令后自动停机。

读出寄存器中的运算结果,与理论值比较。

五、实验步骤和实验结果记录

1.程序译码。

内存地址 机器指令 30H 31H 32H 33H ADD R1, R2 OUT R1 STP 机器代码(二进制表示) 0000 1001 0111 01** 0110 **** LDA R1, [R0] 0100 0001

2.实验接线(本实验接线比较多,需仔细) 控制器 数据通路 LDIR PC+1 LDPC# AR+1 LDIR PC+1 LDPC# AR+1 SW_BUS# SW_BUS# LR/W# LR/W# 进位C 进位C IR3 RS1 TJ TJ Rs_BUS# Rs_BUS# M M IR6 IR6 IR1 RD1 LDAR# LDDR1 LDDR2 LDRi LDAR# LDDR1 LDDR2 LDRi CEL# CEL#

控制器 数据通路

控制器 数据通路

控制器 数据通路

数据通路 数据通路

控制器 时序电路

只要把上表种同列的信号用线连接即可,一共接线33条。 接好线后,将编程开关拨到“正常位置”。合上电源,按CLR#按钮,使TEC-5实验实验系统处于初始状态。

3.实验任务3:使用控制台命令将寄存器内容初始化为:R0=11H,R1=22H,R2=0AAH的操作步骤及结果记录。

(1)掌握写寄存器WRF的原理和步骤(详见实验参考资料)。 (2)操作过程如下:

IR2 RS0 IR0 RD0 IR1 WR1 IR0 WR0 IR7 IR7 IR5 IR5 IR4 IR4 Cn# Cn# S0 S0 S1 S1 S2 S2 S3 S3 ALU_BUS# RAM_BUS# CER# ALU_BUS# RAM_BUS# CER# 步骤 操作 各个信号灯的值 DBUS IBUS AR PC uA5~uA0 1 令DP=0,DB=0,使系统处于连续运行状态。令SWC=0,SWB=1,SWA=1,使系统处于00 写寄存器状态WRF。按CLR#按钮,使实验系统处于初始状态。 在SW7—SW0上设置一个存储器地址,例如可将该地址设置为0FFH。按一次QD按钮,将0FFH写入左端口地址寄存器AR。 在SW7—SW0上设置00H,作为通用寄存器R0的寄存器号。按一次QD按钮,将00H写入指令寄存器IR。 00 00 00 000000 2 FF 00 FF FF 001011 3 00 00 FF FF 001101 4 在SW7—SW0设置11H,按一次QD按钮,11 将11H写入IR指定的R0寄存器。 00 FF FF 001110 5 在SW7—SW0上设置01H,作为通用寄存器R1的寄存器号。按一次QD按钮,将01H写入指令寄存器IR。 00 01 FF FF 001101 6 在SW7—SW0设置22H,按一次QD按钮,22 将22H写入IR指定的R1寄存器。 00 FF FF 001110 7 在SW7—SW0上设置10H,作为通用寄存器R2的寄存器号。按一次QD按钮,将01H写入指令寄存器IR。 00 02 FF FF 001101 8 在SW7—SW0设置55H,按一次QD按钮,55 将55H写入IR指定的R2寄存器。 00 FF FF 001110 9 设置寄存器内容完毕。按CLR#按钮,使系统恢复到初始状态 00 00 FF FF 000000

注意:设置完R0、R1、R2的值后,最好用读寄存器控制台操作检查一下写入的内容是否正确(需注意读寄存器的选择控制信号为SW3和SW2,而非SW1和SW0!)。读寄存器内容的控制台操作见参考资料“实验箱(TEC-5)模型机的控制台操作开关SWC、SWB、SWA详解”。

4.实验任务4:使用控制台命令将任务1中的程序代码存入内存起址为30H的连续单元,以及将内存地址为11H的单元内容设置为0AAH。

(1)掌握写寄存器WRM的原理和步骤(详见实验参考资料)。 (2)操作过程如下: 步骤 操作 令DP=0,DB=0,使系统处于连续运行状态。令SWC=0,SWB=0,SWA=1,使系统处于写存储器状态WRM。按CLR#按钮,使实验系统处于初始状态。 在SW7—SW0上设置需要写入的存储器起始地址,本实验中应设置为30H。按一次QD按钮,将30H写入左端口地址寄存器AR。 在SW7—SW0上设置需要写入存储器的数据,此处为LDA R1,[R0];的程序代码。按一次QD按钮,将数据写入存储器中,同时AR+1。 在SW7—SW0上设置需要写入存储器的数据,此处为ADD R1,R2;的程序代码。按一次QD按钮,将数据写入存储器中,同时AR+1。 在SW7—SW0上设置需要写入存储器的数据,此处为OUT R1;的程序代码。按一次QD按钮,将数据写入存储器中,同时AR+1。 在SW7—SW0上设置需要写入存储器的数据,此处为STP;的程序代码。按一次QD按钮,将数据写入存储器中,同时AR+1。 按CLR#按钮,使实验系统处于初始状态。在SW7—SW0上设置需要写入的存储器地址11H。按一次QD按钮,将11H写入左端口地址寄存器AR。 在SW7—SW0上设置需要写入存储器的数据0AAH。按一次QD按钮,将0AAH—> (11H),同时AR+1。 各个信号灯及SW开关的值 DBUS AR SW7~SW0 uA5~uA0 1 00 ** ******** 000000 2 30 30 00110000 001001 3 00 31 01000001 000101 4 00 32 00001001 000101 5 00 33 011101** 000101 6 00 34 0110**** 000101 6 11 11 00010001 001001 7 00 12 10101010 000101 输入完毕,往存储器输入程序和数据结束,按CLR#按钮,使实验系统恢复到初始状态。

注意:设置完存储器的程序和数据后,最好用存储器器控制台操作检查一下写入的内容是否正确。读 存储器内容的控制台操作见实验参考资料。

5.实验任务5:用单拍(DP)方式执行一遍程序。

(1)置SWC=0,SWB=0,SWA=0,DP=1,DB=0,使实验系统处于单拍运行状态。

(2)置SW7—SW0=30H,使程序从地址30H开始执行。按CLR#按钮,使实验系统处于初始状态,然后按一次一次按QD按钮,使程序一拍一拍的执行。

结果记录如下: 按下QD 第一次 第二次 第三次 第四次 第五次 第六次 第七次 第八次 第九次 第十次 第十一次

执行结果 R0= 11H ,R1= FFH ,R2= 55H 。存储器11H单元的内容为 AAH 。 最后的执行结果可通过控制台的读寄存器操作和读存储器操作观察到,在观察最后结果之前,首先应按CLR#按钮,使实验系统处于初始状态。

6.实验任务6:用连续方式再次执行程序。

(1)由于上面的单拍执行程序,已破坏了寄存器R1的内容(其他寄存器和程序没有破坏),因此需要重新设置寄存器R1的初值:R1=22H。

(2)置SWC=0,SWB=0,SWA=0,DP=0,DB=0,使实验系统处于连续运行状态。

(3)置SW7—SW0=30H,使程序从地址30H开始执行。按CLR#按钮,使实验系统处于初始状态,然后按一次QD按钮,则程序自动连续运行到地址为33H的STP指令。 此步需经实验验收。

各个信号灯的值 uA5~uA0 DBUS 30H 00H 11H AAH 00H 00H FFH 00H FFH 00H 00H IBUS 00000000 01000001 00000000 00000000 00001001 00000000 00000000 011101** 00000000 0110**** 00000000 AR ** ** 11H 11H 11H 11H 11H 11H 11H 11H 11H PC 30H 30H 30H 31H 31H 31H 32H 32H 33H 33H 34H 对应完成的微操作 SW->DBUS->PC RAM->IBUS->IR RD->DBUS->AR RAM->DBUS->RS,PC+1 RAM->IBUS->IR RD->DR1,RS->DR2 ALU->DBUS->RD,PC+1 RAM->IBUS->IR RS->DBUS,PC+1,TJ RAM->IBUS->IR PC+1,TJ 08H 0FH 14H 1CH 0FH 10H 18H 0FH 17H 0FH 16H 六、实验小结及心得体会

本文来源:https://www.bwwdw.com/article/wi2h.html

Top