- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
计算机组成原理
武汉科技大学
计算机科学与技术学院;第四章 指令系统;4.1.1 指令系统的发展
程序:解决某一实际问题的指令序列
指令:要计算机执行某种操作的命令;4. 指令系统的发展
50年代——只有定点加减、逻辑运算、数据传送、转移等十几至几十条指令
60年代后期——增加了乘除运算、浮点运算、十进制运算、字符串处理等,指令多达一二百条,寻址方式也趋多样化
60年代后期——开始出现系列计算机
70年代末期——CISC(Complex Instruction Set Computer) RISC(Reduced Instruction Set Computer)
系列计算机——基本指令系统、体系结构相同的一系列计算机
系列计算机必要条件——同一系列的各机种有共同的指令集;且实现“向上兼容”;CISC和RISC; 一个完善的指令系统应满足的条件:
完备性 指令丰富、功能齐全、使用方便——用汇编语言编各种程序时,直接提供的指令足够用
有效性 程序占存储空间小、执行速度快
规整性 对称性、匀齐性、指令格式和数据格式的一致性
对称性:所有的寄存器和存储器单元都可同等对待;所有的指令都可使用各种寻址方式
匀齐性:一种操作指令可支持各种数据类型
指令格式和数据格式的一致性:指令长度和数据长度有一定关系,方便处理和存取
兼容性 “向上兼容”;低级语言分机器语言(二进制)和汇编语言(符号)
高级语言与低级语言的性能比较:
高级语言的语句和用法与具体机器的指令系统无关
低级语言和具体机器的指令系统密切相关
机器语言是机器能直接识别和执行的惟一语言
汇编语言与硬件关系密切,编写的程序紧凑、占内存小、速度快,适合编写经常与硬件打交道的系统软件
高级语言不涉及机器的硬件结构,通用性强、编写程序容易,适合编写与硬件没有直接关系的应用软件;高级语言与低级语言的比较;4.2? 指令格式;(1)零地址指令
两种情况:
一是该指令不需要操作数,如NOP指令
二是操作数隐含,如DAA操作数隐含于累加器AC中
(2)一地址指令(单操作数指令)
也有两种情况:
一是指令本身只需要一个操作数,如NOT指令
二是被操作数和结果隐含于累加器AC中
AC ← (AC) OP (A)
(A)表示地址为A的内存或通用寄存器中的数;(3)二地址指令(双操作数指令)
A1← (A1) OP (A2)
按操作数的物理位置不同又分为:SS型、RR型、RS型指令
(4)三地址指令
A3← (A1) OP (A2)
A1——被操作数地址,也称源操作数地址
A2——操作数地址,也称终点操作数地址
A3——存放结果的地址
A1,A2,A3可为内存单元或通用寄存器的地址;机器字长:计算机能直接处理的二进制数的位数
指令字长度:指令字包含二进制代码的位数,等长、变长两种
等长指令字结构:结构简单,且指令字长度不变
变长指令字结构:结构灵活,但控制较复杂;典型的指令助记符;1. 八位微型计算机(字长8位)的指令格式
——可变字长形式:单字长、双字长、三字长指令;字长32位,字节寻址,通用寄存器32个
R型指令——所有算术运算,数据必须放在通用寄存器中;ARM指令集的一种指令格式;[例1] 已知指令格式,OP为操作码,试分析其特点;[例2] 试分析下面指令格式的特点;[例3] MIPS R4000汇编语言中,寄存器$s0?$s7对应寄存器号为16? 23(十进制),寄存器$t0?$t7对应寄存器号为8? 15。下表列出了2条R型指令(add、sub),2条I型指令(IW、SW)的汇编语言表示。请将4条汇编语言手工翻译成对应的机器语言(十进制)表示;$s0?$s7对应寄存器号为16? 23;4.3 操作数类型;Pentium数据类型;4.3.3 Power PC数据类型;4.4? 指令和数据的寻址方式;跳跃寻址——下条指令的地址码由本条指令给出;——形成操作数的有效地址的方法
例如,一种单地址指令的结构如下所示;——指令中不显式给出而是隐含着操作数的地址
例如,单地址的指令格式隐含着累加器AC为第二操作数地址
2.立即寻址
——指令的地址字段给出的是操作数本身,而不是操作数地址
不需要访问内存取数,故指令执行时间很短
3.直接寻址;——形式地址A是操作数地址的指示器,A单元的内容才是操作数的有效地址;——指令中给出通用寄存器的编号,操作数在通用寄存器中
6.寄存器间接寻址方式
——指令中给出寄存器的编号,但该寄存器的内容是操作数的地址,操作数在内存中
如:8086 CPU的指令系统中MO
文档评论(0)