姓名: 学号: 班级:计科班
实验名称:CPU与简单模型机 实验性质:综合型实验 时间:2018.12.1
(1) 掌握一个简单 CPU 的组成原理。
(2) 在掌握部件单元电路的基础上,进一步将其构造一台基本模型计算机。
(3) 为其定义五条机器指令,编写相应的微程序,并上机调试掌握整机概念。
本实验要实现一个简单的 CPU,并且在此 CPU 的基础上,继续构建一个简单的模型计算机。CPU 由运算器(ALU)、微程序控制器(MC)、通用寄存器(R0),指令寄存器(IR)、程序计数器(PC)和地址寄存器(AR)组成,
除了程序计数器(PC),其余部件在前面的实验中都已用到,在此不再讨论。系统的程序计数器(PC)和地址寄存器(AR)集成在一片 CPLD 芯片中 。CLR
连接至 CON 单元的总清端CLR,按下 CLR 按钮,将使 PC 清零,LDPC
和 T3 相与后作为计数器的计数时钟,当 LOAD为低时,计数时钟到来后将 CPU 内总线上的数据打入 PC。
本模型机和前面微程序控制器实验相比,新增加一条跳转指令 JMP,共有五条指令:IN(输入)、ADD(二进制加法)、OUT(输出)、JMP(无条件转移),HLT(停机),其指令格式如下(高4位为操作码):
其中 JMP 为双字节指令,其余均为单字节指令,********为 addr 对应的二进制地址码。微程序控制器实验的指令是通过手动给出的,现在要求 CPU
自动从存储器读取指令并执行。根据以上要求,设计数据通路图,如图 5-1-3 所示。
本实验在前一个实验的基础上增加了三个部件,一是 PC(程序计数器),另一个是 AR(地址寄存器),还有就是 MEM(主存)。因而在微指令中应增加相应的控制位
系统涉及到的微程序流程见图 5-1-4 所示,当拟定“取指”微指令时,该微指令的判别测试字段为
P<1>测试。指令译码原理见图 3-2-3 所示,由于“取指”微指令是所有微程序都使用的公用微指令,因此 P<1> 的测试结果出现多路分支。本机用指令寄存器的高 6 位(IR7—IR2)作为测试条件,出现5路分支,占用5个固定微地址单元,剩下的其它地方就可以一条微指令占用控存一个微地址单元随意填写,微程序流程图上的单元地址为 16 进制。
当全部微程序设计完毕后,应将每条微指令代码化,表 5-1-2 即为将图 5-1-4 的微程序流程图按微指令格式转化而成的“二进制微代码表”。
设计一段机器程序,要求从 IN 单元读入一个数据,存于 R0,将
R0 和自身相加,结果存于 R0,再将 R0 的值送 OUT 单元显示。
根据要求可以得到如下程序,地址和内容均为二进制数。
按图 5-1-5 连接实验线路。
写入实验程序,并进行校验,分两种方式,手动写入和联机写入。
(1) 手动写入微程序
① 将时序与操作台单元的开关 KK1 置为‘停止’档,KK3 置为‘编程’档,KK4 置为‘控
存’档,KK5 置为‘置数’档。
② 使用 CON 单元的 SD05——SD00 给出微地址,IN
单元给出低 8 位应写入的数据,连续两次按动时序与操作台的开关
ST,将 IN 单元的数据写到该单元的低 8 位。
③ 将时序与操作台单元的开关 KK5 置为‘加 1’档。
④ IN 单元给出中
8 位应写入的数据,连续两次按动时序与操作台的开关 ST,将
IN 单元的数据写到该单元的中 8 位。IN 单元给出高 8 位应写入的数据,连续两次按动时序与操作台的开关 ST,将 IN 单元的数据写到该单元的高 8 位。
⑤ 重复①、②、③、④四步,将表 5-1-2 的微代码写入 2816 芯片中。
(2) 手动校验微程序
① 将时序与操作台单元的开关 KK1 置为‘停止’档,KK3 置为‘校验’档,KK4 置为‘控
存’档,KK5 置为‘置数’档。
② 使用 CON 单元的 SD05——SD00 给出微地址,连续两次按动时序与操作台的开关 ST,
MC 单元的指数据指示灯 M7——M0 显示该单元的低 8 位。
③ 将时序与操作台单元的开关 KK5 置为‘加 1’档。
④ 连续两次按动时序与操作台的开关 ST,MC 单元的指数据指示灯 M15——M8
显示该单元的中 8 位,MC 单元的指数据指示灯 M23——M16 显示该单元的高 8 位。
⑤ 重复①、②、③、④四步,完成对微代码的校验。如果校验出微代码写入错误,重新写
入、校验,直至确认微指令的输入无误为止。
(3) 手动写入机器程序
① 将时序与操作台单元的开关 KK1 置为‘停止’档,KK3 置为‘编程’档,KK4 置为‘主
存’档,KK5 置为‘置数’档。
② 使用 CON 单元的 SD07——SD00 给出地址,IN 单元给出该单元应写入的数据,连续两次按动时序与操作台的开关 ST,将 IN 单元的数据写到该存储器单元。
③ 将时序与操作台单元的开关 KK5 置为‘加 1’档。
④ IN 单元给出下一地址(地址自动加 1)应写入的数据,连续两次按动时序与操作台的开关 ST,将 IN 单元的数据写到该单元中。然后地址会又自加 1,只需在 IN 单元输入后续地址的数据,连续两次按动时序与操作台的开关 ST,即可完成对该单元的写入。
⑤ 亦可重复①、②两步,将所有机器指令写入主存芯片中。
(4) 手动校验机器程序
①将时序与操作台单元的开关 KK1 置为‘停止’档,KK3 置为‘校验’档,KK4 置为‘主
存’档,KK5 置为‘置数’档。
② 使用 CON 单元的 SD07——SD00 给出地址,连续两次按动时序与操作台的开关 ST,CPU内总线的指数据指示灯 D7——D0 显示该单元的数据。
③ 将时序与操作台单元的开关 KK5 置为‘加 1’档。
④ 连续两次按动时序与操作台的开关 ST,地址自动加 1,CPU 内总线的指数据指示灯 D7
——D0 显示该单元的数据。此后每两次按动时序与操作台的开关 ST,地址自动加 1,CPU 内总线的指数据指示灯 D7——D0 显示该单元的数据,继续进行该操作,直至完成校验,如发现错误,则返回写入,然后校验,直至确认输入的所有指令准确无误。
⑤ 亦可重复①、②两步,完成对指令码的校验。如果校验出指令码写入错误,重新写入、
校验,直至确认指令码的输入无误为止。
联机软件提供了微程序和机器程序下载功能,以代替手动读写微程序和机器程序,但是微
程序和机器程序得以指定的格式写入到以TXT为后缀的文件中,微程序和机器程序的格式如下:
选择联机软件的“【转储】—【装载】”功能,在打开文件对话框中选择上面所保存的文件,软件自动将机器程序和微程序写入指定单元。
选择联机软件的“【转储】—【刷新指令区】”可以读出下位机所有的机器指令和微指令,
并在指令区显示,对照文件检查微程序和机器程序是否正确,如果不正确,则说明写入操作失败,应重新写入,可以通过联机软件单独修改某个单元的指令,以修改微指令为例,先用鼠标左键单击指令区的‘微存’TAB 按钮,然后再单击需修改单元的数据,此时该单元变为编辑框,输入 6 位数据并回车,编辑框消失,并以红色显示写入的数据。
方法一:本机运行
将时序与操作台单元的开关 KK1、KK3 置为‘运行’档,按动 CON 单元的总清按钮 CLR,将使程序计数器 PC、地址寄存器 AR 和微程序地址为 00H,程序可以从头开始运行,暂存器 A、B,指令寄存器 IR 和 OUT 单元也会被清零。
将时序与操作台单元的开关 KK2 置为‘单步’档,每按动一次 ST 按钮,即可单步运行一
条微指令,对照微程序流程图,观察微地址显示灯是否和流程一致。每运行完一条微指令,观测一次 CPU 内总线和地址总线,对照数据通路图,分析总线上的数据是否正确。
当模型机执行完 JMP 指令后,检查 OUT 单元显示的数是否为 IN 单元值的 2 倍,按下 CON单元的总清按钮
CLR,改变 IN 单元的值,再次执行机器程序,从 OUT 单元显示的数判别程序执行是否正确。
方法二:联机运行
将时序与操作台单元的开关 KK1 和 KK3 置为‘运行’档,进入软件界面,选择菜单命令“【实验】—【简单模型机】”,打开简单模型机数据通路图。
按动 CON 单元的总清按钮 CLR,然后通过软件运行程序,选择相应的功能命令,即可联机
运行、监控、调试程序,当模型机执行完 JMP 指令后,检查 OUT 单元显示的数是否为 IN 单元值的 2 倍。在数据通路图和微程序流中观测指令的执行过程,并观测软件中地址总线、数据总线以及微指令显示和下位机是否一致。
本次实验程序如下,程序中分号‘;’为注释符,分号后面的内容在下载时将被忽略掉:
; //*************************************** //
; // //
; // CPU 与简单模型机实验指令文件 //
; // //
; // By TangDu CO.,LTD //
; // //
; //*************************************** //
; //****** Start Of Main Memory Data ****** //
$P 00 20 ; START: IN R0 从 IN 单元读入数据送 R0
$P 01 00 ; ADD R0,R0 R0 和自身相加,结果送 R0
$P 02 30 ; OUT R0 R0 的值送 OUT 单元显示
$P 03 E0 ; JMP START 跳转至 00H 地址
$P 04 00 ;
$P 05 50 ; HLT 停机
; //******* End Of Main Memory Data ******* //
; //**** Start Of MicroController Data **** //
$M 00 000001 ; NOP
$M 01 006D43 ; PC->AR,PC 加 1
$M 03 107070 ; MEM->IR, P<1>
在本次实验过程中开始的步骤是重复以前的实验过程。我的实验线路也再次出现了问题,经过检查,发现是接线有问题,总是犯错误。这次实验让我更加了解了微程序以及CPU。CPU需要运算器、微程序控制器、通用寄存器、指令寄存器、程序计数器、地址寄存器组成。在这个过程中程序计数器决定下一.条执行的指令是什么。整体感觉这次的实验较为有效的帮助我们理解,但是感觉还是需要好好的看书。