1、计算机组成原理课程设计汇报班级:09计算机04班 姓名: 学号:完成时间: 1月4日星期三 一、课程设计目标1在试验机上设计实现机器指令及对应微指令(微程序)并验证,从而深入掌握微程序设计控制器基础方法并了解指令系统和硬件结构对应关系;2经过控制器微程序设计,综合了解计算机组成原理课程关键知识并深入建立整机系统概念;3培养综合实践及独立分析、处理问题能力。二、课程设计任务针对COP试验仪,从具体了解该模型机指令/微指令系统入手,以实现乘法和除法运算功效为应用目标,在COP集成开发环境下,设计全新指令系统并编写对应微程序;以后编写实现乘法和除法程序进行设计验证。三、 课程设计使用设备(环境)1硬
2、件l COP试验仪l PC机2软件l COP仿真软件四、课程设计具体内容(步骤)1具体了解并掌握COP 模型机微程序控制器原理,经过综合试验来实现 总体概述COP模型机包含了一个标准CPU所含有全部部件,这些部件包含:运算器ALU、累加器A、工作寄存器W、左移门L、直通门D、右移门R、寄存器组R0-R3、程序计数器PC、地址寄存器MAR、堆栈寄存器ST、中止向量寄存器IA、输入端口IN、输出端口寄存器OUT、程序存放器EM、指令寄存器IR、微程序计数器uPC、微程序存放器uM,和中止控制电路、跳转控制电路。其中运算器和中止控制电路和跳转控制电路用CPLD来实现,其它电路全部是用离散数字电路组成
3、。微程序控制部分也能够用组合逻辑控制来替换。 模型机为8位机,数据总线、地址总线全部为8位,但其工作原理和16位机相同。相比而言8位机试验降低了烦琐连线,但其原理却更轻易被学生了解、吸收。模型机指令码为8位,依据指令类型不一样,能够有0到2个操作数。指令码最低两位用来选择R0-R3寄存器,在微程序控制方法中,用指令码做为微地址来寻址微程序存放器,找到实施该指令微程序。而在组合逻辑控制方法中,按时序用指令码产生对应控制位。在本模型机中,一条指令最多分四个状态周期,一个状态周期为一个时钟脉冲,每个状态周期产生不一样控制逻辑,实现模型机多种功效。模型机有24位控制位以控制寄存器输入、输出,选择运算器
4、运算功效,存放器读写。模型机缺省指令集分几大类: 算术运算指令、逻辑运算指令、移位指令、数据传输指令、跳转指令、中止返回指令、输入/输出指令。 模型机寻址方法表1 模型机寻址方法模型机寻址方法寻址方法说明指令举例指令说明累加器寻址操作数为累加器ACPL A将累加器A值取反隐含寻址累加器AOUT将累加器A值输出到输出端口寄存器OUT寄存器寻址参与运算数据在R0R3寄存器中ADD A,R0将寄存器R0值加上累加器A值,再存入累加器A中寄存器间接寻址参与运算数据在存放器EM中,数据地址在寄存器R0-R3中MOV A,R1将寄存器R1值作为地址,把存放器EM中该地址内容送入累加器A中存放器直接寻址参与
5、运算数据在存放器EM中,数据地址为指令操作数。AND A,40H将存放器EM中40H单元数据和累加器A值作逻辑和运算,结果存入累加器A立即数寻址参与运算数据为指令操作数。SUB A,#10H从累加器A中减去立即数10H,结果存入累加器A(2)该模型机微指令系统特点(包含其微指令格式说明等): 总体概述该模型机微命令是以直接表示法进行编码,其特点是操作控制字段中每一位代表一个微命令。这种方法优点是简单直观,其输出直接用于控制。缺点是微指令字较长,所以使控制存放器容量较大。 微指令格式说明模型机有24位控制位以控制寄存器输入、输出,选择运算器运算功效,存放器读写。微程序控制器由微程序给出24位控制
6、信号,而微程序地址又是由指令码提供,也就是说24位控制信号是由指令码确定。该模型机微指令长度为24位,其中微指令中只含有微命令字段,没有微地址字段。其中微命令字段采取直接按位表示法,哪位为0,表示选中该微操作,而微程序地址则由指令码指定。这24位操作控制信号功效如表2所表示:(按控制信号从左到右次序依次说明)表2 微指令控制信号功效操作控制信号控 制 信 号 说 明XRD外部设备读信号,当给出了外设地址后,输出此信号,从指定外设读数据。EMWR程序存放器EM写信号。EMRD程序存放器EM读信号。PCOE将程序计数器PC值送到地址总线ABUS上。EMEN将程序存放器EM和数据总线DBUS接通,由
7、EMWR和EMRD决定是将DBUS数据写到EM中,还是从EM读出数据送到DBUS。IREN将程序存放器EM读出数据打入指令寄存器IR和微指令计数器PC。EINT中止返回时清除中止响应和中止请求标志,便于下次中止。ELPPC打入许可,和指令寄存器IR3、IR2位结合,控制程序跳转。MAREN将数据总线DBUS上数据打入地址寄存器MAR。MAROE将地址寄存器MAR值送到地址总线ABUS上。OUTEN将数据总线DBUS上数据送到输出端口寄存器OUT里。STEN将数据总线DBUS上数据存入堆栈寄存器ST中。RRD读寄存器组R0R3,寄存器R?选择由指令最低两位决定。RWR写寄存器组R0R3,寄存器R
8、?选择由指令最低两位决定。CN决定运算器是否带进位移位,CN=1带进位,CN=0不带进位。FEN将标志位存入ALU内部标志寄存器。X2X2、X1、X0三位组合来译码选择将数据送到DBUS上寄存器。X1X0WEN将数据总线DBUS值打入工作寄存器W中。AEN将数据总线DBUS值打入累加器A中。S2S2、S1、S0三位组合决定ALU做何种运算。S1S0COP中有7个寄存器能够向数据总线输出数据, 但在某一特定时刻只能有一个寄存器输出数据. 由X2,X1,X0决定那一个寄存器输出数据。X2 X1 X0输出寄存器0 0 0IN_OE 外部输入门0 0 1IA_OE 中止向量0 1 0ST_OE 堆栈寄
9、存器0 1 1PC_OE PC寄存器1 0 0D_OE 直通门1 0 1R_OE 右移门1 1 0L_OE 左移门1 1 1没有输出COP中运算器由一片EPLD实现. 有8种运算, 经过S2,S1,S0来选择。运算数据由寄存器A及寄存器W给出, 运算结果输出到直通门D。S2 S1 S0功效0 0 0A+W 加0 0 1A-W 减0 1 0A|W 或0 1 1A&W 和1 0 0A+W+C 带进位加1 0 1A-W-C 带进位减1 1 0A A取反1 1 1A 输出A2。计算机中实现乘法和除法原理(1)无符号乘法(1)无符号乘法实例演示(即,列4位乘法具体例子演算算式):被乘数为1001(二进制
10、),即为十进制9;乘数为0110(二进制),即为十进制6。那么,能够经过笔算得到:10000111=00110110即十进制运算结果为:87=56 无符号乘法实例演示图1所表示: 1 0 0 0 ;被乘数 0 1 1 1 ;乘数 0 0 0 0 ;初始值(零) 1 0 0 0 (1) ;乘数最低位为1,部分积加被乘数,被乘数左;移一位,乘数右移一位。 1 0 0 0 ;部分积 1 0 0 0 (1) ;乘数最低位为1,部分积加被乘数,被乘数左;移一位,乘数右移一位。 1 1 0 0 0 ;部分积 1 0 0 0 (1) ;乘数最低位为1,部分积加被乘数,被乘数左;移一位,乘数右移一位。 1 1
11、 1 0 0 0 ;部分积 0 0 0 0 (0) ;乘数最低位为0,部分积加0,被乘数左移一;位,乘数右移一位。 (0) 0 1 1 1 0 0 0 ;计算完成,结果为00111000 即:10000111=00111000图1 无符号乘法实例演示硬件原理框图:图2 无符号乘法硬件原理框图在模型机上实现无符号数乘法运算时,采取“加法移位”反复运算方法。那么,无符号乘法硬件原理框图图2所表示。算法步骤图:在模型机上实现无符号数乘法运算时,采取“加法移位”反复运算方法。所以,无符号乘法算法步骤图图3所表示。(2)无符号除法实例演示(即,列4位除法具体例子演算算式):硬件原理框图:算法步骤图:3对
12、应于以上算法怎样分配使用COP试验仪中硬件(初步分配,设计完成后再将正确使用情况填写在此处)4在COP集成开发环境下设计全新指令/微指令系统设计结果如表所表示(可按需要增删表项)(1) 新指令集(设计两个不一样指令集要分别列表)助记符机器码1机器码2指令说明(2) 新微指令集助记符状态微地址微程序数据输出数据打入地址输出运算器移位控制mPCPC5用设计完成新指令集编写实现无符号二进制乘法、除法功效汇编语言程序(1)乘法4位乘法算法步骤图和汇编语言程序清单:(2)除法(选作) 4位除法算法步骤图和汇编语言程序清单:6上述程序运行情况(跟踪结果)按下表填写描述以上各程序运行情况内容。按每个程序一张表进行。程序运行过程汇 编 指 令程序地址机器码指令说明微程序PC mPC运行时寄存器或存放器值7设计结果说明调试运行程序时是否出现问题,是否有重新调整指令/微指令系统设计情况出现?请在此做具体说明。五、此次课程设计总结体会(不少于200字) 关键总结学到具体知识、方法及设计中切身体会;包含列出在设计各个阶段出现问题及处理方法。(以上红色字内容为由设计者完成并填写)
©2010-2024 宁波自信网络信息技术有限公司 版权所有
客服电话:4008-655-100 投诉/维权电话:4009-655-100