计算机组成原理课程设计---基本模型机的设计与实现.doc_第1页
计算机组成原理课程设计---基本模型机的设计与实现.doc_第2页
计算机组成原理课程设计---基本模型机的设计与实现.doc_第3页
计算机组成原理课程设计---基本模型机的设计与实现.doc_第4页
计算机组成原理课程设计---基本模型机的设计与实现.doc_第5页
已阅读5页,还剩32页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

*实践教学* 计算机与通信学院2011年春季学期计算机组成原理课程设计题 目: 模型机设计5 专业班级: 08级计算机科学与技术(5)班 姓 名: 学 号: 08240539 指导教师: 成 绩: 前 言通过对计算机组成原理及实验的学习,设计14条机器指令,并编写相应的微程序,完成由基本单元电路构成一台基本模型机,再经过调试指令和模型机使其在微程序的控制下自动产生各部件单元的正常工作控制信号。在设计基本模型机5的实验过程中,个别部件单元的控制信号是人为模拟产生的,而本课程设计将能在微程序控制下自动产生各部件单元控制信号,实现特定指令的功能。这里,计算机数据通路的控制将由微程序控制器来完成,cpu从内存中取出一条机器指令到指令执行结束的一个指令周期,全部由微指令组成的序列来完成,即一条机器指令对应一条微程序。本课程设计以dvcc计算机组成原理教学实验系统为平台设计完成。1、 根据任务要求设计整机系统的方案。2、 存储系统:使用模型机的存储模块,说明存储器的输入输出时序,模块连接方式等。3、 运算器:使用模型机的器件,组成带有片间串行进位8位移位运算功能的运算器。4、 微程序控制器模块:使用教学机的系统,设计微程序控制器。5、 设计模型机指令系统:(含设计微指令格式、微程序流程图,每条指令所对应的微程序等)。6、 了解并说明教学模型机的输入输出模块。7、 在自己设计的指令系统基础上,编制一个汇编语言小程序并进行调试通过。8、 整机设计分模块进行,说明模块中数据和控制信号的来源、去向、功能、时序,以及模块间数据和控制信号的来源、去向、功能、时序等。本设计的规定项目采用14条机器指令:in.out.sta.lda.jmp.bzc.clr.mov.cmp.sub.dec.hlt.rrc.rlc。摘 要本次课程设计课题是基本模型机的设计与实现,该设计要求根据计算机组成原理课程所学知识,设计、开发一套简单的模型计算机。通过对一个简单计算机的设计,以达到对计算机的基本组成、部件的功能与设计、微程序控制器的设计、微指令和微程序的编制与调试等过程有更深的了解,加深对理论课程的理解。通过模型机的设计和调试,连贯运用计算机组成原理课程学到的知识,建立计算机整机概念,加深计算机时间和空间概念的理解。部件实验过程中,本课程设计将能在微程序控制下自动产生各部件单元的控制信号,实现特定指令的功能,通过设计流程图,编写机器指令,微指令和控制信号程序。首先向存储器中装入数据和程序,然后检查写入是否正确,启动程序执行,并将实验结果显示输出。关键词:模型机 运算器 存储系统 指令系统 微程序指令目录前 言2摘 要3一 设计的目的及设计原理41 设计的目的42 设计的原理5二 总体设计9三 详细设计131 运算器的物理结构132 存储器的组成与说明143 指令系统的设计与格式分析154 微程序控制器的逻辑机构及功能255 微程序的设计与实现27四.系统调试报告33五 设计总结36六 设计(论文)的主要参考文献37七 致谢38一 设计的目的及设计原理1 设计的目的计算机组成原理课程设计是“计算机组成原理”课程的后续设计性课程,通过设计一台模型计算机,可更好地理解计算机组成原理课程的基本内容,掌握模型计算机设计与实现的基本方法,培养实验动手能力和创新意识,为以后进行计算机应用系统的设计与开发奠定基础。设计一个8位模型计算机系统,包括运算器,微程序控制器,存储器,简单输入输出接口和设备,时序和启停控制等电路。定义一套简单的指令系统,制定系统的设计方案和实现方法,画出所设计的模型机系统的电路原理图。在计算机组成原理与系统结构实验系统上搭建模型计算机系统,完成微程序控制器的实验调试过程,并用所设计的指令系统编写一个实现简单功能的程序,在搭建的模型机系统上输入、调试和运行程序。最后总结实验结果,完善所设计的模型机系统方案和电路图,写出设计报告。2 设计的原理(1)基本模型机的设计与实现部件实验过程中,各部件单元的控制信号是人为模拟产生的,而本次实验将能在微程序控制下自动产生各部件单元控制信号,实现特定指令的功能。这里,计算机数据通路的控制将由微程序控制器来完成,cpu从内存中取出一条机器指令到指令执行结束的一个指令周期全部由微指令组成的序列来完成,即一条机器指令对应一个微程序。此基本模型机的设计主要包括存储器、运算器、输入/输出设备、微控器和指令系统五个模块组成。其中运算器主要由运算器u3、u4(74ls181)、暂存器u1、u2(74ls273)、输出缓冲器u5(74ls245)、移位器(74ls299)以及进位控制和判零标志控制电路等构成。存储器存储该主存储器采用一级cache-存储器结构。输入/输出设备主要有两种外部i/o设备,一种是键盘,它作为输入设备input;另一种是字符显示块,它作为输出设备output。控制器它主要由控制存储器、微指令寄存器和地址转移逻辑三大部分组成,其中微指令寄存器分为微地址寄存器和微命令寄存器两部分。一台计算机中所有机器指令的集合,成为这台计算机的指令系统,它是计算机系统设计的一个核心问题,它不仅与计算机的硬件结构紧密相关,而且直接关系到用户的使用需要。指令从内存中读出,首先放到ir指令寄存器中,再送入到微控器中进行译码,再由微控器输出各种控制信号给各功能部件,执行相应的操作。指令和数据统统放在内存中,从形式上看,它们都是二进制代码,。一般来讲,取值周期从内存中读出的信息流是指令流,它指向控制器;而在执行周期中从内存中读出的信息流是数据流,它由内存流向运算器。指令从存储器中得到,送到指令寄存器中。由指令得到相应的控制信号,从控制器输出控制信号来控制计算机的运行。(2)各模块功能为:a.存储器存储器的功能是保存或“记忆”各种数据。在存放到存储器以前,他们全部变成0或1表示的二进制代码。采用半导体器件来存放大量的0,1.一个半导体触发器由于有0和1两种状态,可以记忆一个二进制代码。一个数据假定用8位二进制代码来表示,那么就需要8各触发器来保存这些代码。通常,在存储器中保存一个数的8个触发器称为一个存储单元。存储器是由许多存储单元组成的,每一个存储单元都有编号,称为地址。存储器的所有存储单元的总数称为存储器的存储容量。b.运算器运算器就好像是一个由电子线路构成的算盘,它的主要功能就是进行加、减、乘、除等运算。还可以进行逻辑运算。电子器件的特性,计算机中通常采用二进制数。其运算规律非常简单。0+0+0,0+1=1,1+0=1,1+1=10,00=0,01=0,10=0,11=1。该模块中算术运算是由2片74ls181构成,是运算器的核心。74ls181功能表如表1-1所示 表1-1 74ls181功能表4位alus3 s2 s1 s0m0(算术运算)m1 (逻辑运算)cn=1 无进位cn=0 有进位l l l ll l l hl l h ll l h hl h l ll h l hl h h ll h h hh l l lh l l hh l h lh l h hh h l lfafa+bfa+/bf2的补fa加(a*/b)f(a+b)加(a*/b)fa减b减1f(a*/b)减1fa加a*bfa加bf(a+/b)加a*bfa*b减1fa加afa加1f(a+b)加1f(a+/b)加1f0 fa加(a*/b)加1f(a+b)加(a*/b)加1 fa减b f(a*/b) fa加ab加1fa加b加1f(a+/b)加a*b加1fab fa加a加1 f/af/(a+b) f/a*b f0 f/(a*b) f/b f(a b) f(a*/b) f/a+b f/(a b) fbfab f=1 进位输入信号来自于两个方面:其一对运算器74ls181的进位输出/cn+4进位倒相所得cn4;其二由移位寄存器74ls299的选择参数s0、s1、aq0、aq7决定所得,移位寄存器74ls299主要用于带进位左、右移位操作。c.控制器控制器是计算机中发号施令的部件,它控制计算机的各部件有条不紊的进行工作。更具体地讲,控制器的任务就是从内存中取出解题步骤加以分析,然后执行某种操作。d.输入/输出设备 本系统有两种外部i/o设备,一种是键盘,它作为输入设备input;另一种是字符显示块,它作为输出设备output。e.指令系统指令系统控制计算机系统有条不紊的工作f.寄存器介绍 指令寄存器用来保存当前正在执行的一条指令。当执行一条指令时,先把它从内存取到缓冲寄存器中,然后再传送到指令寄存器。指令划分为操作码和地址码字段,由二进制构成,为了执行任何一条给定的指令,必须对操作码进行测试p(1),通过节拍脉冲t4的控制以便识别所要求的操作。“指令译码器”根据指令中的操作码进行译码,强置微控器单元的微地址,使下一条微指令指向相应的微程序首地址。数据寄存器用来存放从内存中读出的数据或是从输入设备输入的数据,然后将数据送到运算器等功能部件,起了暂存的作用。pc为指令指针计数寄存器,用来存放下一条将要执行指令的地址。sp为堆栈指针计数寄存器,用来在堆栈寻址方式中指示栈顶指针的位置。(3)带移位运算的模型机的设计与实现 在基本模型机的基础上搭接移位控制电路,实现移位控制运算。实验中新增4条移位运算指令:rl(左环移)、rlc(带进位左环移)、rr(右环移)、rrc(带进位右环移),其指令格式如下: 操作码 rr 01010000 rrc 01100000 rl 01110000 rlc 10000000以上4条指令都为单字长(8位)。rr为将r0寄存器中的内容循环右移1位。rrc为将r0寄存器中的内容带进位右移1位,它将r0寄存器中的数据右边第1位移入进位,同时将进位寄存器的数移至r0寄存器的最左位。rl为将r0寄存器中的数据循环左移1位。 rlc为将r0寄存器中的数据带进位循环左移1位。为了向ram中装入程序和数据,检查写入是否正确,并能启动程序执行,还设计了3个控制台操作微程序。存储器读操作(krd):拨动总清开关clr后,控制台开关swb,swa为“00”时,按start启动纽,可对ram连续手动读操作。存储器写操作(kwe):拨动总清开关clr后,控制台开关swb,swa置为“01”时,按动start启动纽可对ram进行连续手动写入。启动程序:拨动总清开关clr后控制台开关swb,swa置为“11”时,按动启动键,即可转入到第01号“取址”微指令上述三条控制台指令用两个开关swb、swa的状态来设置,其定义如下表1-2: 表1-2swb swa 控制台指令001011读内存(krd)写内存(kwe)启动程序(rp) 二 总体设计本次实验将能在微程序控制下自动产生各部件单元的控制信号,实验特定指令的功能。在制定设计方案的时候,首先要理解所设计的模拟机各个部件的作用及功效,弄清楚他们可以干什么,怎么样去干。这样才能更好的完成设计达到我们设计的目的和通过实验所要继续深化的知识点。计算机数据通路的控制是由微程序控制器来实现的,cpu从内存中取出一条机器指令到指令执行结束的一个指令周期全部由微指令组成的序列来完成,即一条机器指令对应一个微程序。而每一条微指令都是由我们自己根据cpu要完成的功能设计的。总体设计框图如下:实验仪的总体结构框图(图1-1)(1)控制信号说明:1s3,s2,s1,s0 有微程序控制器输出的alu操作选择信号,以控制执行16种算术操作或16种逻辑操作中的一种操作。2m 微程序控制器输出的alu操作方式选择信号端,m0执行算术操作;m1执行逻辑操作。3/cn 微程序控制器输出的进位标志信号。/cn0表示alu运算时最低位加进位1;/cn1则表示无进位。4alubus 微程序控制器的输出信号,控制运算器的运算结果是否送到总线bus,低电平有效。5lddr1 微程序控制器的输出信号,控制把总线上的数据打入运算暂存器dr1。6lddr2 微程序控制器的输出信号,控制把总线上的数据打入运算暂存器dr2。7rbus 微程序控制器的输出信号,控制寄存器r0的内容是否送到总线bus,低电平有效。8ldr 微程序控制器的输出信号,控制把总线上的数据打入寄存器r0。9pcbus 微程序控制器的输出信号,控制程序计数器的内容是否送到总线bus,低电平有效。10ldpc 微程序控制器的输出信号,控制pc加1。11ldar 微程序控制器的输入信号,将程序计数器的内容打入到地址寄存器ar中,产生ram的地址。12ldir 微程序控制器的输出信号,控制把总线上的数据(指令)输入到指令寄存器ir中。13swbus 微程序控制器的输出信号,控制8位数据开关sw7sw0的开关量是否送到总线,低电平有效。14out 微程序控制器的输出信号,控制和数据总线上的数据是否送到发光二极管上,低电平有效。(2)框图部件概述:1.运算器(使用可编程器件74ls181实现):运算器是用来完成各种运算的部件,通常将运算分成算术运算和逻辑运算两大类:算术运算是指需要考虑进位的加、减、乘、除运算。逻辑运算是指位对位的运算。运算器中除了包含一个能完成算术和逻辑运算功能的算术逻辑运算单元(alu)之外,还要有可存放参加运算的操作数和运算结果的寄存器,以及在它们之间传送数据的通道。2.微程序控制器:控制器是整个系统的指挥中心,由它向系统内的各个部件发出各种控制命令,使系统构成一个有机的整体。通常将运算器和控制器合起来称之为“中央处理器”简称cpu。3.存储器:存储器主要由6116芯片及相应的缓冲芯片和控制线路实现的。存储器是用来存放各类信息的部件,所有能在机内运行的程序和所需的数据都要存放在存储器中,通常被称作主存储器或内存储器。一般说来,主存储器的容量越大,计算机功能越强。通常将cpu和主存储器合起来称之为计算机的“主机”。4.简单输入输出设备:输入由铅笔开关实现,输出由发光晶体管组成。输入设备是用来完成输入功能的部件。所有需要输入到机内的程序或数据,都是经输入设备输入的。输出设备是用来完成输出功能的部件,所有需要从计算机内输出的运算结果或在机内运行的程序、数据均可通过输出设备输出。 三 详细设计1 运算器的物理结构运算器模块主要由运算器u31、u32(74ls181)、暂存器u29、u30(74ls273)、输出缓冲器u33(74ls245)以及进位控制和判零标志控制电路等构成。 运算器物理结构(图3-1)下面以8位机为例说明运算器模块的工作原理:该模块中算术运算是由2片74ls181(u31、u32)构成,它是运算器的核心。它可以对两个8位的二进制数进行多种算术或逻辑运算,具体由74ls181的功能控制条件m、cn、s3、s2、s1、s0来决定,详见表11。两个参加运算的数分别来自于暂存器u29和u30,运算结果直接输出到输出缓冲器u33,由输出缓冲器发送到系统的数据总线上,以便进行移位操作或参加下一次运算。运算器是在 alu unit 单元电路上进行 ,控制信号、数据、时序信号由实验仪的逻辑开关电路和时序发生器提供。 sw7sw0 八个逻辑开关用于产生数据,由bussw控制发送到总线上。dr1,dr2 为运算暂存器 ,lddr1,lddr2为运算暂存器的输入控制信号,将总线上的数据输入到暂存器 drl,dr2;通过 s3、s2、sl、s0、m、/cn 的选择,可实现对 alu 算术操作和逻辑操作。在busalu控制信号作用下将运算结果送到总线 bus上。s3、s2、s1、s0、m、/cn、lddr1、 lddr2、busalu信号、bussw信号,本次实验中这些控制信号与对应逻辑开关都已接好,由逻辑开关模拟这些控制信号 。 lddr1、lddr2由t4 信号进行定时。当t4信号上升沿到来时 lddr1、lddr2 才起作用。2 存储器的组成与说明主存储器单元电路主要用于存放实验机指令,它的数据总线挂在外部数据总线exd0exd7上。它的地址总线由地址寄存器单元的地址寄存器74ls245(u37)给出,地址值由8个led灯lad0lad7显示,高电平亮,低电平灭;在手动方式下,输入数据由8位数据开关kd0kd7提供,并进一三态门74ls245(u51)连至外部数据总线exd0exd7,实验时将外部数据总线的exd0exd7用8芯排线练到内部数据总线busd0busd7,分时给出地址和数据。它的读信号直接就地;它的写信号和片选信号由写入方式确定。该存储器中机器指令的读写分别控制cpu的p1.2提供,片选信号由控制cpu的p1.1提供。由于地址寄存器为8位,故接入6264的地址为a0a7,而高4位a8a12接地,所以其实际使用容量为256字节。6264有控制线:cs1 第一片选线,cs2第二片选线,oe 读线,we 写线。cs1 片选线由w/r控制,cs2直接+5v.信号线ldar由开关ldar提供,手动方式实验时,跳线器ldar拨在左边,脉冲信号t3由实验机上时序电路模式ts3提供,实验时只需j22跳线器连上即可,t3的脉冲宽度可调。原理图如下: (图3-2) 存储器原理图3 指令系统的设计与格式分析1 指令系统的设计与格式:(1)数据格式 模型机规定采用定点补码表示法表示数据,且字长为8位,其格式如下: 表3-1 d7 d6 d0符号尾数其中第7位为符号位,数值表示范围是:1x1。 (2)指令格式 本模型机共有13条基本指令,其中算术运算类指令4条(add、sub、move、clr),访问内存指令和程序控制指令4条(sta、lda、jmp、bzc),i / o指令2条(in、out),位操作指令3条(and、or、xor),各指令格式如下所示。1) 算术逻辑指令 设计4条算术运算指令(add、sub、move、clr)并用单字节表示,寻址方式采用寄存器直接寻址,其格式如下: 表3-2 d7 d4 d3 d2 d1 d0 op-codersrd其中,opcode为操作码,rs为源寄存器,rd为目的寄存器,并规定: 表3-3 rs或rd选定的寄存器000110r0r1r22) 访问内存指令和程序控制指令 模型机设计访问内存指令和程序控制指令4条(存数sta、取数lda、无条件转移jmp、有进位转移指令bzc)。指令格式为: 表3-4 d7 d6 d5 d4 d3 d2 d1 d00 0mop-coderdd其中,opcode 为操作码,rd为目的寄存器地址(lda、sta 指令使用)。d为位移量(正负均可),m为寻址模式,其定义如下: 表3-5 m有效地址说明00011011e=de=(d)e=(ri)+de=(pc)+d直接寻址间接寻址ri变址寻址相对寻址 本模型机规定变址ri指定为寄存器r2。 3) i / o指令 输入in和输出out指令采用单字节指令,其格式如下:表3-6 d7 d4 d3 d2 d1 d0op-codeaddrrdaddr=01时,选中键盘作为输入设备;addr=10时,选中字符显示器作为输出设备。(3)预设指令:a: in为单字节长指令,含义是将输入设备输入的数据放入r0中 指令格式: in r0, inputdevice 指令功能:“inputdevice”-r0b: out为单字节长指令,含义是根据指令提供的地址,将内存中的数据取出由数码管进行显示。指令格式:out bus,(add)指令功能:将内存中的add为地址的数据读到总线上。c:sta为双字节长指令,第二个字节是要存放的地址,含义是将r0中的内容存储到第二字为地址的内存单元中。指令格式:sta(add),r0指令功能:将r0寄存器的内容存到以add为地址的内存单元中。d:lda为双字节指令,含义是将内存单元的地址存储于r0中。指令格式:lda 指令功能:ram-r0e: jmp为双字节长指令,含义是使程序跳转到指定的地址执行。 指令格式:jmp (jmp) 指令功能:ram-pcf:bzc为单字长指令,其中m为寻址模式字段,d为偏移地址。 指令格式:bzc m,d指令功能:当cy=1或zi=1,e-pcg:clr系统总清开关,低电平有效。 指令格式:clr r0 指令功能:r0=0 h:mov是双字节长指令,第二字节是要存放的间接地址,含义是将r0中的内容存储到第二字为间接地址的内存单元中。 指令格式:mov ax,r0 指令功能:(ax)=r0i:cmp比较指令,与sub指令一样执行减法操作,但不保存结果,只是根据结果设置条件标志位。 指令格式:cmp opr1,opr2 指令功能:(opr1)-(opr2)j:sub指令(subtract byte or word)字节或字相减.指令格式:sub dst,src指令功能:(dst)(src)=(dst) 将内存中的dst为地址单元内数与src的内容相减结果送dst。k:dec减1指令。 指令格式:dec opr 指令功能:(opr)-1=(opr)l:hlt为空转指令,保持执行结束状态,并不在执行任何操作。m:rl是左移指令,参加左移的数是8个位。 指令格式:rl al,cl 指令功能:将al中的数左移(cl)位n:rlc是带进位位的左移,参加左移的共有9个位 指令格式:rlc al,cl 指令功能:将al中的数带进位左移(cl)位(4)指令系统是设计计算机的依据 ,拟订指令系统将涉及基本字长、指令格式、指令种类、寻址方式等内容。基本字长:程序设计平台中配置的存储器容量为256*8,可知道基本字长定为8位。指令格式:指令格式可有单字长和双字长指令两种,在双字长格式中,第二字节一般定义为操作数或操作数地址。14条指令用单字节表示,寻址方式采用寄存器直接寻址,其格式如表3-7所示:表3-7 算数逻辑指令格式 d7 d6 d5 d4 d3 d2 d1 d0 op-codersrd对于预设指令可设计操作码如下:表3-8 指令格式和功能 指令类型汇编符号指令格式功能访问指令及转移指令sta m,d,rd1 1m0 1rdrdedlda m,d,rd1 1m1 0rderddjmp m,d0 0m1 0rdepcdbzc m,d0 1m1 1rd当cy=1时epcdi / o指令in addr,rdout addr,rd000001rdaddrrdrdaddr111110rd移位操作指令rl rs,rd0111rsrd rl rs,rdrlc rs,rd1110rdrd rlc rs,rd算术运算指令cmp rs,rd0100rsrdcmp rs,rdsub rs,rd0011rsrdsub rs,rdmov rs,rd1001rsrdmov rs,rdclr rd011000rdclr rddec rd 100000rdsub rd,1 (5)微指令流程图:运行:pc-arpc+1ram-busbus-irp(1)sw-busbus-rdpc-arpc+1pc-arpc+1pc-arpc+1pc-arpc+1rd-arram-busbus-arram-busbus-arram-busbus-pcr0-busbus-ramram-busbus-r0dr1-mram-busbus-arram-busbus-dr1 01 02 10 in out sta lda jmp bzc 10 11 12 13 14 15 01 01 01 01 01 01 0-r0stoppc-arpc+1rd-busbus-dr22r0-busbus-ramram-busbus-arrd-busbus-dr2rd-busbus-dr1r0-busbus-dr2dr1-1-r0r0-dr1dr1-dr2-r0dr1-ledr0-dr1dr1-ledr0-dr1dr1-dr2-r0 clr mov cmp sub dec hlt 16 17 18 19 20 21 01 01 01 01 01r0-299r0-299不带进位左移dr1-leddr1-led299-r0r0-dr1带进位循环左移299-r0r0-dr1 rl rlc 22 23 01 01 2指令格式分析:(1)微指令格式表表3-9:微指令格式表23222120191817161514131211s3s2s1s0m/cnloadceweldrolddr1lddr2ldir选择运算器运算模式打入pcram片选ram写打入r0打入dr1打入dr2打入ir109876543210ldpcldaralubuspcbusr0busswbusp(1)ua4ua3ua2ua1ua0pc1打入ar运算器结果送总线pc内容送总线r0内容送总线开关内容送总线判别字下一微指令地址24位代码的含义:s3,s2,s1,s0,m,cn: 为运算器74ls181芯片的控制信号,详见74ls181功能表1-1。 we :为w/r信号对ram和out进行写操作,高电平为写有效。 b1,b0 : 为对外部设备(ram,output,input)地址进行译码,b1b0=00时,input(即swb)选中;b1b0=01时,ram(即ce)选中;b1b0=10时, output(即ledb)选中,b1b0=11时,外部设备都不选中。a字段: 表3-10151413选择000001ldri 010lddr1011lddr2100ldir101load110ldarldri:寄存器输入选中,具体选择同指令寄存器(ir)的最低2位(i1,i0)配合,当i1,i0=00时为输入到r0寄存器;i1,i0=01时为r1;i1,i0=10时为r2。 lddr1:暂存器dr1选中。 lddr2:暂存器dr2选中。 ldir:指令寄存器ir选中。 load:总线数据直接装载到pc计数器。 ldar:地址寄存器ar选中。 b字段: 表3-11121110选择000001rs-b 010rd-b011ri-b100299-b101alu-b110pc-brs-b:为源寄存器输出选中。具体选择同指令寄存器(ir)的3,4位(i3,i2)配合,当i3,i2=00时为输入到r0寄存器;i3,i2=01时为r1;i3,i2=10时为r2。 rd-b:为目的寄存器输出选中。具体选择同指令寄存器(ir)的最低2位(i1,i0)配合,当i1,i0=00时为输入到r0寄存器;i1,i0=01时为r1;i1,i0=10时为r2。 ri-b:为变址寄存器选中。本机定固定为r2 。 299-b:移位寄存器输出选中。 alu-b:逻辑运算单元结果输出。 pc-b :pc计数器输出。 c字段: 表3-12987选择000001p(1) 010p(2)011p(3)100p(4)101ar110ldpcp(1):分支判断1,和指令寄存器(ir)的高四位(ir7-ir4)作为测试条件。可分16个分支。 p(2):分支判断2,和指令寄存器(ir)的三四位(ir3,ir2)作为测试条件,有4个分支。 p(3):分支判断3,和cy或zi作为测试条件,有两个分支。 p(4):分支判断4,和开关swb,sba作为测试条件,有4个分支。用于控制台控制区 (读程序,写程序,和运行程序) ar:进行算术运算时是否影响进位和判零标志的控制位。 选中时进行带进位运算。 ldpc:为pc计数信号选中。 ua5ua0: 为下一步微地址。4 微程序控制器的逻辑机构及功能(1)逻辑结构:采用微程序控制方式的控制器称为微程序控制器。所谓微程序控制方式是指微命令不是由组合逻辑电路产生的,而是由微指令译码产生。一条机器指令往往分成几步执行,将每一步操作所需的若干位命令以代码形式编写在一条微指令中,若干条微指令组成一端微程序,对应一条及其指令。在设计cpu时,根据指令系统的需要,事先编制好各段微程序 ,且将它们存入一个专用存储器中。微程序控制器由指令寄存器ir、程序计数器pc、程序状态字寄存器psw、时序系统、控制存储器cm、微指令寄存器以及微地址形成电路。微地址寄存器等部件组成。执行指令时,从控制存储器中找到相应的微程序段,逐次取出微指令,送入微指令寄存器,译码后产生所需微命令,控制各步操作完成。微控制器结构框图如下:它由控制存储器、微地址寄存器、微命令寄存器和地址转移逻辑几部分组成。微地址寄存器和微命令寄存器两者的总长度即为一条微指令的长 度,二者合在一起称为微指令寄存器。 图3-3 微程序控制器原理图(2)微程序控制器功能:a控制存储器(rom):rom中存放微程序,也就是全部的微指令。rom的容量取决于微指令的总数。假如控制器需要128条微指令,则微地址寄存器长度为7位。rom的字长取决于微指令长度。 如果微指令为32位,则rom的字长就是32位。实际应用中rom可采用eprom或e2prom、 earom,用户写入和修改微程序比较方便。b微命令寄存器:微命令寄存器暂存由控制存储器中读出的当前微指令中控制字段与测试判别字段信息可由8d寄存器组成。c微地址寄存器:微地址寄存器暂存由控制存储器读出的当前微指令的下址字段信息。它可由带rd、sd强置端的d触发器组成。其中时钟端和d端配合用做rom的读出打入,用sd进行下址修改。d地址转移逻辑:微指令由rom读出后直接给出下一条微指令的地址,这个地址就放在微地址寄存器中。 当微程序出现分支时通过地址转移逻辑去修改微地址寄存器内容,并按修改好的微地址读出 下条微指令。地址转移逻辑是一个组合逻辑电路,其输入是当前微指令的判别测试字段pi、 执行部件反馈的“状态条件”及时间因素t4。e控制时序信号:上图中标明了一个基本机器周期中的控制时序信号。例如用上一周期的t4时间按微地址寄存器内容从rom中

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论