第4章指令系统

上传人:工**** 文档编号:578412320 上传时间:2024-08-24 格式:PPT 页数:82 大小:463.50KB
返回 下载 相关 举报
第4章指令系统_第1页
第1页 / 共82页
第4章指令系统_第2页
第2页 / 共82页
第4章指令系统_第3页
第3页 / 共82页
第4章指令系统_第4页
第4页 / 共82页
第4章指令系统_第5页
第5页 / 共82页
点击查看更多>>
资源描述

《第4章指令系统》由会员分享,可在线阅读,更多相关《第4章指令系统(82页珍藏版)》请在金锄头文库上搜索。

1、第4章指令系统第4章指令系统4.1指令格式4.2寻址方式4.3指令类型4.4复杂指令系统计算机和精简指令系统计算机4.5指令系统举例1第4章指令系统4.1指令格式4.1.1指令四要素4.1.2指令的地址数目4.1.3指令的操作码4.1.4指令长度2第4章指令系统4.1.1指令四要素1)操作码表征指令的操作特性与功能。n2n2)源操作数地址通过该地址取得所需的操作数。来源:寄存器组、主存或虚存、I/O设备3)目的操作数地址指出指令的操作结果被存放的地方。4)下一条指令的地址顺序执行:隐含(PC)+1PC改变执行顺序:显式指出3第4章指令系统4.1.2指令的地址数目n根据地址码部分所给出地址的个数

2、可分为:零地址指令、一地址指令、二地址指令、三地址指令、多地址指令1)零地址指令只有操作码,而没有地址码无需任何操作数操作数是隐含的操作码4第4章指令系统2)一地址指令单操作数指令隐含第二操作数,如:()()5第4章指令系统3)二地址指令双操作数指令()()()进一步分类为MMRRRM6第4章指令系统4)三地址指令()()5)多地址指令用于处理成批数据7第4章指令系统4.1.3指令的操作码1)指令操作码的两种编码方式定长编码(固定格式)操作码长度固定,且集中放在指令字的一个字段中。变长编码(可变格式)操作码的长度可变,且分散地放在指令字的不同字段中。8第4章指令系统2)可变格式指令的扩展技术指

3、令字中用一个固定长度的字段表示基本操作码,对于不需要某个地址码的指令,可将操作码扩充到地址码字段。例如:某机器的指令长度为16位,其中4位基本操作码字段,3个4位地址码字段,采用操作码扩展技术可以形成多于16条指令。9第4章指令系统一种扩展方法如下:15条三地址指令,操作码0000111015条二地址指令,操作码111100001111111015条一地址指令,操作码11111111000011111111111016条一地址指令,操作码11111111111100001111111111111111共61条10第4章指令系统例题:假设某计算机指令长度为20位,具有二地址指令、一地址指令、零地

4、址指令三类指令形式,在此情况下,这台计算机地址规定用6位表示,问:(1)若操作码字段固定为8位,现已设计出m条二地址指令,n条零地址指令,在此情况下,这台计算机最多可以设计出多少条一地址指令?(2)当二地址指令条数取最大值,且此基础上一地址指令条数也取最大值时,计算这台计算机最多指令数是多少?11第4章指令系统答:(1)由于操作码的位数决定了指令系统的规模及指令的性质。所以一地址指令的条数:28-m-n=256-m-n(2)应为255+63+64=382条。12第4章指令系统4.1.4指令长度1)指令长度与机器字长的关系机器字长是指计算机能直接处理的二进制数据的位数,它决定了计算机的运算精度。

5、指令长度一条指令中包含二进制代码的位数。单字长指令、半字长指令、双字长指令使用多字长指令的目的提供足够的地址位来解决访问主存任何单元的寻址问题。13第4章指令系统2)等长指令字结构、变长指令字结构等长指令字结构所有指令的长度都是相等的。指令字结构简单,指令译码和流水线执行较容易。变长指令字结构指令字长度随指令功能而异。指令字结构灵活,能缩短指令的平均长度,但指令的控制较复杂。14第4章指令系统4.2寻址方式n形成操作数或指令地址的方式,称为寻址方式。n寻址方式分为两类指令寻址方式操作数寻址方式n指令寻址方式顺序寻址方式跳跃寻址方式15第4章指令系统n操作数的寻址方式指令中地址码字段一般是由形式

6、地址和寻址方式特征位(或字段)组成,并不是操作数的有效地址(实际地址)。所谓操作数的寻址方式,就是形成操作数的有效地址(EA)的方法。16第4章指令系统n确定一台计算机系统的寻址方式,必须综合考虑以下几点:指令内包含的地址尽量短,以缩短指令长度能访问尽可能大的存储空间寻址方法尽可能简单,简化硬件设计在不改变指令的情况下,改变地址的实际值,从而方便地访问数组、串、表格等复杂数据。17第4章指令系统4.2.1常用的基本寻址方式1)立即寻址指令的地址字段指出的是操作数本身。立即寻址方式的特点:指令执行速度快;在执行过程,操作数不能修改。EA=(PC)OPM:立即寻址IMME18第4章指令系统指令的地

7、址码部分直接给出操作数在存储器中的地址(有效地址)。有效地址EA=A直接寻址方式的特点简单直观,便于硬件实现;要寻址大容量的主存空间,将造成指令长度加长。2)直接寻址操作数主存AOPM:直接寻址A19第4章指令系统3)间接寻址指令中的地址码部分给出一个指示操作数有效地址的地址指示字;通过地址指示字找到操作数的有效地址,再由有效地址找到操作数。有效地址EA=(A)AEAOPM:间接寻址AEA主存操作数20第4章指令系统间接寻址方式的特点:非常灵活,当操作数地址需改变时,不必修改指令,只要修改有效地址中的内容即可。一次间接需两次访问主存才能取得操作数,降低了指令执行速度。21第4章指令系统4)寄存

8、器寻址方式操作数存放在CPU的通用寄存器中。指令中地址码部分给出某一通用寄存器的编号。EA=Ri操作数通用寄存器OPM:寄存器寻址Ri22第4章指令系统5)寄存器间接寻址指令中地址码部分所指定的寄存器中内容是操作数的有效地址。有效地址EA=(Ri)寄存器间接寻址方式的特点只需访问存储器一次即可得到操作数;寄存器给出全字长的地址码,可寻址较大的存储空间。EA通用寄存器操作数主存OPM:寄存器间接寻址 Ri23第4章指令系统6)相对寻址程序计数器PC的当前内容加上指令给出的形式地址形成操作数的有效地址。形式地址实际上规定了操作数地址和指令地址的相对位置,这个值称为相对位移量(Disp)。有效地址E

9、A=(PC)+DispPCOPMDisp操作数DispOPM:相对寻址 Disp24第4章指令系统相对寻址方式的特点转移地址不是固定的,随着PC值的变化而变化,有利于程序的再定位。位移量一般用补码表示。如果位移量为8位,则寻址范围为(PC)128(PC)+127。25第4章指令系统例题:若某计算机数据线、地址线均是8bit,有一条相对寻址的无条件转移指令存于主存的20H单元中,指令给出的位移量D=00010101B,设该指令占用2个字节,计算:(1)取该指令时PC的内容;(2)该指令执行结束时PC的内容。26第4章指令系统7)变址寻址指令地址码部分给出的形式地址与指令中指定的变址寄存器的内容相

10、加开成操作数的有效地址。有效地址EA=(RX)+AOP M:变址寻址 RX A主存操作数X通用寄存器EA27第4章指令系统8)基址寻址指令地址码部分给出的形式地址与基址寄存器中的内容相加形成操作数的有效地址。有效地址EA=(Rb)+AOP M:基址寻址 RbA主存操作数X通用寄存器28第4章指令系统n基址寻址中基址寄存器提供基准量而指令提供位移量;变址寻址中变址寄存器提供修改量而指令提供基准量。n基址寻址面向系统,用于程序定位和扩大寻址空间;变址寻址面向用户,用于访问数组、向量、字符串等成批数据,以解决程序的循环控制问题。29第4章指令系统4.2.2复合型寻址方式1)基址变址寻址方式EA=(R

11、b)+(Rx)+A2)相对间接寻址方式EA=(PC)+A)3)间接相对寻址方式EA=(PC)+(A)4)变址间接寻址方式EA=(Rx)+A)5)间接变址寻址方式EA=(Rx)+(A)30第4章指令系统例题:一种单地址指令的结构如下图所示:OPIXD其中I为间址特征,X为寻址模式,D为形式地址,设R为通用寄存器,也可作为变址寄存器。在下表中填入适当的寻址方式名称。31第4章指令系统寻址方式名称IX有效地址E000E=D001E=(PC)+D010E=(R)+D011E=R100E=(D)101E=(PC)+D)110E=(R)+D)111E=(R)32第4章指令系统4.3指令类型n设计指令系统,

12、应考虑如下原则:完整性有效性扩充性兼容性33第4章指令系统n指令类型(按指令所完成的功能分类)1.数据传送指令2.算术逻辑运算指令3.移位操作指令4.浮点运算指令5.十进制运算指令6.字符串处理指令7.转移类指令8.堆栈操作指令9.输入/输出指令10.其他指令34第4章指令系统1)数据传送指令一般传送指令用来实现主存和寄存器之间、主存和主存、寄存器和寄存器之间的数据传送。数据交换指令数据块传送指令35第4章指令系统2)算术逻辑运算指令(1)算术运算指令这类指令用于定点数的算术运算如:加、减、乘、除、加1、减1、求补、比较等指令(2)逻辑运算指令与、或、非、异或位操作:测试、清除、置位、求反等算

13、术逻辑运算指令通常根据运算结果设置状态位:Z、S、C、V、P36第4章指令系统3)移位操作指令算术移位(带符号数)逻辑移位(无符号数)循环移位:大循环、小循环双字移位 C37第4章指令系统4)浮点运算指令5)十进制运算指令6)字符串处理指令如:字符串传送、字符串比较、字符串查找、字符串提取、字符串转换等7)转移类指令(1)转移指令无条件转移指令jump条件转移指令branch38第4章指令系统n转移指令的转移地址一般采用直接寻址的和相对寻址方式来确定。采用直接寻址方式,转移地址由指令地址码部分直接给出。采用相对寻址方式,则称为相对转移,转移地址为当前指令地址(PC的值)和指令地址部分给出的位移

14、量相加。39第4章指令系统n16种可能采用的转移条件P=1P=0Z=1Z=0S=1S=0V=1V=0无符号数带符号数ABC+Z=0(SV)+Z=040第4章指令系统(2)循环控制指令(3)调用指令与返回指令ncall与jump和branch的主要差别是保留返回地址(用堆栈)n保留、恢复寄存器内容的两种方法由调用程序保留、恢复由被调用程序保留、恢复41第4章指令系统8)堆栈及堆栈操作指令堆栈是以“先进后出”(FILO)方式工作的一个存储区。堆栈只有一个出口,即当前栈顶;用堆栈指针寄存器SP指定。压栈操作:栈底栈顶65H56HPUSHAX栈顶12H34H1234H42第4章指令系统弹栈的操作POP

15、BX34H12H65H56H栈底1234H栈顶栈顶43第4章指令系统堆栈的两种生成方式自底向上生成方式(向低地址生长)压栈PUSHA;(SP)-1SP,(A)(SP)弹栈POPA;(SP)A,(SP)+1SP自顶向下生成方式(向高地址生长)压栈PUSHA;(SP)+1SP,(A)(SP)弹栈POPA;(SP)A,(SP)-1SP44第4章指令系统堆栈用途在一般结构的计算机中,堆栈主要用于暂存子程序、中断调用时的返回地址和现场以及用于传送参数。通常设置参数指针,利用它访问堆栈不受堆栈的FILO性质的限制在堆栈结构的计算机中(如HP-3000),堆栈作为提供操作数和保存运算结果的主要存储区,大多数

16、指令皆访问堆栈(零地址指令)。45第4章指令系统9)输入/输出(I/O)指令输入输出指令完成主机与外部设备间的信息(数据信息、状态信息、控制信息)传送。通常输入输出指令有三种设置方式专用I/O指令独立编址用通用的数据传送指令实现I/O操作统一编址通过I/O处理机(通道)执行I/O操作46第4章指令系统10)其他指令控制指令完成某种控制功能的指令,如等待指令、停机指令、空操作指令、开中断、关中断、置条件码指令等特权指令具有特殊权限的指令。一般保留给操作系统使用。在多用户、多任务的计算机中必须设置。用于系统资源的管理和分配。例如:LLDT、LTR陷阱指令例如:8086的INTn47第4章指令系统n

17、CISC技术和RISC技术代表着目前计算机指令系统的两个截然不同的优化方向。4.4复杂指令系统计算机和精简指令系统计算机n设置一些功能复杂的指令,把一些原来由软件实现的、常用的功能改用硬件的指令实现,以提高计算机的执行速度,这种计算机系统就被称为复杂指令系统计算机,即ComplexInstructionSetComputer,简称CISC。48第4章指令系统n尽量简化计算机指令功能,只保留那些功能简单、能在一个节拍内执行完成的指令,而把较复杂的功能用一段子程序来实现。通过简化计算机指令功能,使指令的平均执行周期减少,从而提高计算机的工作主频,且大量使用通用寄存器,来提高子程序执行的速度。这种计

18、算机系统被称为精简指令系统计算机,即ReducedInstructionSetComputer,简称RISC。49第4章指令系统1)RISC发展1975年,IBM开始研制IBM801。801是最早开始设计的RISC处理器,是PowerPC的前身。RISC-I机、RISC-II机、MIPS机研究成功。RISC-II是SPARC的前身。从20世纪80年代末至今,RISC体系快速发展并伴随64位处理器的出现日趋完善。nRISC技术开发思路起源于著名的“8020结论”,即约20的计算机指令完成约80的工作。50第4章指令系统主流RISC芯片主要有:PowerPC(IBM)Alpha(DEC)HPPA(

19、HP)UltraSPARC(SUN)R10000(MIPS)51第4章指令系统2)RISC的主要特征选取使用频率高的简单指令。指令长度固定,指令格式种类少,寻址方式种类少。只有取数/存数指令访存,其余指令的操作都在寄存器间进行。中通用寄存器数量相当多。大部分指令在一个机器周期内完成。以硬布线控制为主,不用或少用微程序控制。采用高级语言编程,优化编译以减少程序执行的时间。52第4章指令系统3)RISC的优势nCPU执行程序所需时间P=I*C*TI:机器指令数C:每条机器指令的平均周期数T:每个周期的执行时间IRISCICISCCISC程序中较复杂的指令在RISC中用子程序完成CRISCCCISC

20、RISC大部分指令在一个周期内完成TRISCTCISCRISC完成一个操作所经过的数据通路较短53第4章指令系统4.5指令系统举例4.5.1教学计算机TEC-2指令系统4.5.2Pentium指令系统4.5.3SPARC指令系统54第4章指令系统4.5.1教学计算机TEC-2指令系统1)指令格式(1)单字长指令(16位)操作码条件码目的寄存器号源寄存器号I/O端口地址PORT或相对转移位移量DISP高6位:操作码;9、8位:条件码(C,Z,V,S)低8位:2个通用寄存器号(各4位)/相对转移位移量DISP(-128+127)/I/O端口地址(8位)55第4章指令系统操作码条件码目的寄存器号源寄

21、存器号I/O端口地址PORT或相对转移位移量DISP立即数DATA或绝对地址ADR或变址位移量OFFSET(2)双字长指令(32位)56第4章指令系统2)指令分类(1)指令中的符号说明OP操作码DR/SR目的操作数寄存器/源操作数寄存器SP堆栈指针寄存器PC程序计数器IPPC增量前的值(当前指令的地址)CND测试条件码57第4章指令系统CND测试条件码CND测试条件码OP0=1OP0=000CC=1转移C=0转移01ZZ=1转移Z=0转移10VV=1转移V=0转移11SS=1转移S=0转移58第4章指令系统(2)按指令的地址数目和指令功能分类空操作NOP开/关中断EI/DI进位位置位复位STC

22、/CLC状态字入/出栈PSHF/POPF返回/中断返回RET/IRET动态停机HALT装入微指令代码LDMC零地址指令(11条)OPXXXXXXXXXX59第4章指令系统一地址指令(12条)无符号乘MULSR;R0(高位积),R1(低位积)(R1)*(SR)无符号除DIVSR;R0(余数),R1(商)(R0)(R1)/(SR)入栈PUSHDR;SP(SP)-1,(SP)DR出栈POPDR;DR(SP),SP(SP)+1OPXXXXXXSROPXXDRXXXX60第4章指令系统加1/减1INC/DECDR;DR(DR)+1/-1求反NOTDR;DR/(DR)逻辑左移/右移SHL/SHRDR算术右

23、移ASRDR与C循环左移/右移RCL/RCRDR61第4章指令系统二地址指令(17条)OPXXDRSR加/带进位加ADD/ADCDR,SR减/带借位减SUB/SBBDR,SR比较CMPDR,SR;(DR)-(SR),不送结果与/或/异或AND/OR/XORDR,SR测试TESTDR,SR;(DR)&(SR),不送结果传送MOVDR,SR/SRMOVDR,SR62第4章指令系统传送MOVDR,DATA/ADRMOVADR,SRMOVDR,OFFSETSR;DR(OFFSET+(SR)MOVOFFSETSR,DR;OFFSET+(SR)(DR)OPXXDRSR立即数DATA/绝对地址ADR/变址位

24、移量OFFSET63第4章指令系统例题:阅读下列源程序,指出其完成什么功能?MOVR8,1111;被加数(高位)MOVR9,2222;被加数(低位)MOVR10,3333;加数(高位)MOVR11,4444:加数(低位)ADDR9,R11;低位和ADCR8,R10;高位和RET;返回64第4章指令系统I/O指令(2条)输入INPORT;R0(PORT)输出OUTPORT;PORT(R0)OPXXI/OPORT65第4章指令系统转移指令(9条)无条件绝对转移JPSR;PC(SR)条件绝对转移JPCND,SR;条件满足(0或1)PC(SR),否则PC(IP)+1OPCND/XXXXXXSR66第4

25、章指令系统无条件绝对转移JPADR;PCADR条件绝对转移JPCND,ADR;条件满足(0或1)PCADR,否则PC(IP)+1OPCND/XXXXXXXXXX绝对地址ADR67第4章指令系统无条件相对转移JROBJ;PC(IP)+位移量DISP条件相对转移JRCND,OBJ;条件满足(0或1)PC(IP)+位移量DISP,否则PC(IP)+1OPCND/XX相对转移位移量DISP68第4章指令系统例题:阅读下列源程序,指出其完成什么功能?MOVR1,0;置累加器初值为0MOVR2,0A;最大加数MOVR3,0;加数初值OBJ:INCR3;加数ADDR1,R3;累加CMPR3,R2;判断是否累

26、加完JRNZ,OBJRET;若完成,返回69第4章指令系统子程序调用指令(2条)OPXXXXXXSR调用CALLSR;SP(SP)-1,(SP)(PC),PC(SR)OPXXXXXXXXXX绝对地址ADR调用CALLADR;SP(SP)-1,(SP)(PC),PCADR70第4章指令系统4.5.2Pentium指令系统1)程序员所能见到的寄存器(1)通用寄存器EAX、EBX、ECX、EDXESP、EBP、ESI、EDI(2)6个16位的段寄存器CS、SS、DS、ES、FS、GS(3)指令指针和标志寄存器EIP、EFLAGS(32位)71第4章指令系统2)Pentium在实模式下32位地址的形成

27、段寄存器(CS、DS、ES、FS、GS、SS)基址寄存器(EAX、EBX、ECX、EDX、ESP、EBP、ESI、EDI)变址寄存器(EAX、EBX、ECX、EDX、EBP、ESI、EDI)放大因子1/2/4/8位移量disp(0/8/32)1672第4章指令系统3)Pentium的指令格式n指令由:0到4个可选指令前缀、1或2字节的操作码、一个可选的地址指示器、一个可选的位移量、一个可选的立即数字段组成。(1)前缀0或10或10或10或1指令段取代操作数大小取代地址大小取代Lock或重复指令前缀显式指出段寄存器32、16位地址切换32、16位数据切换73第4章指令系统(2)指令1或20或10

28、或10,1,2或40,1,2或4OPMOD/RMSIBDispImmModReg/opR/M76543210SS变址基址7654321074第4章指令系统4.5.3SPARC指令系统1)指令类型(1)算术运算/逻辑运算/移位指令(2)LOAD/STORE指令(3)控制转移指令(4)读/写专用寄存器指令(5)浮点运算指令(6)协处理器指令75第4章指令系统2)SPARC的指令格式nSPARC采用等长指令字结构,所有指令均是32位,在存储器中是字地址对准的。nSPARC的基本指令格式有三种:格式1CALLOPdisp30(位移量)3130290格式2SETHIBRANCHOPrdOP2imm22(

29、立即数)313029252422210OPacondOP2disp22(位移量)31302925242221076第4章指令系统格式3其它整数指令OPrdOP3rs10asirs231302925241918141312540OPrdOP3rs11Simm13(立即数)31302925241918141312 0浮点/协处理器操作OPrdOP3rs1opf/opcrs231302925241918141354 077第4章指令系统3)SPARC指令的功能与寻址方式(1)算术逻辑运算指令功能(rs1)OP(rs2)rd(rs1)OPSimm13rd(2)LOAD/STORE指令功能(M)rd(r

30、d)MM的地址=(rs1)+(rs2)M的地址=(rs1)+Simm1378第4章指令系统(3)控制转移指令Branch相对寻址JMPL寄存器间接寻址,并将PC当前值保存在rd中CALL相对寻址Trap寄存器间接寻址RETT寄存器间接寻址(4)读/写专用寄存器指令专用寄存器:PSR(程序状态字寄存器)Y(乘法步寄存器)WIM(窗口屏蔽寄存器)TBR(陷阱基址寄存器)79第4章指令系统4)SPARC指令的再定义n利用R0的值恒为0的特点,完成指令系统没有定义的操作。MOVErs1,rdADDrs1,r0,rd;(r0)=0INCrdADDrs,1,rd;立即数imm13作为操作数,rs、rd为同

31、一寄存器。80第4章指令系统DECrdSUBrs,1,rdNEGrdSUBr0,rs2,rdNOTrdXORrs,-1,rdCLEARrdADDr0,r0,rdCMPrs1,rs2SUBCCrs1,rs2,r0;(rs1)-(rs2)r0,置条件码81第4章指令系统本章主要知识点n指令的四要素,指令按地址数目的分类,指令操作码的两种编码方式,指令操作码的扩展技术。n指令和数据的寻址方式,各种数据寻址方式的寻址范围及有效地址表达式的表示。n各种基本指令的功能。n指令系统的两个优化方向:复杂指令系统计算机CISC和精简指令系统计算机RISC,RISC的特征。n教学计算机的指令系统,SPARC的指令系统和Pentium的指令系统。82

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 医学/心理学 > 基础医学

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号