计算机组成原理第讲指令格式课件.ppt
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《计算机组成原理第讲指令格式课件.ppt》由会员分享,可在线阅读,更多相关《计算机组成原理第讲指令格式课件.ppt(32页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第1页,此课件共32页哦第第5章章 指指 令令 系系 统统指令格式指令格式 Instruction Formats寻址方式寻址方式 Addressing modes 指令系统的设计方法指令系统的设计方法Chapter 5 Instruction SetsRISCAn instruction set,or instruction set architecture(ISA),is the part of the computer architecture related to programming,including the native data types,instructions,regi
2、sters,addressing modes,memory architecture,interrupt and exception handling,and external I/O.2第2页,此课件共32页哦 指示计算机完成某一特定操作的最基本的命令称为计算机的“指令指令”Instruction。指令是计算机硬件能直接识别并执行的命令,是用机器语言编写程序的基础工具。一条指令能完成某种基本操作,一台计算机有几十条到几百条不同的指令。一台计算机的指令格式及其所有指令的集合指令格式及其所有指令的集合称为该计算机的指令指令系统系统。指令系统表征着计算机的基本功能,是程序设计者看到的机器的主要属性
3、和软、硬件的主要交界面。指令系统的设计主要包括操作类型操作类型、操作内容操作内容和指令格式指令格式的设计。5.2 指令格式指令格式 Instruction Formats3第3页,此课件共32页哦5.2.1 指令的一般格式指令的一般格式 计算机是通过执行指令来处理各种数据的,为了指出数据的来源、操作结果的去向及所执行的操作,一条指令应包含下列信息:(1)操作的性质及功能。(2)操作数(Operands)的地址(Address)。(3)操作结果的地址。(4)下一条指令的地址。以上信息可以归纳为两类:一是表示该指令要完成的操作操作,每种操作都用一个二进制形式的代码表示,称为操作码操作码(Opera
4、tion Code),操作码一般位于指令字的前部。二是描述操作数或下条指令的地址地址,称为地址码地址码 (Address Code)。4第4页,此课件共32页哦指令的基本格式:操作码操作码地址码地址码 指令中的地址码字段用来指出参与操作的操作数的地址,地址码的位数决定能够直接访问的存储空间范围。指令操作码的长度(二进制位数)决定了指令系统中完成不同操作的指令条数。指令是用来表示控制信息的一组二进制形式的代码,它应包含与自动进行某个基本信息处理操作有关的内容。指令格式指令格式 Instruction Formats5第5页,此课件共32页哦指令的地址结构指令的地址结构地址结构是指在指令中给出几个
5、地址。根据地址码中所给出的地址个数,可有几种不同的指令格式:(1)三地址指令三地址指令 Three-Address Instruction格式:OPCODEA1A2A3 其中:OPCODE操作码,A1第一操作数地址,A2第二操作数地址,A3操作结果的存贮地址。其操作表达式为:(A1)OP(A2)A3(2)两地址指令两地址指令 Two-Address Instruction格式:OPCODEA1A2其操作表达式为:(A1)OP(A2)A1目的操作数源操作数6第6页,此课件共32页哦(3)一地址指令一地址指令 One-Address Instruction格式:OPCODEA一地址指令常被称为“单
6、操作数指令”,实际上它有两种情况。一是参与操作的只有一个操作数,在对地址A所指定的操作数执行OPCODE规定的操作后,产生的结果仍存回到该地址中。例如,加1、减1、求反、(移位)等都是单操作数指令。二是参与操作的有两个操作数,其中一个是隐含的。例如,一些对两个操作数进行算术逻辑运算的指令也采用这种格式。此时,另一个操作数(目的操作数)隐含在累加器中,指令执行后目的操作数为操作结果取代。又如,堆栈操作指令也是有2个操作数的一地址指令,在指令中给出了一个操作数地址,另一个操作数隐含在栈顶。7第7页,此课件共32页哦(4)零地址指令零地址指令 Zero-Address Instruction格式:O
7、PCODE指令中只有操作码,没有操作数,所以也称无操作数指令。零地址格式的指令有两种情况:无需任何操作数。如空操作指令,停机指令等。操作数的地址是隐含的。(5)多地址指令多地址指令 某些计算机设置有一些功能很强的、用于实现成批数据处理的指令。如字符串处理指令,向量、矩阵运算指令等。为了描述一批数据,指令中需要多个地址来指出数据存放的首地址、长度和下标等信息。例如,CDC STAR-100的矩阵运算指令,其地址码部分有7个地址字段,用以指出参加运算的两个矩阵及结果的存储情况。8第8页,此课件共32页哦操作码的编码操作码的编码指令操作码通常有两种编码格式。(1)固定长度操作码固定长度操作码 Fix
8、ed-Length Opcode即操作码的长度固定,且集中放在指令字的一个字段中。这种格式有利于简化硬件设计,减少指令译码时间。若操作码长度为K位,则最多可有 2k 条不同指令。(2)可变长度操作码可变长度操作码 Variable-Length Opcode即操作码的长度可变,且分散地放在指令字的不同字段中。这种格式能有效地压缩程序中操作码的平均长度。但将增加指令译码和分析的难度,使控制器的设计复杂化。例如,操作码扩展技术操作码扩展技术,哈夫曼编码等。第9页,此课件共32页哦5.2.2 指令操作码指令操作码的扩展技术扩展技术 操作码扩展技术操作码扩展技术,在指令字中用一个固定长度的字段来表示基
9、本操作码,对于一部分不需要某个地址码的指令,把操作码扩充到该地址字段。既能充分利用指令字的各个字段,又能在不增加指令长度的情况下扩展操作码的长度,以表示更多的指令。【例1】某计算机的字长为16位,欲设计的指令系统有零地址指令16条,一地址指令15条,两地址指令15条及三地址指令15条,设每个地址码字段为4位,应如何设计?OPCODEA1A2A310第10页,此课件共32页哦 【例1】某计算机的字长为16位,欲设计的指令系统有零地址指令16条,一地址指令15条,两地址指令15条及三地址指令15条,设每个地址码字段为4位,应如何设计?解1.按固定长度操作码固定长度操作码格式设计。如果要求指令字长是
10、字节的整数倍,则零地址指令长度应该为 8位,一地址指令长度应该为 16位,二地址指令长度应该为 16位,三地址指令长度应该为 24位。地址码字段的长度地址码字段的长度均可大于 4位。零地址指令长度为 6位,一地址指令长度为 10位,二地址指令长度为 14位,三地址指令长度为 18位。26=64 61操作码长度操作码长度为 6位共61条指令。11第11页,此课件共32页哦 【例1】某计算机的字长为16位,欲设计的指令系统有零地址指令16条,一地址指令15条,两地址指令15条及三地址指令15条,设每个地址码字段为4位,应如何设计?解2.按操作码扩展技术操作码扩展技术设计。指令格式为:OPA1A2A
11、315 12 11 8 7 4 3 0指令格式包括1个基本操作码字段和3个地址码字段。各字段均为4位,指令字长为16位。要求三地址指令15条,24 1615,所以,基本操作码字段基本操作码字段长度为4位。地址码字段4位。12第12页,此课件共32页哦 4位基本操作码,共有16个码位。其中00001110作为15条三地址指令的操作码,1111作为扩展标志用于把操作码扩展到A1。15条二地址指令操作码为1111000011111110。留下一个码字11111111作为扩展标志用于把操作码扩展到A2。15条一地址指令的操作码为111111110000111111111110。码字1111111111
12、11作为扩展标志用于把操作码扩展到A3。16条零地址指令的操作码为11111111111100001111111111111111OPA1A2A315 12 11 8 7 4 3 0第13页,此课件共32页哦 此外还有其它的扩展方法。例如,可以形成15条三地址指令,14条两地址指令,31条一地址指令和16条零地址指令。本例所用的操作码扩展方法称为15/15/15法。它是指在4位二进制表示的16个码点中,用15个来表示最常用指令的操作码,剩下的一个码字用于把操作码扩展到下一个 4位。而下一个4位表示的16个码字也按同样的原则处理和扩展。作为今天的作业题14第14页,此课件共32页哦5.2.3 指
13、令长度与数据字长的关系指令长度与数据字长的关系 指令指令的长度(指令字长长度(指令字长 Instruction Length)主要取决于操作码操作码的长度长度、操作数地址操作数地址的长度长度和操作数地址操作数地址的个数个数。指令的长度有定长格式定长格式的,也有变长格式变长格式的。当操作数地址是主存储器的直接地址时,其地址码的位数就很长。当操作数地址是寄存器号时,地址码的位数就很短。所以,在两地址和多地址指令中通常只有一个操作数地址是存储器直接地址。为了充分利用存储空间,指令指令的长度长度通常为字节字节的整数倍整数倍。指令指令的长度长度与机器机器的字长没有固定字长没有固定的关系关系,既可以大于或
14、等于机器的字长,也可以小于机器的字长。指令的长度大于机器的字长时称为长长格式指令格式指令,它需要几个连续字单元或字单元加字节单元来存储。指令的长度小于或等于机器的字长时,称为短格式指令短格式指令,它只需一个字单元或一至几个连续的字节单元来存储。15第15页,此课件共32页哦存储器按:字编址存储器按:字编址字节编址字节编址位编址数据数据在存储器中存储器中的存放方式存放方式字地址字地址 为为 低字节低字节 地址地址字地址字地址 为为 高字节高字节 地址地址37621540字地址字地址04低字节低字节04512673字地址字地址04高字节高字节低字节在前高字节在前地址0000010100111001
15、01110111数据ABCDEFGHJKLMNOPQ存储器内容存储器内容 为为 GHEFCDABPQNOLMJK存储器内容存储器内容 为为 ABCDEFGHJKLMNOPQ16第16页,此课件共32页哦地址地址(十进制)0 4 812162024283236双字双字双字双字(地址32)双字双字双字双字(地址24)半字半字(地址20)半字半字(地址22)半字半字(地址16)半字半字(地址18)字节字节(地址 8)字节字节(地址 9)字节字节(地址10)字节字节(地址11)字字(地址 4)字字(地址 0)字节字节(地址14)字节字节(地址15)字节字节(地址13)字节字节(地址12)边界对准边界对
16、准地址地址(十进制)048字节字节(地址7)字节字节(地址6)字字(地址2)半字半字(地址10)半字半字(地址8)半字半字(地址0)字字(地址4)边界未对准边界未对准存储器中存储器中的数据存放数据存放(存储字长为 32 位)第17页,此课件共32页哦5.4 指令类型指令类型 指令的操作类型按功能可分成算术逻辑运算、数据传送、程序控制、指令的操作类型按功能可分成算术逻辑运算、数据传送、程序控制、输入输出等类型。输入输出等类型。1.算术逻辑运算算术逻辑运算 Arithmetic&Logical 一一些些低低档档的的微微型型机机只只有有定定点点加加减减运运算算指指令令、求求补补指指令令、比比较较指指
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 组成 原理 指令 格式 课件
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内