计算机组成原理课程设计1

上传人:沈*** 文档编号:44588984 上传时间:2021-12-05 格式:DOC 页数:14 大小:528.77KB
返回 下载 相关 举报
计算机组成原理课程设计1_第1页
第1页 / 共14页
计算机组成原理课程设计1_第2页
第2页 / 共14页
计算机组成原理课程设计1_第3页
第3页 / 共14页
点击查看更多>>
资源描述
目录 一.目录-2二.实验目的-3三.实验电路-4四.实验任务-9五.连线过程-9六.实验过程-10七.实验结果-11八.实验问题及解决方法-12九.实验心得-13- 14 -二实验目的1. 掌握时序产生器的组成原理。2.掌握微程序控制器的组成原理。3.掌握微指令格式的化简和归并。4.将微程序控制器同执行部件(整个数据通路)联机,组成一台模型计算机。5.用微程序控制器控制模型机数据通路。6.通过CPU运行九条机器指令(排除中断指令)组成的简单程序,掌握机器指令与微指令的关系,牢固建立计算机的整机概念。三实验电路1.时序发生器TEC4计算机组成原理实验系统的时序电路如图9所示。电路采用2片GAL22V10(U6、U7),可产生两级等间隔时序信号T1T4和W1W4,其中一个W由一轮T1T4循环组成,它相当于一个微指令周期或硬布线控制器的一拍,而一轮W1W4循环可供硬布线控制器执行一条机器指令。本次实验不涉及硬布线控制器,因此时序发生器中的相关内容也可根据需要放到硬布线控制器实验中进行。 微程序控制器只使用时序信号T1T4,产生T信号的功能集成在GAL22V10芯片TIMER1(U6)中,另外它还产生节拍信号W1、W2、W3、W4的控制时钟CLK1。该芯片的逻辑功能用ABEL语言实现。 2.微指令格式与微程序控制器电路根据给定的12条机器指令功能和数据通路总体图的控制信号,采用的微指令格式见图10。微指令字长共35位。其中顺序控制部分10位:后继微地址位,判别字段位,操作控制字段25位,各位进行直接控制。微指令格式中,信号名带有后缀“#”的信号为低有效信号,不带有后缀“#”的信号为高有效信号。3.微程序控制组成图 对应微指令格式,微程序控制器的组成见图11。控制存储器采用5片EEPROM 28C64(U8、U9、U10、U11、U12)。28C64的输出是D0D7,分别与引脚11、12、13、15、16、17、18、19相对应,CM0是最低字节,CM4是最高字节。微地址寄存器位,用一片6D触发器74HC174(U1)组成,带有清零端。两级与门、或门构成微地址转移逻辑,用于产生下一微指令的地址。在每个T1上升沿时刻,新的微指令地址会打入微地址寄存器中,控制存储器随即输出相应的微命令代码。微地址转移逻辑生成下一地址,等下一个T1上升沿时打入微地址寄存器。跳转开关JUMP(J1)是一组6个跳线开关。当用短路子将它们连通时,微地址寄存器mAR从本实验系统提供的微程序地址译码电路得到新的微程序地址mD0mD5。当他们被断开时,用户提供自己的新微程序地址mD0mD5。这样用户能够使用自己设计的微程序地址译码电路。5片EEPROM的地址A6(引脚4)直接与控制台开关SWC连接,当SWC = 1时,微地址大于或者等于40H,当SWC = 0时,微地址的范围为00H3FH。SWC主要用于实现读寄存器堆的功能。 微地址转移逻辑的多个输入信号中,INTQ是中断请求,本实验中可以不理会。SWA、SWB是控制台的两个二进制开关信号,实验台上线已接好接。是进位信号,IR7IR4是机器指令代码,由于本次实验不连接数据通路,这些信号都接到二进制开关K0K15上。4.指令功能与格式指令的高位提供给微程序控制器,低位提供给数据通路。表5 指令功能与格式名称助记符功能指令格式R7 R6 R5 R4R3 R2R1 R0加法ADD Rd,RsRd+Rs-Rd0 0 0 0RS1 RS0RD1 RD0减法SUB Rd,RsRd-Rs-Rd0 0 0 1RS1 RS0RD1 RD0乘法MUL Rd,RsRd*Rs-Rd0 0 1 0RS1 RS0RD1 RD0逻辑与AND Rd,RsRd&Rs-Rd0 0 1 1RS1 RS0RD1 RD0存数STA Rd,RsRd-Rs0 1 0 0RS1 RS0RD1 RD0取数LDA Rd,RsRs-Rd0 1 0 1RS1 RS0RD1 RD0无条件转移JMP RsRs-PC1 0 0 0RS1 RS0X X条件转移JC D若C=1则PC+D-PC1 0 0 1D3 D2D1 D0停机STP暂停运行0 1 1 0X XX X中断返回IRET返回断点1 0 1 0X XX X开中断INTS允许中断1 0 1 1X XX X关中断INTC禁止中断1 1 0 0X XX X5.微程序流程图存储器写操作(KWE):按下复位按钮CLR#后,微地址寄存器状态为全零。此时置SWC = 0、SWB ,SWA ,按启动按钮后微指令地址转入27H,从而可对连续进行手动写入。存储器读操作(KRD):按下复位按钮CLR#后,置SWC = 0,SWB ,SWA ,按启动按钮后微指令地址转入17H,从而可对RAM连续进行读操作。写寄存器操作(KLD):按下复位按钮CLR#后,置SWC = 0,SWB 1,SWA ,按启动按钮后微指令地址转入37H,从而可对寄存器堆中的寄存器连续进行写操作。读寄存器操作(KRR):按下复位按钮CLR#后,置SWC = 1,SWB 0,SWA 0,按启动按钮后微指令地址转入47H,从而可对寄存器堆中的寄存器连续进行读操作。启动程序(PR):按下复位按钮CLR#后,置SWC = 0,SWB 0,SWB A,用数据开关SW7SW0设置内存中程序的首地址,按启动按钮后微指令地址转入07H,然后转到“取指”微指令。6.微指令按十六进制编码微指令地址微指令编码微指令地址微指令编码00H005C002073CH405C8003D07H00541200517H00544003F27H40544003D3FH409C0003E3DH00140003C3EH005C8003F7.对机器指令系统组成的简单程序进行译码。 将下表的程序按指令格式手工汇编成十六进制机器代码,此项任务应在预习时完成。地址指令机器代码00HLDA R0,R258H01HLDA R1,R35DH02HADD R0,R104H03HJC +595H04HAND R2,R33EH05HSUB R3,R21BH06HSTA R3,R24BH07HMUL R0,R124H08HSTP60H09HJMP R184H8.模拟计算机连线示意图 开关控制 控制台 时序发生器 时序信号 开关控制 指示灯信号 控制信号 时序信号 控制信号 微程序控制器 数据通路 指令代码、条件信号图13 模型计算机连线示意图四实验任务1. 在TEC-4计算机组成原理实验台上,依次输入以下十条指令。2.其中R2的地址为36H,36H里边的数是03H。R3的地址是37H,37H里边的数是05H。3.输入完毕后把R0,R1里的数读出来。4.执行完毕后把R0,R1,R2,R3里的数读出来,把存储器36H,37H的内容读出来。并记录结果。所要输入的十条指令地址指令机器代码00HLDA R0,R258H01HLDA R1,R35DH02HADD R0,R104H03HJC +595H04HAND R2,R33EH05HSUB R3,R21BH06HSTA R3,R24BH07HMUL R0,R124H08HSTP60H09HJMP R184H五连线过程1. 将跳线开关J1用短路子短接。时序发生器的输入TJ1接控制存储器的输入TJ。控制存储器的输入C接运算器ALU的C。控制器的输入IR7,IR6,IR5,IR4依次接指令寄存器IR的输出端IR7,IR6,IR5,IR4。共6根线。2. 控制器的输出LDIR(CER),LDPC(LDR4),PC_ADD,PC_NC,M4,LDIAR,LDAR1(LDAR2),AR1_INC,M3,LDER,IAR_BUS#,SW_BUS#,RS_BUS#,ALU_BUS,CER#,LRW,WRD,LDDR1(LDDR2),M1(M2),S2,S1,S0依次与数据通路的对应信号连接。共27条线。 3.指令寄存器IR的输出IR0接双端口寄存器堆的RD0,WR0,IR1接RD1,WR1,IR2接RS0,IR3接RS1.共6条线。六实验过程1. 利用控制台微程序KLD设置通用寄存器R2,R3的值(1) 。令DP=0,DB=0,DZ=0,使实验系统处于与连续运行状态。令SWC=0,SWB=1,SWA=1,使实验系统处于寄存器加载工作方式。按CLR#按钮,是系统处于初始状态。(2) 在SW7-SW0上设置一个寄存器地址,该地址供设置通用寄存器使用。可将该地址设置为0FFH。(3) 在SW7-SW0上设置02H,作为R2的寄存器号。按一次QD,将02H写入IR。(4)在SW7-SW0设置36H,作为R2的值。按一次QD,将36H写入指定的寄存器中。(5)在SW7-SW0上设置03,作为通用寄存器R3的寄存器号。按一次QD,将03H写入IR。(6)在SW7-SW0设置37H,作为R3的值。按一次QD按钮,将37H写入R3。(7)设置R2,R3结束,按CLR#按钮,使实验系统处于初始状态。2. 利用控制台微程序KWE存程序机器代码从00H地址开始存储10个机器代码:58H,5DH,04H,95H,3EH,1BH,4BH,24H,60H,84H。在36H存入03H,用于给R0置初值;在37H存入05H,用于给R1置初值。(1) 令DP=0,DB=0,DZ=0,使系统处于连续状态。令SWC=0,SWS=1,SWA=0。(2) 置SW7-SW0为00H,按QD按钮,将00H写入AR1。(3) 置SW7-SW0为58H,按QD按钮,将58H写入存储器00H单元。AR1自动加1,变为01H.(4) 如此重复下去,一直到将84H写入存储器09H单元。按CLE#,使实验系统处于初始状态。(5) 置SW7-SW0为36H,按QD按钮,将36H写入AR1。(6) 置SW7=SW0为03H,按QD按钮,将03H写入存储器36H单元,AR1自动加1,变为61H。(7) 置SW7-SW0为05H,按QD按钮,将05H写入存储器37H,按CLE#使系统处于初始状态。3. 用单拍(DP)方式执行一遍程序在单拍执行过程中,首先要随时监测AR2的值和IR的值,一判定程序执行到何处。七实验结果1. LDA R0,R2执行结果 R2=36H,R0=03H。2. LDA R1,R3执行结果 R3=37H,R1=05H.3.ADD R0,R1执行结果 R0=08H,R1=05H,C=0。4. JC+5执行结果转移到03H,以为C=05. AND R2,R3执行结果 R2=36H,R3=37H6. SUB R3,R2执行结果 R2=36H,R3=01H.7. STA R3,R2执行结果 R2=36H,R3=01H,寄存器36H单元的内容为01H.8. MUL R0,R1执行结果 R0=28H,R1=05H9. STP执行结果 无变化10.JMPR1执行结果 转移到05H执行结束后,执行结果为R0=28H,R1=05H,R2=36H,R3=01H。寄存器36H单元的内容为01H,37H单元的内容为05H。8 实验问题及解决方案 在实验过程中,我遇到了许多问题。对实验原理的不理解,对实验电路图的不理解,好多知识都忘记了,动手能力差,而且实验台好多都是坏的。在开始试验后,我又看了课本上的相关内容,认真的对实验电路图加以分析理解,并请教同学不会的地方,势必把不懂的地方弄懂,在大检查时由于好多试验台是坏的,在等待其他同学检查时,我在其他实验台上操作了很多遍,直到很流利为止。9 实验心得 在接触计算机语言之前,我们就已经学过了数字逻辑,给计算机组成原理这门课打下了一些基础。但是,学习了计算机组成原理之后才了解到JMP,MOV,LDA,ADD,SUB,STA,MUL,STP等指令的执行原理,执行过程与执行结果,让我们更加的深入了解了计算机的内部的组织结构,对我们计算机专业的学生来说,学习计算机组成原理提高了我们的综合能力。计算机组成原理的学习更多的是学习计算机基本体系结构。其中遇到很多新概念,如寄存器,中断,寻址方式,指令系统,存储系统等。这些概念在刚接触这门课时难以理解,但是在之后的学习中通过老师讲解,渐渐明了起来。要学好计算机组成原理,实验师不可少的环节。我们都知道,书上的基本原理都能能明白,但实际动手起来却并不是那么简单。通过实验,可以加深对知识的理解与认识。十分感谢任课并指导我们课程设计的刘超老师,在刘超老师的认真指导下,我们才能顺利的学完计算机组成原理这门重要的课程,并且能顺利的完成计算机组成原理的课程设计。
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!