计算机组成原理第五章课件.ppt
《计算机组成原理第五章课件.ppt》由会员分享,可在线阅读,更多相关《计算机组成原理第五章课件.ppt(64页珍藏版)》请在三一办公上搜索。
1、2023/11/17,第1页,第5章 指令系统,计算机组成原理,教学目标教学重点教学过程,2023/11/17,第2页,教学目标,了解指令系统的发展与性能要求掌握指令格式和寻址方式,2023/11/17,第3页,教学重点,指令格式扩展操作码寻址方式,2023/11/17,第4页,教学过程,5.1 计算机的指令系统的发展与性能5.2 指令的格式5.3 寻址方式5.4 指令的分类与高级语言5.5 典型指令系统,2023/11/17,第5页,5.1计算机的指令系统的发展与性能,指令系统决定了计算机的基本功能,指令系统的设计是计算机系统设计的一个核心问题。它不仅与计算机的硬件设计紧密相关,而且直接影响
2、到系统软件设计的难易程度。完善的计算机的指令系统应具备:1、完备性:一台计算机中最基本的、必不可少的指令构成了指令系统的完备性。2、有效性:指利用该指令系统所提供的指令编制的程序能够产生高效率。高效率主要表现在空间和时间方面,即占用存储空间小、执行速度快。3、规整性:指令操作的对称性和匀齐性,指令格式与数据格式的一致性。(1)对称性:在指令系统中,所有寄存器和存储单元都可同等对待,这对简化程序设计,提高程序的可读性非常有用。(2)匀齐性:是指一种操作性质的指令可以支持各种数据类型。(3)指令的格式与数据格式的一致性:指令长度与数据长度有一定关系,以方便存取和处理。4、兼容性:兼容性一般是指计算
3、机的体系结构设计基本相同,机器之间具有相同的基本结构、数据表示和共同的基本指令集合。,2023/11/17,第6页,5.2指令的格式,计算机的指令格式与机器的字长、存储器的容量及指令的功能密切相关。,2023/11/17,第7页,5.2.1指令操作码与地址码(1/9),两个字段:操作码字段+操作数地址字段:1.操作码操作码是指明指令操作性质的命令码。它提供指令的操作控制信息。(1)每条指令都要求它的操作码必须是独一无二的位组合。(2)指令系统中指令的个数N与操作码的位数n,必须满足关系式:N2n2.操作数地址码(1)地址码:用来描述该指令的操作对象。(2)指令字长=操作码的位数+(操作数地址个
4、数)*(操作数地址码位数),2023/11/17,第8页,5.2.1指令操作码与地址码(2/9),一、指令格式1.零地址指令格式这是一种没有操作数地址部分的指令格式。这种指令有两种可能:(1)无需任何操作数。如空操作指令,停机指令等。(2)所需的操作数是默认的:堆栈。,操作码OC,2023/11/17,第9页,5.2.1指令操作码与地址码(3/9),A、堆栈的概念(a)是若干个存储单元(或寄存器)的有序集合,它顺序地存放一组元素。(b)数据的存取都只能在栈顶单元内进行,即数据的进栈与出栈都只能经过栈顶单元这个“出入口”。(c)堆栈中的数据采用“先进后出”或“后进先出”的存取工作方式。B、堆栈结
5、构在计算机中的作用(a)具有堆栈结构的机器使用零地址指令,这不仅合指令长度短,指令结构简单,机器硬件简化。(b)实现程序调用,子程序嵌套调用和递归调用。(c)对于“中断”技术,堆栈更是不可缺少的,保存“断点”和“现场”。,2023/11/17,第10页,5.2.1指令操作码与地址码(4/9),C、堆栈的操作设数据进栈方向为从高地址向低地址发展,当向堆栈压入数据时,SP的内容先自动递减而指向一个新的空栈顶单元,再把数据写入此栈顶单元;当数据弹出堆栈时,立即读出SP所指向的栈顶单元内容,再把SP内容自动递增而指向新的栈顶位置。即 PUSH X;(SP)-1SP(X)(SP)POP X;(SP)X(
6、SP)+1SP,2023/11/17,第11页,5.2.1指令操作码与地址码(5/9),2.一地址指令格式(1)指令中给出的一个地址即是操作数的地址,又是操作结果的存储地址。如加1、减1、移位等单操作数指令。(2)在某些计算机中,指令中提供的一个地址提供一个操作数,另一个操作数是由机内硬件寄存器“隐含”地自动提供的。所谓“隐含”是指此操作数在指令中不出现,而是按照事先约定由寄存器默认提供,运算结果仍送到寄存器中。因为这个寄存器在连续运算时,保存着多条指令连续操作的累计结果,故称为累加器(AC)。,2023/11/17,第12页,5.2.1指令操作码与地址码(6/9),3.二地址指令格式(1)把
7、保存操作前原来操作数的地址称为源点地址(SS),把保存指令执行结果的地址称为终点地址或目的地址(DD)。(2)将源点与终点操作数进行操作码规定的操作后,将结果存入终点地址。通常二地址指令又称为双操作数指令。例如,双操作数加法指令:ADD R0,R1表示将R0寄存器的内容和R1寄存器的内容相加以后,将结果存入R1寄存器中。又如ADD(R0),R1表示将R0寄存器的内容作为地址,到内存中取出该地址所指向的单元内容作为源点操作数,和作为终点操作数的R1寄存器的内容相加以后,将结果存入R1寄存器中。,2023/11/17,第13页,5.2.1指令操作码与地址码(7/9),4.三地址指令格式其操作是对A
8、C1、AC2指出的两个操作数进行操作码所规定的操作,并将结果存入AC3中。例如:ADD X Y Z 含义为(X)+(Y)Z 即X单元内容加上Y单元内容,结果送Z单元中。,2023/11/17,第14页,5.2.1指令操作码与地址码(8/9),5.多地址指令格式例如四地址指令格式。(1)含义:ADD X Y Z WA、(X)+(Y)ZB、(W)下一条指令地址(2)特点:A、直观明了;B、程序执行的流向明确;C、操作数和结果可以分散在内存各处。D、但是指令字长度太长。,2023/11/17,第15页,5.2.1指令操作码与地址码(9/9),指令格式设计准则 1、指令字长要短,以得到时间和空间上的优
9、势。2、指令字长必须有足够的长度。3、指令字长一般应是机器字符长度的整数倍以便存储系统的管理。若机器中字符码长是L位,则机器字长最好是L,2L,4L,8L等。4、指令格式的设计还与如何选定指令中操作数地址的位数有关。例如,对同一容量(如64KB)的存储器(1)若取存储单元为一字节长,则需要16位地址码,(2)若存储单元长度为32位,则只需14位地址码。方案(1)对字符操作方便,但地址码位数多,方案(2)地址码位数少,很有利,但字符操作困难,分辩率低。(存储器分辩率:指存储器能被区分、识别与操作的精细程度),2023/11/17,第16页,5.2.2指令字长与扩展方法(1/3),一、操作码和地址
10、码间的权衡(操作码有两种编码格式)1、固定格式:操作码长度固定,且集中放在指令字的一个字段中。2、可变格式:即操作码长度可变,且分散地放在指令字的不同字段中。二、扩展操作码 1、要点:(1)操作码位数随地址码个数变化采取可变长度的类型;(2)指令间指令码一定不重复;(3)根据需要灵活变通。,2023/11/17,第17页,5.2.2指令字长与扩展方法(2/3),2、比较假设一台计算机指令字长16位,操作码与地址码都为4位,如图所示。(1)方法一:固定格式,则最多可以设计16条三地址指令,图10-3 阵列处理机结构,2023/11/17,第18页,5.2.2指令字长与扩展方法(3/3),(2)方
11、法二:扩展操作码,具体方法如下:A、4位OC中用0000-1110定义15条三地址指令,留编码1111作为扩展标志与下一个4位组成一个8位操作码,引出二地址指令,则:B、(a)若将AC1全部用作2地址指令的OC,能再定义16条2地址指令;(b)8位OC中用11110000-11111110定义15条二地址指令,剩下的一个编码11111111与下一个4位组成一个12位的操作码,引出一地址指令;(c)选1111000011111101共14条2地址指令,留11111110,11111111为扩展标志,再与AC2组合,以此类推。3、扩展操作码的另一个演变是用操作码中的某一位或几位来说明指令的格式与长
12、度,或是说明操作数的特征。例如:小型机PDP-11是用操作码最左边一位(最高位15位)来指明指令操作处理的数据字长度,当第15位=0,是字指令,操作数是16位长的字;当15位=1,是字节指令,操作数是8位长的字节。,2023/11/17,第19页,5.3 寻址方式(1/11),一、寻址方式的设计1、目的(1)丰富程序设计手段,提高程序质量;(2)减少访问主存的次数,压缩程序占用的存储空间。保证指令的地址码字段尽可能缩短,而访问的存储空间尽可能地大。2、概念(1)形式地址:指令中直接给出的地址;(2)有效地址:操作数所在的真实地址;(3)寻址方式:从形式地址生成有效地址的各种方式称为寻址方式。,
13、2023/11/17,第20页,5.3 寻址方式(2/11),3、寻址方式选用的依据(1)要与数据的表示方式相配合,对各种结构的数据能方便地进行存取和处理;(2)要与指令系统相匹配,依据对机器性能要求的高低来考虑选择;(3)还要考虑硬件实现的可能性与复杂程度,成本高低,设备与价格增加的合理性。4、区分寻址方式的方法(1)在指令中划出一个字段,用二进制编码来标志所采用的类型,此编码称寻址方式码;(2)使用隐含寻址方式,用操作码隐含寻址方式。,2023/11/17,第21页,1、隐含寻址,指令中隐含着操作数的地址如某些运算,隐含了累加器AC作为源和目的寄存器如8086汇编中的STC指令,设置标志寄
14、存器的C为1,2023/11/17,第22页,2、立即寻址,立即寻址是一种特殊的寻址方式,指令中在操作码字段后面的部分不是通常意义上的操作数地址,而是操作数本身,也就是说数据就包含在指令中,只要取出指令,就取出了可以立即使用的操作数,因此,这样的操作数被称为立即数。指令格式:操作码 操作数A,2023/11/17,第23页,2、立即寻址,特点:在取指令时,操作码和操作数被同时取出,不必再次访问存储器,从而提高了指令的执行速度。但是,因为操作数是指令的一部分,不能被修改;而且对于定 长指令格式,操作数的大小将受到指令长度的限制,所以这种寻址方式灵活性最差通常用于给某一寄存器或主存单元赋初值,或者
15、用于提供一个常数。,2023/11/17,第24页,3、直接寻址,指令中地址码字段给出的地址A就是操作数的有效地址EA(Effective Address),即EAA。,2023/11/17,第25页,3、直接寻址,操作数地址是不能修改的,与程序本身所在的位置无关,所以又叫做绝对寻址方式在早期的计算机中,主存储器的容量较小,指令中地址码的位数要求不长,采用直接寻址方式简单快速,也便于硬件实现,因此,常被作为主要的寻址方式。但在现代,随着计算机主存容量的不断扩大,所需的地址码将会越来越长。指令中地址码的位数将不能满足整个主存空间寻址的要求,因此直接寻址方式受到了很大的限制。另外,在指令的执行过程
16、中,为了取得操作数,必须进行访存操作,降低了指令的执行速度。,2023/11/17,第26页,4、间接寻址,间接寻址意味着指令的地址码部分给出的地址A不是操作数的地址,而是存放操作数地址的主存单元的地址,简称操作数地址的地址。操作数的有效地址的计算公式为:EA(A),2023/11/17,第27页,4、间接寻址,特点:因为操作数的有效地址在主存储器中,可以被灵活的修改而不必修改指令,从而使间接寻址要比直接寻址灵活得多。但是,间接寻址在指令执行过程中至少需要两次访问主存储器才能取出操作数,严重降低了指令执行的速度。,2023/11/17,第28页,5、寄存器寻址,在指令的地址码部分给出CPU内某
17、一通用寄存器的编号,指令的操作数存放在相应的寄存器中,即EA=Ri 优点:(1)由于寄存器在CPU的内部,指令在执行时从寄存器中取操作数比访问主存要快得多;(2)由于寄存器的数量较少,因此寄存器编号所占位数也较少,从而可以有效减少指令的地址码字段的长度。,2023/11/17,第29页,6、寄存器间接寻址,为了克服间接寻址中多次访存的缺点,可采用寄存器间接寻址,即将操作数放在主存储器中,而操作数的地址放在某一通用寄存器中,然后在指令的地址码部分给出该通用寄存器的编号,这时有EA=(Ri)这种寻址方式的指令较短,并且在取指后只需一次访存便可得到操作数,因此指令执行速度较前述的间接寻址方式要快,也
18、是目前在计算机中使用较为广泛的一种寻址方式。,2023/11/17,第30页,7、相对寻址,由程序计数器PC提供基准地址,而指令的地址码部分给出相对的位移量D,两者相加后作为操作数的有效地址,即:EA(PC)D。,2023/11/17,第31页,7、相对寻址,对寻址方式使程序模块可采用浮动地址,编程时只要确定程序内部操作数与指令之间的相对距离,而无需确定操作数在主存储器中的绝对地址,这样,将程序安排在主存储器的任意位置都不会影响程序执行的正确性。,2023/11/17,第32页,8、基址寻址,在基址寻址方式中,指令的地址码部分给出偏移量D,而基准地址放在基址寄存器Rb中,最后操作数的有效地址仍
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 组成 原理 第五 课件

链接地址:https://www.31ppt.com/p-6606695.html