1、计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第1页第第5章章 指令系统指令系统计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社教学目标教学重点教学过程计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第2页教学目标教学目标l了解指令系统的发展与性能要求了解指令系统的发展与性能要求l掌握指令格式和寻址方式掌握指令格式和寻址方式计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第3页教学重点教学重点l指令格式指令格式l扩展操作码扩展操作码l寻址
2、方式寻址方式计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第4页教学过程教学过程l5.1 计算机的指令系统的发展与性能计算机的指令系统的发展与性能l5.2 指令的格式指令的格式l5.3 寻址方式寻址方式l5.4 指令的分类与高级语言指令的分类与高级语言l5.5 典型指令系统典型指令系统l5.6 例题解析例题解析计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第5页5.1计算机计算机的的指令系统指令系统的的发展发展与与性能性能l指令系统决定了计算机的基本功能,指令系统的设计是计算机系统设计指令系统决定了计算
3、机的基本功能,指令系统的设计是计算机系统设计的一个核心问题。它不仅与计算机的硬件设计紧密相关,而且直接影响的一个核心问题。它不仅与计算机的硬件设计紧密相关,而且直接影响到系统软件设计的难易程度到系统软件设计的难易程度。l完善的计算机的指令系统应具备:完善的计算机的指令系统应具备:1、完备性:完备性:一台计算机中最基本的、必不可少的指令构成了指令系统的完一台计算机中最基本的、必不可少的指令构成了指令系统的完备性。备性。2、有效性:有效性:指利用该指令系统所提供的指令编制的程序能够产生高效率。指利用该指令系统所提供的指令编制的程序能够产生高效率。高效率主要表现在空间和时间方面,即占用存储空间小、执
4、行速度快。高效率主要表现在空间和时间方面,即占用存储空间小、执行速度快。3、规整性:规整性:指令操作的对称性和匀齐性,指令格式与数据格式的一致性。指令操作的对称性和匀齐性,指令格式与数据格式的一致性。(1)对称性:在指令系统中,所有寄存器和存储单元都可同等对待,这对)对称性:在指令系统中,所有寄存器和存储单元都可同等对待,这对简化程序设计,提高程序的可读性非常有用。简化程序设计,提高程序的可读性非常有用。(2)匀齐性:是指一种操作性质的指令可以支持各种数据类型。)匀齐性:是指一种操作性质的指令可以支持各种数据类型。(3)指令的格式与数据格式的一致性:指令长度与数据长度有一定关系,)指令的格式与
5、数据格式的一致性:指令长度与数据长度有一定关系,以方便存取和处理。以方便存取和处理。4、兼容性:兼容性:兼容性一般是指计算机的体系结构设计基本相同,机器之间具兼容性一般是指计算机的体系结构设计基本相同,机器之间具有相同的基本结构、数据表示和共同的基本指令集合。有相同的基本结构、数据表示和共同的基本指令集合。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第6页5.2指令指令的的格式格式l计算机的指令格式与机器的字长、存储器的容量及指令的计算机的指令格式与机器的字长、存储器的容量及指令的功能密切相关。功能密切相关。计算机组成原理计算机组成原理(第二版第
6、二版)清华大学出版社清华大学出版社2023年1月26日第7页5.2.1指令操作指令操作码与码与地址地址码码(1/9)l两个字段:操作码字段两个字段:操作码字段+操作数地址字段:操作数地址字段:1.操作码操作码操作码是指明指令操作性质的命令码。它提供指令的操作控制信息。操作码是指明指令操作性质的命令码。它提供指令的操作控制信息。(1)每条指令都要求它的操作码必须是独一无二的位组合。)每条指令都要求它的操作码必须是独一无二的位组合。(2)指令系统中指令的个数)指令系统中指令的个数N与操作码的位数与操作码的位数n,必须满足关系式:,必须满足关系式:N2n2.操作数地址码操作数地址码(1)地址码:用来
7、描述该指令的操作对象。)地址码:用来描述该指令的操作对象。(2)指令字长)指令字长=操作码的位数操作码的位数+(操作数地址个数操作数地址个数)*(操作数地址码位数操作数地址码位数)地址码字段AC操作码字段OC计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第8页5.2.1指令操作指令操作码与码与地址地址码码(2/9)一、指令格式一、指令格式1.零地址指令格式零地址指令格式这是一种没有操作数地址部分的指令格式。这是一种没有操作数地址部分的指令格式。这种指令有两种可能:这种指令有两种可能:(1)无需任何操作数。如空操作指令,停机指令)无需任何操作数。如空
8、操作指令,停机指令等。等。(2)所需的操作数是默认的:堆栈。)所需的操作数是默认的:堆栈。操作码OC计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第9页5.2.1指令操作指令操作码与码与地址地址码码(3/9)A、堆栈的概念、堆栈的概念 (a)是若干个存储单元)是若干个存储单元(或寄存器或寄存器)的有序集合,它顺序地存放一组元的有序集合,它顺序地存放一组元素。素。(b)数据的存取都只能在栈顶单元内进行,即数据的进栈与出栈都只)数据的存取都只能在栈顶单元内进行,即数据的进栈与出栈都只能经过栈顶单元这个能经过栈顶单元这个“出入口出入口”。(c)堆栈中的数
9、据采用)堆栈中的数据采用“先进后出先进后出”或或“后进先出后进先出”的存取工作方式。的存取工作方式。B、堆栈结构在计算机中的作用堆栈结构在计算机中的作用 (a)具有堆栈结构的机器使用零地址指令,这不仅合指令长度短,指)具有堆栈结构的机器使用零地址指令,这不仅合指令长度短,指令结构简单,机器硬件简化。令结构简单,机器硬件简化。(b)实现程序调用,子程序嵌套调用和递归调用。)实现程序调用,子程序嵌套调用和递归调用。(c)对于)对于“中断中断”技术,堆栈更是不可缺少的,保存技术,堆栈更是不可缺少的,保存“断点断点”和和“现现场场”。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出
10、版社2023年1月26日第10页5.2.1指令操作指令操作码与码与地址地址码码(4/9)C、堆栈的操作、堆栈的操作设数据进栈方向为从高地址向低地址发展,当向堆栈设数据进栈方向为从高地址向低地址发展,当向堆栈压入数据时,压入数据时,SP的内容先自动递减而指向一个新的空栈的内容先自动递减而指向一个新的空栈顶单元,再把数据写入此栈顶单元;当数据弹出堆栈时,顶单元,再把数据写入此栈顶单元;当数据弹出堆栈时,立即读出立即读出SP所指向的栈顶单元内容,再把所指向的栈顶单元内容,再把SP内容自动递内容自动递增而指向新的栈顶位置。即增而指向新的栈顶位置。即 PUSH X;(SP)-1SP (X)(SP)POP
11、 X;(SP)X (SP)+1SP计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第11页5.2.1指令操作指令操作码与码与地址地址码码(5/9)2.一地址指令格式一地址指令格式(1)指令中给出的一个地址即是操作数的地址,又是操作)指令中给出的一个地址即是操作数的地址,又是操作结果的存储地址。如加结果的存储地址。如加1、减、减1、移位等单操作数指令。、移位等单操作数指令。(2)在某些计算机中,指令中提供的一个地址提供一个操)在某些计算机中,指令中提供的一个地址提供一个操作数,另一个操作数是由机内硬件寄存器作数,另一个操作数是由机内硬件寄存器“隐含隐含
12、”地自动地自动提供的。所谓提供的。所谓“隐含隐含”是指此操作数在指令中不出现,而是指此操作数在指令中不出现,而是按照事先约定由寄存器默认提供,运算结果仍送到寄存是按照事先约定由寄存器默认提供,运算结果仍送到寄存器中。因为这个寄存器在连续运算时,保存着多条指令连器中。因为这个寄存器在连续运算时,保存着多条指令连续操作的累计结果,故称为累加器续操作的累计结果,故称为累加器(AC)。AC1操作码OC计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第12页5.2.1指令操作指令操作码与码与地址地址码码(6/9)3.二地址指令格式二地址指令格式 (1)把保存操
13、作前原来操作数的地址称为源点地址)把保存操作前原来操作数的地址称为源点地址(SS),把保存指令,把保存指令执行结果的地址称为终点地址或目的地址执行结果的地址称为终点地址或目的地址(DD)。(2)将源点与终点操作数进行操作码规定的操作后,将结果存入终点将源点与终点操作数进行操作码规定的操作后,将结果存入终点地址。通常二地址指令又称为双操作数指令。地址。通常二地址指令又称为双操作数指令。例如,双操作数加法指令:例如,双操作数加法指令:ADD R0,R1表示将表示将R0寄存器的内容和寄存器的内容和R1寄存器的内容相加以后,将寄存器的内容相加以后,将结果存入结果存入R1寄存器中。寄存器中。又如又如AD
14、D (R0),R1表示将表示将R0寄存器的内容作为地址,到内存中取出寄存器的内容作为地址,到内存中取出该地址所指向的单元内容作为源点操作数,和作为终点操作数的该地址所指向的单元内容作为源点操作数,和作为终点操作数的R1寄寄存器的内容相加以后,将结果存入存器的内容相加以后,将结果存入R1寄存器中。寄存器中。AC1操作码OCAC2计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第13页5.2.1指令操作指令操作码与码与地址地址码码(7/9)4.三地址指令格式三地址指令格式其操作是对其操作是对AC1、AC2指出的两个操作数进指出的两个操作数进行操作码所规定
15、的操作,并将结果存入行操作码所规定的操作,并将结果存入AC3中。中。例如:例如:ADD X Y Z 含义为含义为 (X)+(Y)Z 即即X单元内容加上单元内容加上Y单元内容,单元内容,结果送结果送Z单元中。单元中。AC1操作码OCAC3AC2计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第14页5.2.1指令操作指令操作码与码与地址地址码码(8/9)5.多地址指令格式多地址指令格式例如四地址指令格式。例如四地址指令格式。(1)含义:)含义:ADD X Y Z WA、(、(X)+(Y)ZB、(、(W)下一条指令地址下一条指令地址(2)特点:)特点:A
16、、直观明了;、直观明了;B、程序执行的流向明确;、程序执行的流向明确;C、操作数和结果可以分散在内存各处。、操作数和结果可以分散在内存各处。D、但是指令字长度太长。、但是指令字长度太长。AC1操作码OCAC4AC3AC2计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第15页5.2.1指令操作指令操作码与码与地址地址码码(9/9)l指令格式设计准则指令格式设计准则 1、指令字长要短,以得到时间和空间上的优势。、指令字长要短,以得到时间和空间上的优势。2、指令字长必须有足够的长度。、指令字长必须有足够的长度。3、指令字长一般应是机器字符长度的整数倍以便
17、存储系统的管理。、指令字长一般应是机器字符长度的整数倍以便存储系统的管理。若机器中字符码长是若机器中字符码长是L位,则机器字长最好是位,则机器字长最好是L,2L,4L,8L等。等。4、指令格式的设计还与如何选定指令中操作数地址的位数有关。、指令格式的设计还与如何选定指令中操作数地址的位数有关。l例如,对同一容量例如,对同一容量(如如64KB)的存储器的存储器 (1)若取存储单元为一字节长,则需要)若取存储单元为一字节长,则需要16位地址码,位地址码,(2)若存储单元长度为)若存储单元长度为32位,则只需位,则只需14位地址码。位地址码。方案(方案(1)对字符操作方便,但地址码位数多,)对字符操
18、作方便,但地址码位数多,方案(方案(2)地址码位数少,很有利,但字符操作困难,分辩率低。)地址码位数少,很有利,但字符操作困难,分辩率低。(存储器分辩率:指存储器能被区分、识别与操作的精细程度)(存储器分辩率:指存储器能被区分、识别与操作的精细程度)计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第16页5.2.2指令指令字长与字长与扩展扩展方法方法(1/3)一、操作码和地址码间的权衡(操作码有两种编码格式)一、操作码和地址码间的权衡(操作码有两种编码格式)1、固定格式:操作码长度固定,且集中放在指令字的一、固定格式:操作码长度固定,且集中放在指令字
19、的一个字段中。个字段中。2、可变格式:即操作码长度可变,且分散地放在指令字、可变格式:即操作码长度可变,且分散地放在指令字的不同字段中。的不同字段中。二、扩展操作码二、扩展操作码 1、要点:、要点:(1)操作码位数随地址码个数变化采取可变长度的)操作码位数随地址码个数变化采取可变长度的类型;类型;(2)指令间指令码一定不重复;)指令间指令码一定不重复;(3)根据需要灵活变通。)根据需要灵活变通。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第17页5.2.2指令指令字长与字长与扩展扩展方法方法(2/3)2、比较、比较假设一台计算机指令字长假设一台计
20、算机指令字长16位,操作码位,操作码与地址码都为与地址码都为4位,如图所示。位,如图所示。(1)方法一:固定格式,则最多可以设计)方法一:固定格式,则最多可以设计16条三地址指令条三地址指令图10-3 阵列处理机结构AC1操作码OCAC3AC2计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第18页5.2.2指令指令字长与字长与扩展扩展方法方法(3/3)(2)方法二:扩展操作码,具体方法如下:)方法二:扩展操作码,具体方法如下:A、4位位OC中用中用0000-1110定义定义15条三地址指令,留编码条三地址指令,留编码1111作为扩展标志作为扩展标志
21、与下一个与下一个4位组成一个位组成一个8位操作码,引出二地址指令,则:位操作码,引出二地址指令,则:B、(、(a)若将)若将AC1全部用作全部用作2地址指令的地址指令的OC,能再定义,能再定义16条条2地址指令;地址指令;(b)8位位OC中用中用11110000-11111110定义定义15条二地址指令,剩下的一个条二地址指令,剩下的一个编码编码11111111与下一个与下一个4位组成一个位组成一个12位的操作码,引出一地址指令;位的操作码,引出一地址指令;(c)选)选1111000011111101共共14条条2地址指令,留地址指令,留11111110,11111111为扩展标志,再与为扩展
22、标志,再与AC2组合,以此类推。组合,以此类推。C、若选、若选B(c),则可定义),则可定义31条条1地址指令,留一个编码地址指令,留一个编码111111111111为扩展为扩展标志,与下一个标志,与下一个4位组成位组成16位操作码,引出位操作码,引出16条零地址指令;条零地址指令;3、扩展操作码的另一个演变是用操作码中的某一位或几位来说明指令的格式与、扩展操作码的另一个演变是用操作码中的某一位或几位来说明指令的格式与长度,或是说明操作数的特征。长度,或是说明操作数的特征。例如:小型机例如:小型机PDP-11是用操作码最左边一位是用操作码最左边一位(最高位最高位15位位)来指明指令操作处来指明
23、指令操作处理的数据字长度,当第理的数据字长度,当第15位位=0,是字指令,操作数是,是字指令,操作数是16位长的字;当位长的字;当15位位=1,是字节指令,操作数是,是字节指令,操作数是8位长的字节。位长的字节。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第19页5.3 寻址方式寻址方式(1/11)一、寻址方式的设计一、寻址方式的设计1、目的、目的 (1)丰富程序设计手段,提高程序质量;丰富程序设计手段,提高程序质量;(2)减少访问主存的次数,压缩程序占用的存储空间。保证减少访问主存的次数,压缩程序占用的存储空间。保证指令的地址码字段尽可能缩短,
24、而访问的存储空间尽可能指令的地址码字段尽可能缩短,而访问的存储空间尽可能地大。地大。2、概念概念(1)形式地址:指令中直接给出的地址;)形式地址:指令中直接给出的地址;(2)有效地址:操作数所在的真实地址;)有效地址:操作数所在的真实地址;(3)寻址方式:从形式地址生成有效地址的各种方式称为)寻址方式:从形式地址生成有效地址的各种方式称为寻址方式。寻址方式。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第20页5.3 寻址方式寻址方式(2/11)3、寻址方式选用的依据、寻址方式选用的依据(1)要与数据的表示方式相配合,对各种结构的数据能方)要与数据
25、的表示方式相配合,对各种结构的数据能方便地进行存取和处理;便地进行存取和处理;(2)要与指令系统相匹配,依据对机器性能要求的高低来)要与指令系统相匹配,依据对机器性能要求的高低来考虑选择;考虑选择;(3)还要考虑硬件实现的可能性与复杂程度,成本高低,)还要考虑硬件实现的可能性与复杂程度,成本高低,设备与价格增加的合理性。设备与价格增加的合理性。4、区分寻址方式的方法、区分寻址方式的方法(1)在指令中划出一个字段,用二进制编码来标志所采用在指令中划出一个字段,用二进制编码来标志所采用的类型,此编码称寻址方式码;的类型,此编码称寻址方式码;(2)使用隐含寻址方式,用操作码隐含寻址方式。)使用隐含寻
26、址方式,用操作码隐含寻址方式。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第21页5.3 寻址方式寻址方式(3/11)二、常用的寻址方式二、常用的寻址方式 1、立即寻址方式、立即寻址方式(1)含义:地址字段给出的是可以立即使用的操作数实际)含义:地址字段给出的是可以立即使用的操作数实际值,称立即寻址方式。值,称立即寻址方式。(2)优缺点:)优缺点:A、优点:提供操作数最快、优点:提供操作数最快 B、缺点:精度较低,可采用变字长格式解决。、缺点:精度较低,可采用变字长格式解决。例如:在例如:在IBM-PC指令系统中指令系统中 MOVAX,05FFH
27、计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第22页5.3 寻址方式寻址方式(4/11)2、直接寻址方式、直接寻址方式(1)含义:地址字段直接指明操作数在存储器内)含义:地址字段直接指明操作数在存储器内的位置的寻址方法。即形式地址等于有效地址,的位置的寻址方法。即形式地址等于有效地址,(2)缺点:直接寻址方式中指令字长限制了一条)缺点:直接寻址方式中指令字长限制了一条指令所能够访问的最大主存空间,可以使用可变指令所能够访问的最大主存空间,可以使用可变字长指令格式来解决此局限性。利用扩大了的操字长指令格式来解决此局限性。利用扩大了的操作数地址码就能
28、全部访问主存储器的所有的存储作数地址码就能全部访问主存储器的所有的存储单元。单元。例如:在例如:在IBM-PC指令系统中指令系统中MOV AX,3000H计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第23页5.3 寻址方式寻址方式(5/11)3、间接寻址方式、间接寻址方式(1)含义:指令字中地址码字段给出的不是操作数地址,而是操作数地址)含义:指令字中地址码字段给出的不是操作数地址,而是操作数地址的地址。的地址。(2)优缺点:)优缺点:A、优点:实现简便,对编程带来较大的、优点:实现简便,对编程带来较大的灵活性,灵活性,灵活性表现在:灵活性表现在
29、:间接寻址方式的指令可以访问大的存储空间,扩大了指令的寻址间接寻址方式的指令可以访问大的存储空间,扩大了指令的寻址能力。能力。当操作数地址改变时,只需修改间接地址指示器的单元内容,而当操作数地址改变时,只需修改间接地址指示器的单元内容,而不必修改指令,原指令的功能照样实现。这给程序编制带来很大不必修改指令,原指令的功能照样实现。这给程序编制带来很大方便。方便。B、缺点:、缺点:多次访问内存,增加了指令的执行时间;多次访问内存,增加了指令的执行时间;占用主存储器单元多。占用主存储器单元多。(3)间接寻址可分为一级间接寻址和多级间接寻址。)间接寻址可分为一级间接寻址和多级间接寻址。例如:在例如:在
30、IBM-PC指令系统中指令系统中 MOV AX,BX计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第24页5.3 寻址方式寻址方式(6/11)4、变址寻址方式、变址寻址方式 (1)含义:把指令字中的形式地址)含义:把指令字中的形式地址A与地址修改量与地址修改量X自动自动相加,相加,X可正可负,形成操作数的有效地址可正可负,形成操作数的有效地址EA。即:。即:EA=A+X。其中,与形式地址相加的数。其中,与形式地址相加的数X是一个地址修改是一个地址修改量,称为量,称为“变址值变址值”,保存变址值的设备称为变址器。,保存变址值的设备称为变址器。(2)硬
31、件开销:)硬件开销:A、变址器变址器 B、有效地址形成逻辑有效地址形成逻辑例如:在例如:在IBM-PC指令系统中指令系统中MOV AX,COUNTSI计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第25页5.3 寻址方式寻址方式(7/11)5、基址寻址方式、基址寻址方式(1)含义:)含义:EA=A+X。其中,。其中,X是基址是基址R,A是偏移量。是偏移量。(2)与变址寻址的区别:)与变址寻址的区别:基址基址R,用户程序无权操作和修改,由系,用户程序无权操作和修改,由系统软件管理控制程序使用特权指令来管理的。统软件管理控制程序使用特权指令来管理的。(
32、3)基址寻址方式主要用以解决程序在存储)基址寻址方式主要用以解决程序在存储器中的定位和扩大寻址空间等问题。器中的定位和扩大寻址空间等问题。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第26页5.3 寻址方式寻址方式(8/11)6、相对寻址方式、相对寻址方式 (1)含义:把程序计数器)含义:把程序计数器PC作为基本地址寄存作为基本地址寄存器,指令字中的形式地址码作为位移量,则有效器,指令字中的形式地址码作为位移量,则有效地址地址EA=(PC)+A。相对寻址主要用于转移指令。相对寻址主要用于转移指令。(2)特点:)特点:(A)位移量可正、可负,通常用
33、补码表示。若位)位移量可正、可负,通常用补码表示。若位移量为移量为n位,正向有位,正向有2n-1-1个位置,负向有个位置,负向有2n-1个位个位置,程序可以直接访问的实际存储空间是置,程序可以直接访问的实际存储空间是2n个位个位置的小块,或称为一页。置的小块,或称为一页。(B)位移量是操作数位置与本指令之间的相对距)位移量是操作数位置与本指令之间的相对距离。离。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第27页5.3 寻址方式寻址方式(9/11)7、寄存器寻址方式、寄存器寻址方式 (1)含义:把指令字中的地址码用寄存器编号来代替,寄存器的作)含
34、义:把指令字中的地址码用寄存器编号来代替,寄存器的作用由寻址方式码来指定。用由寻址方式码来指定。(2)优点:)优点:A、有效压缩指令字长有效压缩指令字长 B、加快存取速度加快存取速度 C、编程灵活编程灵活(3)寄存器寻址方式的变化:)寄存器寻址方式的变化:A、寄存器直接寻址方式、寄存器直接寻址方式 例如在例如在PDP-11机中:机中:ADD R0,R1 B、寄存器间接寻址方式、寄存器间接寻址方式 例如在例如在PDP-11机中:机中:ADD R0,R1 又如在又如在PDP-11机中:机中:ADD R0,R1计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26
35、日第28页5.3 寻址方式寻址方式(10/11)8、复合寻址方式:、复合寻址方式:(A)变址间址寻址方式变址间址寻址方式其含义是先将变址寄存器的内容其含义是先将变址寄存器的内容X和形式地址和形式地址A相加得到相加得到A+X,然后再作间接寻址,得到操作数的有效地址。故操作数的有效地址为:然后再作间接寻址,得到操作数的有效地址。故操作数的有效地址为:EA=(A+X)(B)间址变址寻址方式间址变址寻址方式含义是先将形式地址取间接变换(含义是先将形式地址取间接变换(A)=N,然后把,然后把N和变址寄存和变址寄存器的内容器的内容X相加,得到操作数的有效地址。故操作数的有效地址为:相加,得到操作数的有效地
36、址。故操作数的有效地址为:EA=N+X=(A)+X (C)Intel 8086/8088中基址变址寻址方式中基址变址寻址方式基址寄存器可以采用基址寄存器可以采用BX或或BP,变址寄存器可以用,变址寄存器可以用SI或或DI,有效,有效地址是通过将基址寄存器中的值、变址寄存器中的值和位移量三这相地址是通过将基址寄存器中的值、变址寄存器中的值和位移量三这相加而求得的。加而求得的。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第29页5.3 寻址方式寻址方式(11/11)8、复合寻址方式:、复合寻址方式:(D)分页寻址方式)分页寻址方式若计算机中欲采用直接
37、寻址方式,但由于其访问的内存地若计算机中欲采用直接寻址方式,但由于其访问的内存地址空间受指令中地址码字段长度的制约,若内存空间较大,则址空间受指令中地址码字段长度的制约,若内存空间较大,则可采用分页寻址方式来解决。将指令中操作数地址码可以访问可采用分页寻址方式来解决。将指令中操作数地址码可以访问到的内存地址空间称为一页,则整个内存空间可以按页的大小到的内存地址空间称为一页,则整个内存空间可以按页的大小分为多个页面。分为多个页面。例如设内存储器容量为例如设内存储器容量为64K个单元,而指令中地址码长度个单元,而指令中地址码长度为为9位,则每一页有位,则每一页有512个单元,可将内存空间划分为个单
38、元,可将内存空间划分为64K/512=128页。为访问页。为访问128页,需要页,需要7位代码来表示页号。若位代码来表示页号。若预先将页号送入页号寄存器,把页号寄存器的内容与指令寄存预先将页号送入页号寄存器,把页号寄存器的内容与指令寄存器中形式地址两者拼接起来,就能获得一个可以访问整个内存器中形式地址两者拼接起来,就能获得一个可以访问整个内存空间的有效地址。空间的有效地址。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第30页5.4 指令指令的的分类分类与与高级语言高级语言l5.4.1 指令系统的分类指令系统的分类l5.4.2 指令系统指令系统与与
39、高级语言高级语言计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第31页5.4.1 指令系统指令系统的的分类分类(1/9)1.数据传送类指令数据传送类指令寄存器至寄存器(寄存器至寄存器(R-R:Register-Register)存储器至寄存器(存储器至寄存器(S-R:Storage-Register)寄存器至存储器(寄存器至存储器(R-S::Register-Storage)存储器至存储器(存储器至存储器(S-S:Storage-Storage)计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第32页5.
40、4.1 指令系统指令系统的的分类分类(2/9)2.运算运算类类指令指令 加法,减法,乘法和除法等指令。加法,减法,乘法和除法等指令。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第33页5.4.1 指令系统指令系统的的分类分类(3/9)3.逻辑运算指令逻辑运算指令 逻辑运算主要是对布尔变量的运算。逻辑运算主要是对布尔变量的运算。基本操作:包括逻辑与,逻辑或与逻辑非基本操作:包括逻辑与,逻辑或与逻辑非3种基本操作;种基本操作;组合逻辑操作:例如:异或。组合逻辑操作:例如:异或。(1)逻辑与指令:)逻辑与指令:(2)逻辑或指令:)逻辑或指令:(3)逻辑
41、非指令:)逻辑非指令:(4)逻辑异或指令:)逻辑异或指令:算术逻辑运算指令除了给出运算结果外,往往还要给出算术逻辑运算指令除了给出运算结果外,往往还要给出某些状态信息。如运算结果的正、负;运算结果是否为零;某些状态信息。如运算结果的正、负;运算结果是否为零;是否有溢出;是否有低位向高位的进位等,供其它指令或程是否有溢出;是否有低位向高位的进位等,供其它指令或程序分析时使用。序分析时使用。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第34页5.4.1 指令系统指令系统的的分类分类(4/9)4.移位指令移位指令l算术移位:左移或右移(右移时符号位不变
42、)算术移位:左移或右移(右移时符号位不变)l逻辑移位:左移或右移(右移时符号位补逻辑移位:左移或右移(右移时符号位补0)l循环移位:左移或右移。循环移位:左移或右移。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第35页5.4.1 指令系统指令系统的的分类分类(5/9)5.程序控制类指令程序控制类指令(1)转移指令:)转移指令:包括无条件转移指令和条件转移指令。包括无条件转移指令和条件转移指令。(2)转子与返回指令:)转子与返回指令:子程序是一组可以共享的指令序列,可被主程序调用执行。转子程序是一组可以共享的指令序列,可被主程序调用执行。转子指令与
43、转移指令之间最大的差别在于:转移指令无需返回,而转子子指令与转移指令之间最大的差别在于:转移指令无需返回,而转子指令则需要。指令则需要。子程序调用指令就是用来调用子程序的。为了能够从子程序中子程序调用指令就是用来调用子程序的。为了能够从子程序中正确返回到断点继续执行,并能支持多重嵌套和递归调用,现代计算正确返回到断点继续执行,并能支持多重嵌套和递归调用,现代计算机通常用堆栈来保存返回地址。机通常用堆栈来保存返回地址。(3)程序中断指令:)程序中断指令:中断一般是计算机系统出现异常情况或特殊请求时随机产生的。中断一般是计算机系统出现异常情况或特殊请求时随机产生的。一般在计算机中,中断指令作为隐指
44、令不提供用户使用。但在某些计一般在计算机中,中断指令作为隐指令不提供用户使用。但在某些计算机中设置了可供用户使用的中断指令,以实现系统功能调用和程序算机中设置了可供用户使用的中断指令,以实现系统功能调用和程序请求。如请求。如IBM PC的中断指令,的中断指令,PDP-11的自陷指令等。的自陷指令等。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第36页5.4.1 指令系统指令系统的的分类分类(6/9)6.输入输出类指令输入输出类指令 用来处理机与外部设备之间进行通信的一类用来处理机与外部设备之间进行通信的一类指令。以处理机为基准,信息由外部设备传向
45、处指令。以处理机为基准,信息由外部设备传向处理机称为输入理机称为输入(Input),信息由处理机传给外部设,信息由处理机传给外部设备称为输出备称为输出(Output)。一元化总线的计算机如一元化总线的计算机如PDP-11,不需设置专,不需设置专门的门的I/O指令,可以用一般的数据传送类指令实现指令,可以用一般的数据传送类指令实现输入和输出;输入和输出;对于主存和外设不采用统一编址技术的计算对于主存和外设不采用统一编址技术的计算机来说,则需要有专门的机来说,则需要有专门的I/O指令,如指令,如IBM PC就就是一个典型的例子。是一个典型的例子。计算机组成原理计算机组成原理(第二版第二版)清华大学
46、出版社清华大学出版社2023年1月26日第37页5.4.1 指令系统指令系统的的分类分类(7/9)7.字符串处理指令字符串处理指令 非数值处理能力;非数值处理能力;字符串处理指令一般包括字符串传送、比字符串处理指令一般包括字符串传送、比较、查询、转换等指令。较、查询、转换等指令。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第38页5.4.1 指令系统指令系统的的分类分类(8/9)8.处理机控制类指令处理机控制类指令 包括停机指令、等待指令、空操作指令、包括停机指令、等待指令、空操作指令、开中断指令、关中断指令、设置条件码指开中断指令、关中断指令、
47、设置条件码指令等。令等。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第39页5.4.1 指令系统指令系统的的分类分类(9/9)9.特权指令特权指令 这类指令只能用于操作系统或其它系统软件,而这类指令只能用于操作系统或其它系统软件,而不提供给用户使用,称特权指令。不提供给用户使用,称特权指令。一般来说,在单用户、单任务的计算机中不一般来说,在单用户、单任务的计算机中不一定需要特权指令,而在多用户、多任务的计算一定需要特权指令,而在多用户、多任务的计算机系统中,特权指令却是必不可少的。它主要用机系统中,特权指令却是必不可少的。它主要用于系统资源的分配
48、和管理,包括改变系统的工作于系统资源的分配和管理,包括改变系统的工作方式、检测用户的访问权限、修改虚拟存储器管方式、检测用户的访问权限、修改虚拟存储器管理的段表、页表和完成任务的创建和切换等。理的段表、页表和完成任务的创建和切换等。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第40页5.4.2 指令系统指令系统与与高级语言高级语言(1/2)1、传统的冯、传统的冯 诺依曼计算机的机器语言和高级程序设计语言诺依曼计算机的机器语言和高级程序设计语言在语义上的差别的主要原因在语义上的差别的主要原因(1)存储器组织方式不同)存储器组织方式不同 冯冯 诺依曼
49、计算机的存储器是一维的线性结构,而高级程诺依曼计算机的存储器是一维的线性结构,而高级程序设计语言表示的存储器则是一组变量,访问时调用变量序设计语言表示的存储器则是一组变量,访问时调用变量即可,不必考虑访问方法,而且数据结构经常是多维的,即可,不必考虑访问方法,而且数据结构经常是多维的,如数组结构。如数组结构。(2)高级程序设计语言中,高级语言中的每种操作对于任)高级程序设计语言中,高级语言中的每种操作对于任何数据类型都是通用的,数据类型直接属于数据本身,而何数据类型都是通用的,数据类型直接属于数据本身,而冯冯 诺依曼计算机的数据本身没有属性标志,同一种操作诺依曼计算机的数据本身没有属性标志,同
50、一种操作要用不同的操作码来对数据类型进行区分。要用不同的操作码来对数据类型进行区分。这些差别间的变换工作,主要由编译程序来承担。这些差别间的变换工作,主要由编译程序来承担。计算机组成原理计算机组成原理(第二版第二版)清华大学出版社清华大学出版社2023年1月26日第41页5.4.2 指令系统指令系统与与高级语言高级语言(2/2)2、计算机指令结构分类、计算机指令结构分类两大类:两大类:(1)复杂指令集计算机(复杂指令集计算机(CISC:Complex Instruction Set Computer)指令系统十分庞大,指令类型、寻址方式较多,机器语言指令系统十分庞大,指令类型、寻址方式较多,机