4.3 指令操作码的扩展

4.3.1操作码的编码方式

指令操作码的长度决定了指令系统中完成不同操作的指令条数。设操作码有n位,则指令条数最多为2n条。
1.固定格式
操作码长度固定,集中放在一个字段
2.可变格式
OP长度可变,分散放在指令的不同字段中

4.3.2 扩展操作码技术

当采用统一操作码,指令长度与各类指令的地址长度发生矛盾时,通常采用“扩展操作码”技术加以解决。 扩展操作码是一种指令优化技术,即让操作码的长度 随 地址数的减少 而增加(即扩展)。根据不同的地址指令格式,如三地址、二地址、单地址指令等,操作码的位数可以有不同的选择,从而在满足需要的前提下,有效地缩短了指令长度。

4.3.3 指令扩展的要点

①操作码位数随地址码个数变化采取可变长度的类型;
②不允许短操作码是长操作码的一部分,以保证指令间指令码一定不重复;
③根据需要灵活变通,但操作码长度为有限几种。

某机器的指令长度为16位,包括4位基本操作码和三个4位地址字段。
若三地址指令仅需15条,两地址指令需15条,一地址指令需15条,零地址指令需16条,
共61条指令,应如何安排操作码?

在这里插入图片描述

4.3.4 指令扩展详解

某机器的指令长度为16位,包括4位基本操作码和三个4位地址字段,
运用操作码的扩展技术,设计三地址指令15条、二地址指令15条、
一地址指令14条和零地址指令32条,
试画图写出指令扩展的详细情况。

首先我们知道指令长度为16位, 未扩展操作码的操作码占了4位,那么剩下的就是地址码共12位,现在要求设计的最高是三地址,那我们就把地址码给设为三个,假设每个地址暂时都是4位,这样就正好16位。
现在三地址的操作码只有4位,那就是0000~1110,共15条指令,剩下的1111用来作为扩展位;
扩展到二地址时操作码就有8位了,原本应该时从1111开始,现在又扩展了4位,就是从1111 0000,到1111 1110,同样得,有15条指令,剩下的1111 1111就是用来给下一次扩展作扩展位;
扩展到一地址时,题目要求有变化了,要求一地址有14条,后面的零地址32条,我们先这样做,一地址扩展后的指令范围为1111 1111 0000 ~ 1111 1111 1101,给留两个扩展位,这样就是14条了;
最后的零地址就是两个起点了,先从1111 1111 1110 0000到1111 1111 1110 1111,有16条,接着继续从下一个起点,或者说扩展位 1111 1111 1111 0000到1111 1111 1111 1111 也有16条,共32条。
在这里插入图片描述

  • 15
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值