




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、课程设计说明书题目: 设计一指令系统 院 系: 计算机科学与工程学院 专业班级: 计算机09-9班 学 号: 2009* 学生姓名: * 指导教师: * 2011年 06 月 30日 安徽理工大学课程设计(论文)任务书 计算机科学与技术 院系 计算机硬件 教研室学 号88888888学生姓名88888888 专业(班级)计算机88班设计题目设计一指令系统设计技术参数通过cpth计算机组成原理教学实验系统设计指令/微指令系统。设计要求1. 在基本模型机的基础上改进并实现in,lda,out,jmp,add,sub等6条指令的功能。2. 设计相应的微程序。3. 在实验箱上实现指令系统。工作量1.
2、课程设计说明书2000字;2. 画出流程图,编写微指令代码和程序;3. 对各个指令代码进行分析,并运行测试。工作计划学习微程序控制器,了解实验箱中的各部分结构。分析题目,查阅资料,画出流程图,设计出微指令。按实验要求连线,编写程序在实验箱上运行。写出课程设计报告。参考资料1 陈书开,王毅.计算机组成与系统结构.武汉:武汉大学出版社,20052 张功萱.计算机组成原理.北京:清华大学出版社,2005年09月3 王诚.计算机组成原理实验指导书.北京:清华大学出版社,20024 杨小龙.计算机组成原理与系统结构实验教程.西安:西安电子科技大学出版社,20045 袁开榜.计算机组成原理.北京:高等教育
3、出版社,1995指导教师签字*教研室主任签字 2011 年 6 月 30日指导教师评语:成绩: 指导教师: 年 月 日安徽理工大学课程设计(论文)成绩评定表目录内容摘要i绪言11 需求分析11.1设计背景11.2设计目标32 总体设计32.1 程序微指令分析32.2 算术运算基本模型机微程序概述53.详细设计53.1 cpth模型机简介53.2模型机指令设计说明53.3 根据指令的功能设计相应的微程序73.4编程实现94 调试与运行95心得体会9参考文献11内容摘要部件实验过程中,各部件单元的控制信号是人为模拟产生的,本课程设计将能在微程序控制下自动产生各部件单元的控制信号,实现特定指令的功能
4、,通过设计流程图,编写机器指令,微指令和控制信号程序。首先向存储器中装入数据和程序,然后检查写入是否正确,启动程序执行。另外,还需设计微程序:数据传送(lda),加(add),减(sub),输入(in),输出(out),跳转(jmp)。以上各微指令设计完毕后,用设计好的指令实现逻辑运算,连接线路在cpth计算机组成原理教学实验箱运行程序,并将实验结果显示输出。这一课题的实现不仅使我们对各种微指令有了熟练的掌握,更对以后的学习、工作中有深远的影响。关键词:指令,微程序,cpth绪言随着社会科技的发展,计算机被应用到各行各业,人们步入自动化、智能化的生活阶段。本次课程设计课题是基本模型机的设计与实
5、现,它正体现了这一点。利用cpu与简单模型机来实现计算机组成原理课程及实验中所学到的实验原理和编程思想,硬件设备自拟,编写指令的应用程序,用微程序控制器实现了一系列的指令功能,最终达到将理论与实践相联系。本次设计完成了各指令的格式以及编码的设计,实现了各机器指令微代码,形成具有一定功能的完整的应用程序。1 需求分析1.1设计背景通过计算机组成原理理论课和几次实验的学习,尝试使用八类机器指令中的三到四种设计,并编写相应的微程序,完成由基本单元电路构成一台基本模型机,再经过调试指令和模型机使其在微程序的控制下自动产生各部件单元的正常工作控制信号。本课程设计的模型机的指令码为8位,根据指令类型的不同
6、,可以有0到2个操作数,指令码的最低两位用来选择r0-r3寄存器。在微程序控制方式下,用指令码作为微地址来寻址微程序存储器,找到执行该指令的微程序。在本模型机中,一条指令最多分为四个状态周期,一个状态周期为一个时钟脉冲,每个状态周期产生不同的控制逻辑,实现模型机的各种功能。模型机有24位控制位以控制寄存器的输入输出,选择运算器的运算功能,存储器的读写。简言之,这次设计,计算机数据通路的控制将由微程序控制器来完成,cpu从内存中取出一条机器指令到指令执行结束的一个指令周期,全部由微指令组成的序列来完成,即一条机器指令对应一条微程序,一条微程序又有若干微指令组成,一条微指令的功能由24位操作信号(
7、即控制位)实现。本设计是在dj-cpt816计算机组成原理实验仪和仿真软件上进行的24位控制位分别介绍如下:xrd:外部设备读信号,当给出个外设的地址后,输出此信号,从指定外设读数据。emwr:程序存储器em写信号emrd:程序存储器em读信号pcoe:将程序计数器pc的值送到地址总线abus上emen:将程序存储器em与数据总线dbus接通,有emwr和emrd决定是将dbus数据写入em中,还是从em读出数据到dbusiren:将程序存储器em独处的数据打入指令寄存器ir和微指令计数器upceint:中断返回时清除中断响应和中断请求标志,便于下次中断。elp:pc打入允许,与指令寄存器的i
8、r2.,ir3位结合,控制程序跳转。maren:将数据总线dbus上数据打入地址寄存器marmaroe:将地址寄存器mar的值送到地址总线abus上outen:将数据总线dbus上数据送到输出端口寄存器out里sten:将数据总线dbus上数据存到堆栈寄存器里rrd:读寄存器组r0-r3,寄存器r?的选择由指令的最低两位决定rwr:写寄存器组r0-r3,寄存器r?的选择由指令的最低两位决定cn:决定运算器是否带进位移位,cn=1带进位,cn=0不带进位fen:将标志位存入alu内部的标志寄存器x2,x1,x0三位组合来译码选择将数据送到dbus上的哪个寄存器,见表1-1wen:将数据总线dbu
9、s的值打入工作寄存器w中aen:将数据总线dbus的值打入累加器a中s2,s1,s0三位组合决定alu做何种运算,见表1-2表1-1 寄存器选择控制表x2 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没有输出表1-2 运算器功能控制s2 s1 s0功能0 0 0a+w 加0 0 1a-w 减0 1 0a|w 或续表1-20 1 1a & w 与1 0 0a+w+c 带进位加1 0 1a-w-c 带进位减1
10、1 0a a取反1 1 1a 输出a1.2设计目标 本课程设计要求实现机器指令:,in(输入),out(输出),lda(不带进位算术加),add(带进位算术加),sub(带进位算术减),jmp(跳转指令)。并且要包括直接寻址,立即数寻址,寄存器寻址,间接寻址四种寻址方式。最后要在设计的指令系统基础上,编写程序实现带进位的循环左移。2 总体设计2.1 程序微指令分析将程序在dj-cpt816软件上单步运行结束后可得微指令跟踪图如下表2-1:表2-1 微指令跟踪图助记符状态微地址微程序数据输出数据打入地址输出运算器upcpct000cbffff指令寄存器irpc输出a输出写入100 int144f
11、fff17 用户in 寄存器a a输出 +1t045cbffff指令寄存器irpc输出a输出写入105 jmp 09t19cc6ffff 存贮器值em 寄存器pc pc输出 a输出 +1 写入t09dcbffff指令寄存器irpc输出a输出写入107 add a,#01t210c7ffef 存贮器值em 寄存器w pc输出 a输出 +1 +1t111fffe90 alu直通 寄存器a 加运算 +1续表2-1t012cbffff指令寄存器irpc输出a输出写入109 outt148ffdf9f alu直通 用户out a输出 +1t049cbffff指令寄存器irpc输出a输出写入10a jmp
12、01t19cc6ffff 存贮器值em 寄存器pc pc输出 a输出 +1 写入t09dcbffff指令寄存器irpc输出a输出写入12.2算术运算基本模型机微首先对编好的程序进行保存,然后进行汇编,看是否有语法错误,再进行单步调试,按快捷图标的f7,执行“单微指令运行”功能,观察执行每条微指令时,数据是否按照设计要求流动,寄存器的输入/输出状态是否符合设计要求,各控制信号的状态,pc及upc如何工作。 开始调试的时候是有点错,我还以为是指令错了,经过几次的核对,检验,和与草图对比,指令的跳转是没有问题的, 最后估计可能接线出错了。应接j1和j2座的,却接成了j1和j3座,跳转的指令出错,也可
13、能是ma6ma0接线不对, 改正了后重新检查一编线路后,重新开始运行程序led显示的十六进制数与ma6ma0微地址显示灯对应。拨动开关clr(01)后,微地址清零。pc程序计数器清零,然后控制台swbswa开关置为“00”,按动启动开关start,微地址显示灯“010000”(20),再按动一次start,微地址灯显示“010010”(22),第三次按动start,微地址显示灯显示“010111”3.详细设计3.1 cpth模型机简介 cpth 模型机包括了一个标准cpu 所具备所有部件,这些部件包括:运算器alu、累加器a、工作寄存器w、左移门l、直通门d、右移门r、寄存器组r0-r3、程序
14、计数器pc、地址寄存器mar、堆栈寄存器st、中断向量寄存器ia、输入端口in、输出端口寄存器out、程序存储器em、指令寄存器ir、微程序计数器upc、微程序存储器um,以及中断控制电路、跳转控制电路。其中运算器和中断控制电路以及跳转控制电路用cpld 来实现,其它电路都是用离散的数字电路组成。微程序控制部分也可以用组合逻辑控制来代替。 模型机为8 位机,数据总线、地址总线都为8位,但其工作原理与16位机相同。相比而言8 位机实验减少了烦琐的连线,但其原理却更容易被学生理解、吸收。3.2模型机指令设计说明表3-1模型机指令指令助记符功能描述in从输入端口读数据到累加器a中add a,#*将累
15、加器a中的数据输出到端口中续表3-1sub a,#*将累加器a中的数据输出到端口中jmp *跳转到指定地址out 将累加器a中的数据输出到输出端口lda r?累加器a中取数 一.创建指令系统(助记符、机器码)(1)打开cpth组成原理实验软件,选择文件|新建指令系统/微程序,清除原来的指令/微程序系统,观察软件下方的“指令系统”窗口(图3.1),所有指令码都“未使用”。图3.1指令系统窗口(2)选择第二行,即“机器码1”为0000 01xx行,在下方的“助记符”栏填入数据装载功能的指令助记符“in”,由于此指定了将累加器a输出寄存器,所以不用选择“操作码1”和“操作码2”,也可在“操作数1”栏
16、选择“a”,表示第一个操作数为累加器a,“操作数2”无需选择。按“修改”按钮确认。(3)选择第三行,即“机器码1”为0000 10xx行,在下方的“助记符”栏填入加法功能的指令助记符“lda”,在“操作码1”栏选择“a”,表示第一操作数为累加器a,在“操作数2”栏选择“#*”,表示第二操作数为立即数。按“修改”按钮确认。(4)选择第四行,即“机器码1”为0000 11xx行,在下方的“助记符”栏填入指令助记符“out”,由于此指定了将累加器a输出寄存器,所以不用选择“操作码1”和“操作码2”,也可在“操作数1”栏选择“a”,表示第一个操作数为累加器a,“操作数2”无需选择。按“修改”按钮确认。
17、(5)选择第五行,即“机器码1”为0001 00xx行,在下方的“助记符”栏填入输出数据功能的指令助记符“jmp”,在“操作码1”栏选择“*”,表示跳转地址为*,此指令无第二操作数,无需选择“操作数2”。按“修改”按钮确认。因为硬件设计时,跳转指令的跳转控制需要指令码的第3位和第2位ir3,ir2来决定,无条件跳转的控制要求ir3必须为1,所以无条件跳转的机器码选择此行,机器码为000011xx。关于跳转控制的硬件设计和实验可参考前面章节。(6)选择第六行,即“机器码1”为0001 01xx行,在下方的“助记符”栏填入输出数据功能的指令助记符“add”,在“操作码1”栏选择“a”,表示第一个操
18、作数为累加器a,在“操作数2”栏选择“#*”,表示第二操作数为立即数。按“修改”按钮确认。(7)选择第七行,即“机器码1”为0001 10xx行,在下方的“助记符”栏填入输出数据功能的指令助记符“sub”,在“操作码1”栏选择“a”,表示第一个操作数为累加器a,在“操作数2”栏选择“#*”,表示第二操作数为立即数。按“修改”按钮确认。图3.2指令助记符3.3 根据指令的功能设计相应的微程序 将窗口切换到“um微程序”窗口,现在此窗口中所有微指令值都是0ffffffh,也就是无任何操作,我们需要在此窗口输入每条指令的微程序来实现该指令的功能。每个程序开始要执行的第一条微指令应是取指操作,因为程序
19、复位后,pc 和upc 的值都为0,所以微程序的0 地址处就是程序执行的第一条取指的微指令。取指操作要做的工作是从程序存储器em 中读出下条将要执行的指令,并将指令的机器码存入指令寄存器ir和微程序计数器upc中,读出下条操作的微指令。根据此功能,观察窗口下方的各控制信号,有“勾”表示信号为高,处于无效状态,去掉“勾”信号为低,为有效状态。要从em中读数,emrd 必需有效,去掉信号下面的“勾”使其有效;读em的地址要从pc输出,所以pcoe要有效,允许pc输出,去掉pcoe下面的“勾”,pcoe有效同时还会使pc加1,准备读em的下一地址;iren是将em读出的指令码存入upc和ir,所以要
20、去掉iren的“勾”使其有效。这样,取指操作的微指令就设计好了,取指操作的微指令的值为cbffffh。然后把助记符_fatch_,状态t0,微地址,微程序cbffffh,按照上表格式填入,其余类同现在我们来看把立即数装入累加器a要做哪些工作,首先要从em中读出立即数,并送到数据总线dbus,再从dbus 上将数据打入累加器a中,按照这个要求,从em中读数据,emrd应该有效,em的地址由pc输出,pcoe必需有效,读出的数据送到dbus,emen也应有效,要求将数据存入a中,aen也要有效,根据前面描述“jiayi #*”指令有四个状态周期, t0状态取指微指令的值为cbffffh,t1状态取
21、指微指令的值为cbff90h,t2状态取指微指令的值为d7ffef,t3状态取指微指令的值为ef7fff。(取操作描述可见第 步)。如上,根据指令的执行过程分析,并参照实验指导书上微型机指令集得出其他的微程序。如图3.3图3.3微程序结果 (6)选择菜单文件|保存指令系统/微程序功能,将新建的指令系统/微程序保存下来,以便以后调用。为不与已有的指令系统冲突,将新的指令系统/微程序保存为“new.mac”。如图3.4。图3.4指令系统/微程序文件图3.4编程实现源代码lda r1,#01add a,#01sub a,#01injmp looploop:out将程序另存为a,asm,选择文件| 跳
22、入指令系/微程序,调入a.mac,将程序汇编成机器码,观察反汇编窗口,会现实出程序地址,机器码,反汇编指令。按快捷图标的f7,执行“单微指令运行”功能,观察执行每条微指令时,数据是否按照设计要求流动,寄存器的输入/输出状态是否符合设计要求,各控制信号的状态,pc及upc如何工作是否正确。到此为止,我们利用cpth 软件系统已经建成了一个新的指令系统/微程序。新的指令系统从汇编助记符到指令机器码到微指令都与原来的指令系统有所不同。我们只创建了四条指令,对于其它指令,用户可以做为练习来扩充完整,成为一个真正的指令系统。4 调试与运行使用软件中的f4-load功能装入机器指令格式文件(1)将编程开关置为“run”,“step”置为“step”,“stop”置为“run”状态。(2)拨动开关clr(01),微地址寄存器清零,程序计数器清零,程序的首地址00h。(3)单步来运行一条微指令,每按动一次start键,即单步调试运行一条微指令。对照微程序流程图,观察微地址显示灯是否和流程一致。(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025合同违约责任条款约定
- 2025知识产权许可代理服务合同
- 2025年汽车维修的合同模板
- 农业生产资源承包利用合同
- 公路保洁劳务分包合同
- 公司劳动用工协议书合同
- 注册土木工程师考试知识点概述试题及答案
- 葡萄酒产业国际化挑战与应对:2025年产区特色与品牌创新报告
- 精准扶贫政策对农村电商的影响试题及答案
- 家具设计案例分析与总结试题及答案
- 上海第二工业大学《高等数学B(上)》2023-2024学年第二学期期末试卷
- 2025届上海市(春秋考)高考英语考纲词汇对照表清单
- 2025年黑龙江齐齐哈尔市网络舆情中心招聘5人历年高频重点提升(共500题)附带答案详解
- 区域代理方案(3篇)
- 八年级期中英语试卷分析及整改措施
- 养老院艺术疗愈活动方案
- 《地理高考备考讲座》课件
- 2024-2030年全球及中国雅思练习和考试平台行业发展规模及未来前景预测报告
- TSG 07-2019电梯安装修理维护质量保证手册程序文件制度文件表单一整套
- 2025深圳劳动合同下载
- 《风电施工流程》课件
评论
0/150
提交评论