先来看看指令系统在计算机中的位置:
机器指令:
指令的格式:
指令要进行操作,所以用操作码来进行实现,那么对谁进行操作呢?由地址码来实现,为了编程方便,在指令集当中,往往有多种寻址方式。
操作码—地址码—寻址方式
指令字长(一条指令的长度)
固定字长,可变字长
指令的一般格式
操作码字段–地址码字段
操作码:指出进行什么操作
(1)长度固定
用于指令字长较长的情况,RISC
如 IBM 370 8位
(2)长度可变
操作码分散在指令集的不同字段上
(3)扩展操作码技术
为什么要扩展操作码呢?
用上面的图来进行讲解:如果OP,A1,A2,A3都是4位的,那么这个最多只能有16条不同类型的指令,这显然是不够的,所以我们需要对操作码进行扩展。
我们经全为1的状态作为标记,如果我们的操作为1111,就扩展一位操作码,意思就是这个时候从0000-1110只有15个3地址码。相似的,如果标志位11111111,那么说明这个时候,有11110000-11111110一共有15个2地址码。剩下的分析都是相似的。
注意:3地址指令操作码每减少一个最多可构成2的4次方的2地址指令
2地址操作码每减少一个最多可以构成2的4次方的1地址指令
在程序中经常出现的那些指令我们可以用短操作码(短的查的快呀),那些不常出现的就用常操作码来表示。
地址码:
A1:第一操作数地址
A2:第二操作数地址
A3:结果的地址
A4:下一条指令的地址
(A1)OP(A2)->A3
上面我们一共做了4次访存。第一次是访存操作码,第二次是访存A1,第3次访存A2,第4次访存A3.
设我们的指令字长是32位,操作码8位,那么计算可以知道地址码的位数都是6位,那么这个时候我们会发现我们的寻址范围是2的6次方=