- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
断定型微地址特点 优点:以较短的顺序控制字段配合实现多路并行转移, 提高微程序的执行速度; 微程序在CM中物理分配很方便; 微程序设计灵活。 缺点:形成后继微地址结构比较复杂。 综合上述,后继微地址的形成是设计微程序控制的关键问题之一。确定后继微指令地址有以下几种情况: (A)顺序执行时,后继微地址可以由现行微指令字的下地址字段或微程序计数器?PC直接确定。 (B)无条件转向的后继微地址,可以由现行微指令字的下地址字段确定。 (C)有条件转向的后继微地址由现行机器指令操作码,现行微指令执行时产生状态特征或条件码的判别结果决定。 微指令的格式大体分成两类:水平型微指令和垂直型微指令。 1.水平型微指令 一次能定义并执行多个并行操作微命令的微指令,叫做水平型微指令。其一般格式如下: 控 制 字 段 判别测试字段 下地址字段 按照控制字段的编码方法不同,水平型微指令又分为三种:全水平型(不译法)微指令,字段译码法水平型微指令,以及直接和译码相混合的水平型微指令。 2.垂直型微指令 微指令中设置微操作码字段,采用微操作码编译法,由微操作码规定微指令的功能,称为垂直型微指令。其结构类似于机器指令的结构。它有操作码,在一条微指令中只有1—2个微操作命令,每条微指令的功能简单,因此,实现一条机器指令的微程序要比水平型微指令编写的微程序长得多。它是采用较长的微程序结构去换取较短的微指令结构。 四、微指令的格式 水平型与垂直型微指令比较 水平型微指令并行操作能力强,效率高,灵活性强 水平型微指令执行一条指令的时间短 由水平型微指令指令的微程序,有微指令字较长,微程序短,垂直型号字长短,微程序长。 水平型不便于用户掌握,垂直型与指令相似,易于掌握。 微程序控制器特点 设计规整,设计效率高 易于修改、扩展指令系统功能; 结构规整、简洁,可靠性高; 速度慢 访存频繁 执行效率不高 用于速度要求不高、功能较复杂的机器中。 特别适用于系列机 以“十进制”指令为例:数据通路和微指令流程图如下: 微程序举例 设数a和b已存放在的R1和R2寄存器中,数6存放在R3中,则完成十进制加法的微程序流程图如图,算法要求先进行a+b+6运算,然后判断结果有无进位,当进位标志Cy=1,则说明结果是正确的,当Cy=0,则说明本不需加6,所以应减去6,从而得到正确的结果。 从下面的流程图可见,“十进制加法”指令对应的微程序由四条微指令组成,每一条微指令用一个方框表示。 PC-AR-ABUS DBUS-DR-IR PC+1 P1 R1+R2-R2 R2+R3-R2 P2 R2-R3-R2 0000 0000 1010 1001 0000 0001 0000 Cy=1 Cy=0 微指令格式如下: (1) 第一条微指令是取指周期,有三个任务: 从内存取指令到IR,对应的微命令有 LDAR RD LDDR LDIR 对程序计数器PC加1 PC+1 根据OP进行判别测试,转十进制的加法微程序 所以第一条微指令的二进制代码是000 000 000 000 11111 10 0000。 设十进制加法的OP为1010,在P1有效时,修改μAR的内容为1010,则第二条指令从1010处开始执行。 μA3=P1·IR3·T4 μA2=P1·IR2·T4 μA1=P1·IR1·T4 μA0=P1·IR0·T4+P2·Cy·T4 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 0 0 0 0 0 (2) 第二条微指令的工作是完成a+b,即R1+R2-R2, 对应的微命令为: 所以第二条微指令的二进制编码是010 100 100 100 00000 00 1001 因此时P1P2均为0,所以下一条微指令的地址由下址字段决定即1001。 R1-X R2-Y + LDR2 0 1 0 1 0 0 1 0 0 1 0 0 0 0 0 0 0 0 0 1 0 0 1 指令周期的确定 固定时钟信号环形脉冲发生器: ——指令执行的时钟数固定。 可变长度时钟信号环形脉冲发生器: ——指令执行的时钟数不固定。 实现方法:用END信号,如 END = T5*ADD + T3*CLA + 指令流程图 A D D S T O R E L O A D
文档评论(0)