1、南 京 晓 庄 学 院信息工程学院计算机组成原理 课程实验报告实验名称: 基本模型机的设计与实现 年级专业班级:14 级 计算机 专业专本1班 班级学号: 14131521 姓名: 殷宇翔 学号: 姓名: 学号: 姓名: 时间: 2016 年 12 月 10 日一、 实验目的、要求:1、在掌握部件单元电路实验的基础上,进一步将其组成系统以构造一台基本模型实验计算机。 2、设计五条机器指令,并编写相应的微程序,具体上机调试,掌握整机软硬件组成概念。 二、实验仪器设备、器件及环境:仪器设备名称规格型号编号备注计算机组成原理系统DWCC-C8JH20112055三、实验方法、原理: 部件实验过程中,
2、各部件单元的控制信号是人为模拟产生的,而本次实验将能在微程序控制下自动产生各部件单元控制信号,实现特定指令的功能。这里,实验计算机数据通路的控制将由微程序控制器来完成,CPU从内存中取出一条机器指令到指令执行结束的一个指令周期全部由微指令组成的序列来完成,即一条机器指令对应一个微程序。 有关微控制器部分在前一实验中已详细介绍 主存储器的读、写和运行 为了向主存储器RAM中装入程序或数据,并且检查写入是否正确以及能运行主存储器中的程序,必须设计三个控制操作微程序。 存储器读操作:拨动总清开关后,置控制开关SWC、SWA为“0 0”时,按要求连线后,连续按“启动运行”开关,可对主存储器RAM连续手
3、动读操作。 存储器写操作:拨动总清开关后,置控制开关SWC、SWA为“0 1”时,按要求连线后,再按“启动运行”开关,可对主存储器RAM进行连续手动写入。 运行程序:拨动总清开关后,置控制开关SWC、SWA为“1 1”时,按要求连线后,再按“启动运行”开关,即可转入到第01号“取址”微指令,启动程序运行。 上述三条控制指令用两个开关SWC、SWA的状态来设置,其定义如下: SWCSWA控制台指令001011读内存写内存启动程序 指令寄存器介绍 指令寄存器用来保存当前正在执行的一条指令。当执行一条指令时,先把它从内存取到缓冲寄存器中,然后再传送到指令寄存器。指令划分为操作码和地址码字段,由二进制
4、构成,为了执行任何一条给定的指令,必须对操作码进行测试P(1),通过节拍脉冲T4的控制以便识别所要求的操作。“指令译码器”根据指令中的操作码进行译码,强置微控器单元的微地址,使下一条微指令指向相应的微程序首地址。 输入/输出设备 本系统有两种外部I/O设备,一种是二进制代码开关KD0KD7,它作为输入设备INPUT;另一种是数码显示块,它作为输出设备OUTPUT。例如:输入时,二进制开关数据直接经过三态门送到外部数据总线上,只要开关状态不变,输入的信息也不变。输出时,将输出数据送到外部数据总线上,当写信号(W/R)有效时,将数据打入输出锁存器,驱动数码块显示。 设计指令 根据基本模型机的硬件设
5、计五条机器指令:外设输入指令IN、二进制加法指令ADD、存数指令STA、输出到外设指令OUT、无条件转移指令JMP。指令格式如下: 助记符 机器指令码说明 IN 00000000 ;“外部开关量输入”KD0KD7的开关状态R0 ADD addr0001 0000 ;R0+addrR0 STA addr 0010 0000 ; R0addr OUT addr 00110000 ; addrBUS JMP addr 01000000 ; addrPC 说明: 指令IN为单字节指令,其余均为双字节指令, 为addr对应的主存储器二进制地址码。 基本模型机监控软件的设计 本模型机监控软件主要完成从输入
6、设备读入数据,进行简单算术运算后,将结果存入内存的某个单元,最后通过输出设备输出结果。 监控软件详细如下: 地址 内容 助记符 说明 00000000 00000000IN;“INPUTDEVICE”R0 00000001 00010000ADD0AH; R00AHR0 00000010 00001010 00000011 00100000STA0BH; R00BH 00000100 00001011 00000101 00110000OUT0BH; 0BHBUS 00000110 00001011 00000111 01000000JMP00H ; 00HPC 00001000 000000
7、00 00001001 00001010 00000001;自定义参加运算的数 00001011 ;求和结果存放单元 四、实验内容、步骤:(1)根据机器指令画出对应的微程序流程图 本实验的微程序流程见图3.7.2,当拟定“取指”微指令时,该微指令的判别测试字段为P(1)测试。由于“取指”微指令是所有微程序都使用的公用微指令,因此P(1)的测试结果出现多路分支。本机用指令寄存器的前4位I7I4作为测试条件,出现5路分支,占用5个固定微地址单元。 实验机控制操作为P(4)测试,它以控制开关SWC、SWA作为测试条件,出现了3路分支,占用3个固定微地址单元。当分支微地址单元固定后,剩下的其它地方就可
8、以一条微指令占用控存一个微地址单元随意填写。 注意:微程序流程图上的单元地址为16进制。 (2)根据微程序流程图设计微指令并转换成16进制代码文件。 当全部微程序设计完毕后,应将每条微指令代码化,即按微指令格式将图3.7.2微程序流程图转化成二进制微代码表,如表3.7.1所示,再转换成16进制代码文件。 运 行 微 程 序图 3.7.2 微程序流程图OUTPCAR0BPC+1RAMBUS0EBUSARRAMBUS0FBUSDR1DR1LED1501JMPPCAR0CPC+1RAMBUS16BUSPC01ADDPCAR09PC+1RAMBUS03BUSAR04RAMBUSBUSDR205RODR
9、106(DR1)+(DR2)01ROSWR008IN0101PCARPC+102RAMBUSBUSIRP(1)08STAPCAR0APC+1RAMBUS07BUSARROBUS0DBUSRAM01控 制器00十六进制微地址P(4)10(SWC SWA)KRD(00)RP(11)1301PCARPC+110RAMBUSBUSDR112DR1LED17KWE(01)DR1RAM18PCARPC+111(SW)BUSBUSDR114监控程序的16进制文件格式(文件名C8JHE1): 程序: P00 00 P01 10 P02 0AP03 20P04 0BP05 30P06 0BP07 40P08 0
10、0P0A 01微程序:M00 108105M01 82ED05M02 48C004M03 04E004M04 05B004M05 06A205M06 019A95M07 0DE004M08 011004M09 83ED05M0A 87ED05M0B 8EED05M0C 96ED05M0D 018206M0E 0FE004M0F 15A004M10 92ED05M11 94ED05M12 17A004M13 018005M14 182004M15 010A07M16 81D104M17 100A07M18 118A06表3.7.1 二进制微代码表微地址S3 S2 S1 S0 M CN WE B1
11、 B0ABCUA5UA0000 0 0 0 0 1 0 1 1 0 0 00 0 01 0 00 1 0 0 0 0010 0 0 0 0 1 0 1 1 1 1 01 1 01 1 00 0 0 0 1 0020 0 0 0 0 1 0 0 1 1 0 00 0 00 0 10 0 1 0 0 0030 0 0 0 0 1 0 0 1 1 1 00 0 00 0 00 0 0 1 0 0040 0 0 0 0 1 0 0 1 0 1 10 0 00 0 00 0 0 1 0 1050 0 0 0 0 1 0 1 1 0 1 00 0 10 0 00 0 0 1 1 0061 0 0 1 0
12、1 0 1 1 0 0 11 0 10 0 00 0 0 0 0 1070 0 0 0 0 1 0 0 1 1 1 00 0 00 0 00 0 1 1 0 1080 0 0 0 0 1 0 0 0 0 0 10 0 00 0 00 0 0 0 0 1090 0 0 0 0 1 0 1 1 1 1 01 1 01 1 00 0 0 0 1 10 A0 0 0 0 0 1 0 1 1 1 1 01 1 01 1 00 0 0 1 1 10B0 0 0 0 0 1 0 1 1 1 1 01 1 01 1 00 0 1 1 1 00C0 0 0 0 0 1 0 1 1 1 1 01 1 01 1 0
13、0 1 0 1 1 00D0 0 0 0 0 1 1 0 1 0 0 00 0 10 0 00 0 0 0 0 10E0 0 0 0 0 1 0 0 1 1 1 00 0 00 0 00 0 1 1 1 10F0 0 0 0 0 1 0 0 1 0 1 00 0 00 0 00 1 0 1 0 1100 0 0 0 0 1 0 1 1 1 1 01 1 01 1 00 1 0 0 1 0110 0 0 0 0 1 0 1 1 1 1 01 1 01 1 00 1 0 1 0 0120 0 0 0 0 1 0 0 1 0 1 00 0 00 0 00 1 0 1 1 1130 0 0 0 0 1
14、 0 1 1 0 0 00 0 00 0 00 0 0 0 0 1140 0 0 0 0 1 0 0 0 0 1 00 0 00 0 00 1 1 0 0 0150 0 0 0 0 1 1 1 0 0 0 01 0 10 0 00 0 0 0 0 1160 0 0 0 0 1 0 0 1 1 0 10 0 01 1 00 0 0 0 0 11 70 0 0 0 0 1 1 1 0 0 0 01 0 10 0 00 1 0 0 0 0180 0 0 0 0 1 1 0 1 0 0 01 0 10 0 00 1 0 0 0 1(3)读写程序 手动方法写微程序参看实验六。 手动方法写代码程序(机器指
15、令)步骤如下: 通过上一步将 机器指令对应的微代码正确地写入E2ROM 2816芯片后,再进行机器指令程序的装入和检查。 A. 将“编程开关”置“运行”位置,“运行控制”开关置“运行”位置,“运行方式”开关置“单步”位置。 B. 拨动总清开关(01),微地址寄存器清零,程序计数器清零。然后使控制开关SWC、SWA开关置为“0 1”,按动一次“启动运行”开关,微地址显示灯LUA0LUA5显示“010001”,再按动一次“启动运行”开关,微地址显示灯LUA0LUA5显示“010100”,此时数据开关的内容置为要写入的机器指令,再按动一次“启动运行”开关,即完成该条指令的写入。若仔细阅读微程序流程,
16、就不难发现,机器指令的首地址只要第一次给出即可,PC会自动加1,所以,每次按动“启动运行”开关,只有在微地址灯显示“010100”时,才设置内容,直到所有机器指令写完。 C. 写完程序后须进行检验。拨动总清开关(01)后,微地址清零,PC程序计数器清零,然后使控制开关SWC、SWA为“0 0”,按动“启动运行”开关,微地址灯将显示“010000”,再按“启动运行”开关,微地址灯显示为“010010”,第三次按“启动运行”开关,微地址灯显示为“010111”,此时总线数据显示灯LZD0LZD7显示为该首地址的内容,再按动一次“启动运行”开关,微地址灯显示为“010000”,2位数码管即显示RAM
17、中的程序。不断按动“启动运行”开关,可检查后续单元内容。 注意:每次仅在微地址灯显示为“010000”时,2位数码管显示的内容才是相应地址中的机器指令内容。 联机读/写微程序和机器指令 用联机软件的装载功能将16进制格式文件(文件名为C8JHE1)装入实验系统即可(详细操作见随机软件的README)。 (4)运行程序 单步运行程序 A. “编程开关”置“运行”状态,“运行方式”开关置为“单步”状态,“运行控制”开关置为“运行”状态。 B. 拨动总清开关(01),微地址清零,PC计数器清零,程序首地址为00H。 C. 按动“启动运行”开关,即单步运行一条微指令。对照微程序流程图,观察微地址显示灯
18、是否和流程一致。 连续运行程序 A. “编程开关”置“运行”状态,“运行方式”开关置为“连续”状态,“运行控制”开关置为“运行”状态。 B. 拨动总清开关,清微地址及PC计数器,按动“启动运行”开关,系统连续运行程序。如果要停止程序的运行,只需将“运行控制”开关置为“停止”状态,系统就停机。 C. 停机后,可检查存数单元0BH中的结果是否正确。 五、实验现象、结果:实验结果记录表:1234567输入指令INA80HAAA加法指令ADDBBAAABA传送指令STAABAA输出指令OUTBA无条件跳转指令JMPAA六、实验体会 这学期的学习后,让我对计算机的组成有了一个初步的认识,它的内部有很多的奥妙,理论性很强的。在这次课程设计中,我在实验设计中结合理论学了不少东西。因为课程设计是要求将以前在课堂上学的理论知识运用到实际的设计当中去,所以在设计过程中,我碰到各种各样的问题。为了解决这些问题,我仔细认真的去翻阅自己以前学过但是以为已经了解熟悉的东西。这在无形中帮助我加深对所学知识的了解及运用能力,并且让我明白什么地方是我们真正需要去关注的。尤其对运算器、存储器和微程序控制器,有了非常透彻的认识。并且对线路的连接与模型机的各个硬件的结构,以及微程序微指令的一些编制与设计有了一定的了解。