《计算机组成原理课程设计设计基本模型机的指令系统.doc》由会员分享,可在线阅读,更多相关《计算机组成原理课程设计设计基本模型机的指令系统.doc(19页珍藏版)》请在三一办公上搜索。
1、课程设计说明书题目: 计算机组成原理课程设计 院 系: 计算机科学与工程学院 专业班级: 计算机08-6 学 号: 2008302974 学生姓名: 指导教师: 2010年 12 月 11 日 安徽理工大学课程设计(论文)任务书 计算机科学与工程 院系 硬件 教研室学 号2008302974学生姓名专业(班级)计算机08-6设计题目设计基本模型机的指令系统实现异或设计技术参数计算机组成原理教学实验仪一台,排线若干;PC机一台DJ-CPT816组成原理实验软件模型机的指令系统,微程序,微指令,程序设计要求设计基本模型机的指令系统(包括逻辑与,逻辑或,算术加,减运算,输入,输出,转移,传送指令)在
2、已编写的指令系统上设计程序实现异或按时提交设计报告工作量 论文不少于15页,附带必要的图表工作计划设计课一:分析设计要求,制定设计计划,完成指令系统设计,并在CPTH实验软件中形成.mic文件设计课二:分析设计编写程序实现异或设计课三:在微机和试验仪的支持下,调入指令系统和程序,运行,测试,完成系统的设计设计课四:提交设计报告参考资料1李敬兆. 8086/8088和基于ARM核汇编语言程序设计 2清华大学出版社.计算机组成原理与设计实验指导3白中英.计算机组成原理指导教师签字教研室主任签字 2010年 12月 11 日 指导教师评语:成绩: 指导教师: 年 月 日安徽理工大学课程设计(论文)成
3、绩评定表摘要在飞速发展的科技社会中,计算机被应用到各行各业,各个领域中。人们渐渐地步入自动化、智能化的生活阶段。本次计算机组成原理课程设计课题是基本模型机的设计与实现。利用CPU与简单模型机来实现计算机组成原理课程及实验中所学到的实验原理和编程思想,硬件设备自拟,编写指令的应用程序,用微程序控制器实现了一系列的指令功能,最终达到将理论与实践相联系。本次设计完成了各指令的格式以及编码的设计,实现了各机器指令微代码,设计基本模型机的指令系统(包括逻辑与,逻辑或,算术加,减运算,输入,输出,转移,传送指令),形成具有一定功能的完整的应用程序。简言之,这次设计,计算机数据通路的控制将由微程序控制器来完
4、成,CPU从内存中取出一条机器指令到指令执行结束的一个指令周期,全部由微指令组成的序列来完成,即一条机器指令对应一条微程序,一条微程序又有若干微指令组成,一条微指令的功能由24位操作信号(即控制位)实现。这一课题的实现不仅使我们对各种微指令有了熟练的掌握,更对有关知识的深入学习打下基础。关键词:指令系统,微指令,机器指令,异或目录1系统分析11.1 设计背景11.2 设计目标32系统设计42.1 模型机的指令设计42.2 模型机的微指令设计52.3 异或程序设计103系统实现123.1 程序编写123.2 程序分析123.3 调试结果134总结144.1 设计体会144.2 系统改进14参考文
5、献151.系统分析1.1 设计背景通过计算机组成原理理论课和几次实验的学习,尝试设计八类机器指令,并编写相应的微程序,完成由基本单元电路构成一台基本模型机,再经过调试指令和模型机使其在微程序的控制下自动产生各部件单元的正常工作控制信号。本课程设计的模型机的指令码为8位,根据指令类型的不同,可以有0到2个操作数,指令码的最低两位用来选择R0-R3寄存器。在微程序控制方式下,用指令码作为微地址来寻址微程序存储器,找到执行该指令的微程序。在本模型机中,一条指令最多分为四个状态周期,一个状态周期为一个时钟脉冲,每个状态周期产生不同的控制逻辑,实现模型机的各种功能。模型机有24位控制位以控制寄存器的输入
6、输出,选择运算器的运算功能,存储器的读写。简言之,这次设计,计算机数据通路的控制将由微程序控制器来完成,CPU从内存中取出一条机器指令到指令执行结束的一个指令周期,全部由微指令组成的序列来完成,即一条机器指令对应一条微程序,一条微程序又有若干微指令组成,一条微指令的功能由24位操作信号(即控制位)实现。24位控制位分别介绍如下: XRD:外部设备读信号,当给出个外设的地址后,输出此信号,从指定外设读数据。 EMWR:程序存储器EM写信号 EMRD:程序存储器EM读信号 PCOE:将程序计数器PC的值送到地址总线ABUS上EMEN:将程序存储器EM与数据总线DBUS接通,有EMWR和EMRD决定
7、是将DBUS数据写入EM中,还是从EM读出数据到DBUSIREN:将程序存储器EM独处的数据打入指令寄存器IR和微指令计数器uPCEINT:中断返回时清除中断响应和中断请求标志,便于下次中断。ELP:PC打入允许,与指令寄存器的IR2.,IR3位结合,控制程序跳转。MAREN:将数据总线DBUS上数据打入地址寄存器MARMAROE:将地址寄存器MAR的值送到地址总线ABUS上OUTEN:将数据总线DBUS上数据送到输出端口寄存器OUT里STEN:将数据总线DBUS上数据存到堆栈寄存器里RRD:读寄存器组R0-R3,寄存器R?的选择由指令的最低两位决定RWR:写寄存器组R0-R3,寄存器R?的选
8、择由指令的最低两位决定CN:决定运算器是否带进位移位,CN=1带进位,CN=0不带进位FEN:将标志位存入ALU内部的标志寄存器X2,X1,X0三位组合来译码选择将数据送到DBUS上的哪个寄存器,见表1WEN:将数据总线DBUS的值打入工作寄存器W中AEN:将数据总线DBUS的值打入累加器A中S2,S1,S0三位组合决定ALU做何种运算,见表2表1X2 X1 X0输出寄存器0 0 0IN_OE 外部输入门0 0 1IA_OE 中断向量0 1 0ST_OE 堆栈寄存器0 1 1PC_OE PC寄存器1 0 0D_OE 直通门1 0 1R_OE 右移门1 1 0L_OE 左移门1 1 1没有输出表
9、2S2 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 输出A1.2 设计目标本课程设计要求实现机器指令:ZHN(传送),INPUT(输入), YU(逻辑与),HUO(逻辑或),OUTPUT(输出),JIA(算术加),JIAN(算术减),JC,JZ,JMP(转移)和FEI (逻辑非)。要包括直接寻址,立即数寻址,寄存器寻址,间接寻址四种寻址方式。最后要在设计的指令系统基础上,编写程序实现异或。2.系统设计2.1 模型机的指令设计根据设计要求,设计出的指
10、令要包括传送,逻辑与,逻辑或,算术加,减运算,输入,输出,转移这八种指令,且要运用直接寻址,立即数寻址,寄存器寻址,间接寻址四种寻址方式。由此设计出指令表如表3:表3 指令表指令类型助记符机器码功能取指_FETCH_000000xxIRPC算术加JIA A,R?000001xx R?+AAJIA A, R?000010xx R?+AAJIA A,*000011xx *(*)+AAJIA A,#*000100xx #*+AA算术减JIAN A,R?001001xx R?-AAJIAN A,R?001010xxR?-AAJIAN A,*001011xx *A-(*)AJIAN A,#*001100
11、xx #*A-*A输入INPUT010001xx K23K16A输出OUTPUT010010xxAOUT寄存器逻辑与YU A,R?010011xxR?&AAYU A,R?010100xxR?&AAYU A,*010101xx *(*)&AAYU A,#*010110xx #*&AA逻辑或HUO A,R?010111xxR?|AAHUO A,R?011000xxR?|AAHUO A,*011001xx *(*)|AAHUO A,#*011010xx #*|AA逻辑非FEI A011011xxA取反传送ZHN R?,A100000xxAR?ZHN *,A100010xx *A(*)ZHN R?,#
12、*100011xx #*R?ZHN A,R?011100xxR? AZHN A,#*011111xx #*A转移JC *100100xx *CF=1则*PCJZ *100101xx *ZF=1则*PCJMP *100111xx *2.2 模型机的微指令设计 (1)微指令的24位控制位如下: XRD EMWR EMRD PCOE EMEN IREN EINT ELP MAREN MARDE OUTEN STEN RRD RWR CN FEN X2 X1 X0 WEN AEN S2 S1 S0(2)设计出的微指令集如表4:表4 微指令集表助记符 状态微地址微程序_FETCH_T000CBFFFF0
13、1FFFFFF02FFFFFF03FFFFFFJIA A,R?T204FFF7EFT105FFFE90T006CBFFFF07FFFFFFJIA A,R?T308FF77FFT209D7BFEFT10AFFFE90T00BCBFFFFJIA A,*T30CC77FFFT20DD7BFEFT10EFFFE90T00FCBFFFFJIA A,#*T210C7FFEFT111FFFE90T012CBFFFF13FFFFFFJIAC A,R?T214FFF7EFT115FFFE94T016CBFFFF17FFFFFFJIAC A,R?T318FF77FFT219D7BFEFT11AFFFE94T01B
14、CBFFFFJIAC A,*T31CC77FFFT21DD7BFEFT11EFFFE94T01FCBFFFFJIAC A,#*T220C7FFEFT121FFFE94T022CBFFFF23FFFFFFJIAN A,R?T224FFF7EFT125FFFE91T026CBFFFF27FFFFFFJIAN A,R?T328FF77FFT229D7BFEFT12AFFFE91T02BCBFFFFJIAN A,*T32CC77FFFT22DD7BFEFT12EFFFE91T02FCBFFFFJIAN A,#*T230C7FFEFT131FFFE91T032CBFFFF33FFFFFFJIANC A,
15、R?T234FFF7EFT135FFFE95T036CBFFFF37FFFFFFJIANC A,R?T338FF77FFT239D7BFEFT13AFFFE95T03BCBFFFFJIANC A,*T33CC77FFFT23DD7BFEFT13EFFFE95T03FCBFFFFJIANC A,#*T240C7FFEFT141FFFE95T042CBFFFF43FFFFFFINPUTT144FFFF17T045CBFFFF46FFFFFF47FFFFFFOUTPUTT148FFDF9FT049CBFFFF4AFFFFFF4BFFFFFFYU A,R?T24CFFF7EFT14DFFFE93T04
16、ECBFFFF4FFFFFFFYU A,R?T350FF77FFT251D7BFEFT152FFFE93T053CBFFFFYU A,*T354C77FFFT255D7BFEFT156FFFE93T057CBFFFFYU A,#*T258C7FFEFT169FFFE93T05ACBFFFF5BFFFFFFHUO A,R?T25CFFF7EFT15DFFFE92T05ECBFFFF5FFFFFFFHUO A,R?T360FF77FFT261D7BFEFT162FFFE92T063CBFFFFHUO A,*T364C77FFFT265D7BFEFT166FFFE92T067CBFFFFHUO A,
17、#*T268C7FFEFT169FFFE92T06ACBFFFF6BFFFFFFFEI AT16CFFFE96T06DCBFFFF6EFFFFFF6FFFFFFFZHN A,R?T170FFF7F7T071CBFFFF72FFFFFF73FFFFFFZHN A,R?T274FF77FFT175D7BFF7T076CBFFFF77FFFFFFZHN A,*T278C77FFFT179D7BFF7T07ACBFFFF7BFFFFFFZHN A,#*T17CC7FFF7T07DCBFFFF7EFFFFFF7FFFFFFFZHN R?,AT180FFFB9FT081CBFFFF82FFFFFF83FF
18、FFFFZHN R?,AT284FF77FFT185B7BF9FT086CBFFFF87FFFFFFZHN *,AT288C77FFFT189B7BF9FT08ACBFFFF8BFFFFFFZHN R?,#*T18CC7FBFFT08DCBFFFF8EFFFFFF8FFFFFFFJC *T190C6FFFFT091CBFFFF92FFFFFF93FFFFFFJZ *T194C6FFFFT095CBFFFF96FFFFFF97FFFFFFJMP *T198C6FFFFT099CBFFFF9AFFFFFF9BFFFFFF2.3 异或程序设计程序设计思路:有等式则有程序流程图如图5:图5 程序流程图
19、3.系统实现3.1 程序编写 按照系统分析中得到的指令集,在DJ-CPT816实验软件中新建指令系统,生成.mac文件和.mic文件。在DJ-CPT816实验软件中新建.asm文件,输入程序: INPUTZHN R0,AINPUTZHN R1,AFEI AZHN R2,AZHN A,R0FEI AZHN R3,AZHN A,R0YU A,R2ZHN R2,AZHN A,R1YU A,R3ZHN R3,AZHN A,R2JIA A,R3OUTPUTEND3.2 程序分析INPUT /准备输入第一个二进制数ZHN R0,A /输入第一个二进制数到寄存器R0INPUT /准备输入第二个二进制数ZHN
20、 R1,A /输入第一个二进制数到寄存器FEI A /对累加器A里面的值取反ZHN R2,A /把A里面的值存到寄存器R2中ZHN A,R0 /把R0里面的值存到寄存器A中FEI A /对累加器A里面的值取反ZHN R3,A /把A里面的值存到寄存器R3中ZHN A,R0 /把R0里面的值存到寄存器A中YU A,R2 /对A和R2里面的值进行与操作,并将结果放入A中ZHN R2,A /把A里面的值存到寄存器R2中ZHN A,R1 /把R1里面的值存到寄存器A中YU A,R3 /对A和R3里面的值进行与操作,并将结果放入A中ZHN R3,A /把A里面的值存到寄存器R3中ZHN A,R2 /把R
21、2里面的值存到寄存器A中JIA A,R3 /把A和R3中的值进行加操作,并将结果放入A中OUTPUT /输出A中的值END3.3 调试结果把计算机与试验仪器相连接,打开试验仪器,导入新建的指令系统,编译下载该asm文件,装载正确后单步运行,检查运行结果是否符合要求。实验结果:1第一次置K23K16 为00101000,第二次置K23K16为01011111,输出的是01110111 2第一次置K23K16 为00101111,第二次置K23K16为00101101,输出的是00000010 4.总结4.1 设计体会经过为期四周的课程设计,一路走下来发现自己存在的问题还是非常多的,当初拿到课程设
22、计题目的时候由于相关知识的缺乏,自己并没有很好的设计思路,在通过和同学的探讨以及查阅相关资料之后,发现有时候同学之间的交流还是能够学到很多东西的。本次课程设计要求我们设计一台微程序控制的模型机,设计基本模型机的指令系统(包括逻辑与,逻辑或,算术加,减运算,输入,输出,转移,传送指令),设计的目的是让我们增加自己的动手能力,真正的达到理论与实际的结合。由于自己对计算机硬件知识了解的不是非常透彻,对相关部件的工作原理并不是很清楚,在刚开始设计感觉到无从下手,只能够由实验书上的简单例子进行相关的试验,并查阅相关资料漫漫的由浅入深达到设计的目的。经过本次课程设计,真正的发现理论与实际结合得重要性,有时
23、并不是理论知识学得好动手能力就会高,当真正动起手来发现自己需要学得知识还是很多的,在以后的学习中,自己一定会加强理论与实际的结合,让自己达到新型社会需要人才的标准。在此次的设计中,感谢老师对我们的帮助和指导。过程还不够完善,希望老师继续指导4.2 系统改进本系统由于立即数寻址方式未能做好,所以程序代码方面效率不是太高。主要是因为:修改助记符和微指令时并没有按照规范的步骤修改,就通过记事本方式修改了.mic文件,.mac文件和.dat文件,虽然运行结果运行可以,但立即数那一块运行有问题。所以本系统要想改善的话,应该重新做微指令那块,但考虑到时间问题就没有重新做微指令了,虽然程序不是很精简,但运行也没什么问题。还有就是指令合并没做,这样可以使程序代码简化,运行速度加快,但自身能力不足就没做了。参考文献1计算机组成原理实验指导书. 王诚,宋佳兴,董长洪编著. 清华大学出版社,2002.2计算机组成原理学习指导与训练 . 旷海兰等编著. 中国水利水电出版社, 2004.3计算机原理与设计. 宋焕章 张春元 王保恒. 长沙:国防科技大学出版社, 2000.4 白中英计算机组成原理(第二版)北京:科学出版社,1998