1 / 101

第三章 MCS — 51 系列单片机的指令系统

第三章 MCS — 51 系列单片机的指令系统. 第一节 指令系统概述 第二节 寻址方式 第三节 MCS-51 单片机指令系统     一、数据传送类指令 二、算术运算类指令 三、逻辑运算类指令 四、位操作类指令 五、控制转移类指令. 第一节 指令系统概述. 一、指令的概念 指令是计算机所能执行的一种基本操作的描述。 1 、机器码指令与汇编语言指令 ( 1 )机器码指令 用二进制代码(或十六进制数)表示的指令称为机器码指令或目标代码指令。这种形式的指令能够直接被计算机硬件识别和执行。

kasi
Download Presentation

第三章 MCS — 51 系列单片机的指令系统

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. 第三章MCS—51系列单片机的指令系统 第一节指令系统概述 第二节 寻址方式 第三节 MCS-51单片机指令系统     一、数据传送类指令 二、算术运算类指令 三、逻辑运算类指令 四、位操作类指令 五、控制转移类指令

  2. 第一节 指令系统概述 一、指令的概念 指令是计算机所能执行的一种基本操作的描述。 1、机器码指令与汇编语言指令 (1)机器码指令 用二进制代码(或十六进制数)表示的指令称为机器码指令或目标代码指令。这种形式的指令能够直接被计算机硬件识别和执行。 例如指令INC A执行累加器A加1操作,其二进制代码为“00000100B”,用十六进制数表示的机器码指令为“04H”。

  3. (2)汇编语言指令 机器码指令不易阅读和记忆,为了方便记忆,便于程序的编写和阅读,用助记符来表示的指令称为汇编语言指令。例如用“MOV”表示数据的传送。用助记符表示的指令不能被计算机硬件直接识别和执行,必须通过某种手段(汇编)把它变成机器码指令才能被机器执行。 例如计算机执行操作:把数3FH传送到累加器A中,实现这种操作的汇编语言指令形式为: MOV A,#3FH 其中,“#”号为数3FH的标识符。这条指令的机器码为“74 3FH”。

  4. 2、指令格式 MCS-51系列单片机的指令由操作码和操作数两大部分组成,其指令格式为: 操作码 [操作数1] [,操作数2] [,操作数3] 方括号“[ ]”内的字段表示可有可无。 (1)操作码 表示指令进行何种操作,即操作性质。一般为英语单词的缩写。 (2)操作数指出了参加操作的数据或数据存放的地址,即操作对象。它以一个或几个空格与操作码隔开,根据指令功能的不同,操作数可以有3个、2个、1个或没有,操作数之间以逗号“,”分开。

  5. 例如下列四条指令: • CJNE A,#30H,LOOP • ADD A,@R1 • INC R0 • RET • 分别为3个、2个、1个和没有操作数的指令。

  6. 二、指令系统说明 1、常用符号 在MCS-51系列单片机指令系统中,约定了一些指令格式描述中的常用符号。现将这些符号的标记和含义说明如下: ·A:累加器(ACC),通常用ACC表示累加器的地址,A表示它的名称; ·AB:累加器(ACC)和寄存器B组成的寄存器对; ·direct:8位片内RAM低128B区或SFR块的存储单元地址;

  7. ·#data:8位立即数; ·#data16:16位立即数; ·addr16:16位地址码; ·addr11:11位地址码; ·rel:以补码表示的8位偏移量,其值为+127~-128; ·bit:片内RAM或SFR中可直接寻址的位地址; ·Rn:工作寄存器,其中n=0~7; ·Ri:工作寄存器,其中i=0, 1; ·@:间接寻址符号; ·+:加; ·-:减; ·*:乘; ·/:除;

  8. ·∧:与; ·∨:或; ·⊕:异或; ·=:等于; ·<:小于; ·>:大于; ·<>:不等于; ·←:取代(即右边的源操作数送到左边的目的操作数单元中); ·(X):X寄存器的内容; ·((X)):由X寄存器中的内容作为地址的存储单元内容; ·( X ):X寄存器的内容取反; ·rrr:指令代码中rrr三位的值由工作寄存器Rn确定,R0~R7对应的rrr为000~111; ·$:当前指令的地址。

  9. 2、指令对标志位的影响 MCS-51系列单片机指令系统中有些指令的执行结果要影响PSW中的标志位。表3-1列出了MCS-51系列单片机影响标志位的指令。 表中×表示指令执行时对标志有影响。

  10. 第二节 寻址方式 所谓寻址方式,就是指寻找操作数所在地址的方式。这里,地址泛指一个存储单元或某个寄存器。寻址方式越是多样,越是灵活,指令系统将越有效,计算机的功能也随之越强。 MCS-51系列单片机指令系统的寻址方式有七种。它们是:立即寻址、直接寻址、寄存器寻址、寄存器间接寻址、基址寄存器加变址寄存器间接寻址、相对寻址和隐含寻址。位寻址属于直接寻址的一类。寻址方式通常是针对源操作数的,否则需特别指明是针对目的操作数的,以免弄错。

  11. 一、立即寻址 这种寻址方式在指令中给出直接参与操作的常数 (称为立即数)。这样的操作数前面以“#”号标识, 可以是一个8位或16位的二进制常数。 例如: MOV A,#73H;将常数73H送入累加器A中, MOV DPTR,#2100H; 将16位立即数2100H送入16位寄存器DPTR中。

  12. 二、直接寻址 在指令中直接给出操作数所在存储单元的地址(一个8位二进制数),称为直接寻址。直接地址用direct表示。 直接寻址方式中操作数存储的空间有三种: 1、内部数据RAM的128个字节单元(00H~7FH 例如: MOV A,60H; (A)←(60H) 指令功能是把内部RAM 60H单元中的内容送入累加器A。

  13. 2、位地址位寻址指令均采用直接寻址。位地址分布在MCS-51系列单片机内部两个区域:一个是片内RAM 20H~2FH单元的128个位地址;另一个是字节地址能被8整除的特殊功能寄存器SFR中的92个位地址。位地址常用下列两种方式表示:(1)直接使用位地址。对片内RAM 20H~2FH单元的128个位地址00H~7FH的操作。例如:CPL 08H ;对片内RAM 21H单元中的D0位(位地址08H)内容取反。

  14. (2)对于某些特殊功能寄存器SFR,可以直接用寄存器名字加位数表示,(2)对于某些特殊功能寄存器SFR,可以直接用寄存器名字加位数表示, 例如: CLR PSW.3 ;将PSW.3中的RS0清0。 3、特殊功能寄存器SFR 特殊功能寄存器SFR只能用直接寻址方式进行访问。例如: MOV A,P1 ;将P1口(地址为90H)的内容读入累加器A中。

  15. 三、寄存器寻址 这种寻址方式由指令指出某一寄存器的内容作为操作数。寄存器为4组R0~R7中的某一个。例如: INC R0 ;(R0)←(R0)+1 在这类指令的操作码中,有三个寄存器的选择位,如指令“INC Rn”的操作码是00001rrr,由rrr的8种组合(000~111)决定寄存器R0~R7中的哪一个,由此得到该指令的8个不同的操作码08H~0FH。 工作寄存器的选择由PSW中的RS1和RS0的状态决定。RS1和RS0的状态,可使用指令通过对PSW赋值而改变其状态。

  16. 四、寄存器间接寻址 • 指令中一个寄存器的内容是操作数的地址。对于片内RAM的高128B区,即地址为80H~0FFH单元,只能用此种寻址方式。此类指令执行时,以所指定的寄存器的内容作为地址,再到该地址单元取得操作数。这是一种二次寻址方式,被称为寄存器间接寻址。指定的寄存器代号前用“@”号标识。 • (注意:规定只有R0、R1和DPTR可用于间接寻址.) • 采用@Ri间接寻址指令如: • MOV R0,#38H ;(R0)←38H • MOV A,@R0 ;(A)←((R0))

  17. 内部RAM和外部RAM都可以寄存器间接寻址。 通过@Ri可以访问8052内部RAM的256个存储单元(地址为00H~0FFH)和外部RAM的256个存储单元(地址为00H~0FFH)。 使用数据指针DPTR作为寄存器间接寻址时,可以访问外部RAM的64KB空间。堆栈操作也是间接寻址的。 采用@DPTR间接寻址指令如: MOV DPTR,#1234H;将立即数1234H送数据指针 MOVX @DPTR,A;将累加器A中内容送外部RAM 1234H存储单元

  18. 五、基址寄存器加变址寄存器间接寻址(变址寻址)五、基址寄存器加变址寄存器间接寻址(变址寻址) 它又叫变址寻址。以16位寄存器DPTR(数据指针)或PC(程序计数器)作为基址寄存器,以8位累加器A作为变址寄存器,用基址寄存器内容和变址寄存器内容相加,其和形成一个16位新地址,该新地址即为操作数的存储地址。(该寻址方式主要用于访问程序存储器) 变址寻址方式有两类 第一类变址寻址以程序计数器PC当前值为基址,以累加器A中内容为偏移量,例如: MOVC A,@A+PC; (PC)←(PC)+1,(A)←((A)+(PC)) 这是一条单字节指令(机器码为83H),该指令执行时,先使PC指向下一条指令地址(即指令当前值),然后再与累加器A的内容相加,形成变址寻址单元地址.

  19. 第二类变址寻址以数据指针DPTR内容为基址,以累加器A中内容为偏移量,例如:第二类变址寻址以数据指针DPTR内容为基址,以累加器A中内容为偏移量,例如: • MOV DPTR,#2345H ;DPTR赋值 • MOV A,#10H ;A赋值 • MOVC A,@A+DPTR ; • (A)←((A)+(DPTR)) • 这三条指令的执行结果是将程序存储器2355H单元内容送A中

  20. 六、相对寻址 • 这种寻址方式主要用于转移指令,用于指定转移的目标地址,它是以当前的PC值加上指令中规定的偏移量rel(以8位二进制补码表示)而形成实际的转移地址。一般将相对转移指令操作码所在地址称为源地址,转移后的地址称为目的地址。于是有: • 目的地址=源地址+2(相对转移指令字节数)+rel

  21. 例如指令: • JC 75H ;设CY=1,rel=75H。 • 这是一条以CY为条件的转移指令。因为“JC 75H”指令是双字节指令,当CPU取出第二个字节时,PC的当前值已是原PC的内容加2,由于CY=1,所以程序转向(PC)+75H单元地址去执行。 • 在实际应用中,经常需要根据已知的源地址和目的地址计算偏移量rel。若为3B指令,则rel的计算为: • rel =目的地址-源地址-3 • 计算得到的rel不论正负,均应用8位二进制补码表示。(表明程序跳转在当前地址相距-128~127范围内)

  22. 七、隐含寻址 操作数的地址隐含在操作码中,不需要指明,这种方式称为隐含寻址。 例如INC A 指令,其指令的含义是累加器A中的内容加1,指令代码为04H,但并没有给出A的地址,A的地址隐含在操作码中。 再如ADD A,#55H指令,其指令的含义是A的内容与55H相加,结果放在A中,指令代码为24H 55H,其中24H是操作码,55H是立即数,也没有给出A的地址,A的地址是隐含的。所以针对目的操作数的寻址方式是隐含寻址。 MCS-51系列单片机中,累加器A除了在堆栈操作指令中是直接寻址外,在其它指令中都是隐含寻址;寄存器B则只在乘法、除法指令中是隐含寻址,在其它指令中都是直接寻址;数据指针DPTR、位累加器C也是隐含寻址。

  23. 第三节 MCS-51系列单片机指令系统 MCS-51系列单片机指令系统具有111条指令,按每条指令的代码字节数分,共有49条单字节指令,45条双字节指令和17条三字节指令。若按指令的执行时间分,则有64条单周期指令,45条双周期指令和2条(乘法,除法指令)四周期指令,若取振荡频率为12MHZ,则MCS-51系列单片机大多数指令的执行时间仅需1us(即一个机器周期),所以该指令系统具有存储效率高,执行速度快等优点。

  24. MCS-51系列单片机的指令系统,按其功能可分为:MCS-51系列单片机的指令系统,按其功能可分为: ·数据传送类指令(28条) ·算术运算类指令(24条) ·逻辑运算类指令(25条) ·位操作类指令 (12条) ·控制转移类指令(22条)

  25. 一、数据传送类指令 所谓“传送”,是把源地址单元的内容传送到目的地址单元中去,而源地址单元内容不变;或者源、目的单元内容互换。数据传送操作可以在片内RAM和SFR内进行,也可以在累加器A和片外存储器之间进行。在这类指令中,除以累加器A为目的操作数寄存器指令会对奇偶标志位P有影响外,其余指令执行时均不会影响任何标志位。

  26. 1、内部数据传送指令MOV 这类指令的源操作数和目的操作数地址都在单片机内部,可以是片内RAM地址,也可以是特殊功能寄存器SFR地址。 (1)以累加器A为目的地址的指令 指令操作指令代码 MOV A,Rn (A)←(Rn) 11101rrr MOV A,direct (A)←(direct) 11100101 direct MOV A,@Ri (A)←((Ri)) 1110011i MOV A,#data (A)← data 11100100 data 这组指令的功能是把源操作数送入累加器A中。源操作数的寻址方式分别为寄存器寻址、直接寻址、寄存器间接寻址和立即寻址方式。

  27. 例3-1 MOV A,R5 ;(A)←(R5) MOV A,P1 ;(A)←(P1),这是一条输入指令,P1口引脚上的电平通过单片机模数转换传给P1口锁存器90H单元和累加器A中 MOV A,@R0 ;(A)←((R0)) MOV A,#78H ;(A)← 78H

  28. (2)以Rn为目的地址的指令 指令操作指令代码 MOV Rn,A (Rn)←(A) 11111rrr MOV Rn,direct (Rn)←(direct) 10101rrr direct MOV Rn,#data (Rn)← data 01111rrr data 这组指令的功能是把源操作数送入当前工作寄存器区R0~R7中的某一寄存器中。源操作数的寻址方式分别为隐含寻址、直接寻址和立即寻址方式。 例3-2 MOV R2,A ;(R2)←(A) MOV R7,60H ;(R7)←(60H) MOV R5,#0FAH ;(R5)←0FAH

  29. (3)以直接地址为目的地址的指令 指令操作指令代码 MOV direct,A (direct)←(A) 11110101 direct MOV direct,Rn (direct)←(Rn) 10001rrr direct MOV direct,@Ri (direct)←((Ri)) 1000011i direct MOV direct1,direct2 (direct1)←(direct2) 10000101 direct2 direct1 MOV direct,#data (direct)← data 01110101 direct data

  30. 这组指令的功能是将源操作数送入由直接地址指出的存储单元中。源操作数的寻址方式分别为隐含寻址、寄存器寻址、寄存器间接寻址、直接寻址和立即寻址方式。这组指令的功能是将源操作数送入由直接地址指出的存储单元中。源操作数的寻址方式分别为隐含寻址、寄存器寻址、寄存器间接寻址、直接寻址和立即寻址方式。 • 例3-3 MOV P1,A ;(P1)←(A),这是一条输出指令,累加器A中内容传送到P1口引脚(电平形式)和P1口锁存器90H单元 • MOV 70H,R3 ;(70H)←(R3) • MOV 45H,@R0 ;(45H)←((R0)) • MOV 0E0H,72H ;(0E0H)←(72H) • MOV 01H,#50H ;(01H)←50H

  31. (4)以寄存器间接地址为目的地址的指令 MOV @Ri,A ((Ri))←(A) 1111011i MOV @Ri,direct ((Ri))←(direct) 1010011i direct MOV @Ri,# data ((Ri))← data 0111011i data 这组指令的功能是把源操作数送入R0或R1指出的片内RAM存储单元中。源操作数的寻址方式分别为隐含寻址、直接寻址和立即寻址方式。 例3-4 MOV @R1,A ;((R1))←(A) MOV @R0,50H ;((R0))←(50H) MOV @R1,#0D8H ;((R1))←0D8H

  32.    上述指令中,累加器A是一个特别重要的8位寄存器,Rn为CPU当前选择的工作寄存器区中的R0~R7,在指令代码中对应的rrr=000~111,直接地址指出的存储单元为片内RAM的00H~7FH和特殊功能寄存器(SFR),在间接寻址中,用R0和R1作为地址指针访问片内RAM的00H~0FFH这256个单元。   上述指令中,累加器A是一个特别重要的8位寄存器,Rn为CPU当前选择的工作寄存器区中的R0~R7,在指令代码中对应的rrr=000~111,直接地址指出的存储单元为片内RAM的00H~7FH和特殊功能寄存器(SFR),在间接寻址中,用R0和R1作为地址指针访问片内RAM的00H~0FFH这256个单元。

  33. 例3-5设(70H)=60H,(60H)=20H,(P1)=0B7H,执行下面程序:例3-5设(70H)=60H,(60H)=20H,(P1)=0B7H,执行下面程序: MOV R0,#70H ; (R0)← 70H MOV A,@R0 ; (A)← 60H MOV R1,A ; (R1)← 60H MOV A,@R1 ; (A)← 20H MOV @R0,P1 ; (70H)← 0B7H 结果为:(70H)=0B7H,(A)=20H,(R1)=60H,(R0)=20H。

  34. 2、外部数据传送指令 (1)16位数据传送指令 指令 操作 MOV DPTR,#data16 (DPTR) ← data16     指令代码 10010000 立即数 立即数   高8位 低8位 这条指令的功能是把一个16位的立即数送入DPTR。 16位的数据指针DPTR由DPH和DPL组成,这条指令 把立即数的高8位送DPH,低8位送DPL。   这个被机器作为立即数看待的数其实就是外部 RAM/ROM的地址,是专门配合外部数据传送指 令来用的。

  35. (2)外部RAM数据传送指令MOVX    功能:实现片外数据存储器(或扩展I/O口)与累加器A之间的数据传送。寻址方式只能用间接寻址。这组指令有: 指令操作指令代码 MOVX A,@DPTR (A)←((DPTR))11100000 MOVX A,@Ri (A)←((Ri))1110001i MOVX @DPTR,A ((DPTR))←(A) 11110000 MOVX @Ri,A ((Ri))←(A) 1111001i 由于片外扩展的RAM和I/O口是统一编址的,共同使用64KB的空间,所以指令本身看不出是对片外RAM还是对扩展I/O口操作,而是由硬件的地址分配所定。 用Ri进行间接寻址时,因为Ri是一个8位寄存器,用它只能寻址256个单元,当片外RAM容量小于256个单元时可直接采用这种寻址方式,当片外RAM超过256个字节时,就要利用DPTR进行间接寻址。

  36. 例3-6 设R0的内容为21H,R1的内容为43H,外部RAM 43H单元内容为65H,执行下列指令: • MOVX A,@R1 ;(A)←((R1))=(43H)=65H • MOVX @R0,A ;((R0))=(21H)←(A)=65H • 结果是把外部RAM 43H单元内容65H送入累加器A和外部RAM 21H单元。 • 例3-7 将片内RAM单元20H的内容送到片外RAM单元3000H中。 • MOV R0,#20H ;(R0)←20H • MOV DPTR,#3000H ;(DPTR)←3000H • MOV A,@R0 ;(A)←((R0))=(20H) • MOVX @DPTR,A ;((DPTR))=(3000H)←(A)

  37. (3)外部ROM数据传送指令MOVC    功能:从程序存储器中读取源操作数送入累加器A。寻址方式只能用基址寄存器加变址寄存器间接寻址方式,这组指令包括以下两条指令: 1)指令操作指令代码 MOVCA,@A+PC(A)←((A)+(PC))10000011    这条指令以当前PC作为基址寄存器,A的内容作为无符号数,相加得到一个16位的地址,将该地址指出的程序存储单元的内容送入累加器A。   例3-8 设(A)=30H,执行指令: 1000H MOVC A,@A+PC 执行结果是当前PC值1001H与A中内容30H相加得1031H,然后将程序存储器中1031H单元的内容送入累加器A。

  38. 2)指令操作        指令代码 MOVC A,@A+DPTR (A)←((A)+(DPTR))10010011    这条指令以DPTR作为基址寄存器,A的内容作为无符号数与DPTR的内容相加得到一个16位地址,由该地址指出的程序存储单元的内容送入累加器A中。    这组指令常用于在程序存储器中的查表操作,故也称作查表指令,它是MCS-51系列单片机的特色指令之一,其中MOVC A,@A+PC指令称为近程查表指令(因为它只能在以当前PC为基准的+256B范围内查表),而MOVC A,@A+DPTR称为远程查表指令(它可以在64KB范围内查表)。

  39. 例3-9编制根据累加器A中的数(0~9之间),查其平方表的程序。例3-9编制根据累加器A中的数(0~9之间),查其平方表的程序。 解:把平方表用伪指令DB存放在程序存储器中,把表的首址置入DPTR中,把数0~9存放在变址寄存器A中,程序如下: MOV DPTR,#TABLE MOVC A,@A+DPTR ┇ TABLE:DB 00H,01H,04H,09H,10H,19H,24H DB 31H,40H,51H

  40. 3、数据交换指令 (1)字节交换指令XCH 指令操作指令代码 XCH A,Rn (A)(Rn)11001rrr XCH A,direct (A)(direct)11000101 direct XCH A,@Ri (A)((Ri))1100011i 这组指令的功能是将累加器A的内容和源操作数相互交换。源操作数的寻址方式分别为寄存器寻址、直接寻址和寄存器间接寻址。 例3-10设(A)=20H,(R3)=6FH,执行指令: XCH A,R3 结果:(A)=6FH,(R3)=20H

  41. (2)半字节交换指令XCHD 指令操作指令代码 XCHD A,@Ri (A)低4位((Ri))低4位1101011i 这条指令的功能是A的低4位和(R0)或(R1)指出的RAM单元低4位相互交换,各自的高4位不变。 例3-11设(A)=15H,(R1)=30H,(30H)=34H,执行指令: XCHD A,@R1 结果:(A)=14H,(30H)=35H,(R1)=30H

  42. 4、栈操作指令 在MCS-51系列单片机的片内RAM中,可以设置一个后进先出(LIFO)的堆栈,特殊功能寄存器SP作为堆栈指针,在进行栈操作时,它始终指向栈顶所在的位置。在指令系统中有两组用于数据传送的栈操作指令。它们是直接寻址方式,但其操作实质上是寄存器间接寻址方式。 (1)进栈(压栈)指令PUSH 指令操作指令代码 PUSH direct (SP)←(SP)+1 11000000 direct ((SP))←(direct) 这组指令的功能是首先将栈指针SP的内容加1,然后把直接地址指出的内容传送到栈指针(SP)所寻址的片内RAM单元中。

  43. 例3-12设(SP)=60H,(A)=30H,(B)=70H,执行指令:例3-12设(SP)=60H,(A)=30H,(B)=70H,执行指令: PUSH ACC ;(SP)←(SP)+1=61H, ((SP))←(ACC) PUSH B ;(SP)←(SP)+1=62H, ((SP))←(B) 结果:(61H)=30H,(62H)=70H, (SP)=62H

  44. (2)出栈(弹栈)指令POP 指令操作指令代码 POP direct (direct)←((SP)) 11010000 direct (SP)←(SP)-1 这组指令的功能是将堆栈指针(SP)寻址的片内RAM单元内容送入直接地址指出的存储单元中,然后SP的内容减1。 例3-13 设(SP)=62H,(62H)=70H,(61H)=30H,执行指令: POP DPH;(DPH)←((SP))=(62H), (SP)←(SP)-1=61H POP DPL;(DPL)←((SP))=(61H), (SP)←(SP)-1=60H 结果:(DPTR)=7030H,(SP)=60H

  45. 二、算术运算指令 MCS-51系列单片机算术运算指令包括:加法指令、带进位加法指令、带进位减法指令、加1指令、减1指令、十进制调整指令、乘法和除法指令,共24条。 大部分算术运算指令要影响标志寄存器PWS有关位的内容.如C、AC、P、OV等。

  46. 1、加法指令 (1)不带进位的加法指令ADD 指令 操作 指令代码 ADD A,Rn (A)←(A)+(Rn) 00101rrr ADD A,direct (A)←(A)+(direct) 00100101 direct ADD A,@Ri(A)←(A)+((Ri)) 0010011i ADD A,#data (A)←(A)+ data 00100100 data 这组加法指令的功能是指令源字节变量的内容和目的字节变量A的内容相加,其结果存放在A中。

  47. 若结果的D7位产生进位,则进位位CY被置1,否则CY被清0;若结果的D3位产生进位,则辅助进位位AC被置1,否则AC被清0。对溢出标志OV的影响是:如果结果的D6位有进位而D7位无进位,或者D7位有进位而D6位无进位,则OV标志被置1,否则被清0。从另一方面看,若把参加运算的数看作是8位二进制补码,当运算结果超过二进制补码所表示的范围(+127~-128)时,OV被置1,否则OV被清0。对于带符号数的补码运算,溢出标志OV=1,表示运算结果出错。若结果的D7位产生进位,则进位位CY被置1,否则CY被清0;若结果的D3位产生进位,则辅助进位位AC被置1,否则AC被清0。对溢出标志OV的影响是:如果结果的D6位有进位而D7位无进位,或者D7位有进位而D6位无进位,则OV标志被置1,否则被清0。从另一方面看,若把参加运算的数看作是8位二进制补码,当运算结果超过二进制补码所表示的范围(+127~-128)时,OV被置1,否则OV被清0。对于带符号数的补码运算,溢出标志OV=1,表示运算结果出错。 奇偶标志位P将随累加器A中1的个数的奇偶性变化。若A中1的个数为奇,则P置1,否则P置0。 源操作数分别为寄存器寻址、直接寻址、寄存器间接寻址和立即寻址方式。

  48. 例3-14 设(A)=84H,(30H)=8DH,执行指令: ADD A,30H   (A)= 1 0 0 0 0 1 0 0 +)(30H)= 1 0 0 0 1 1 0 1 ---------------------------------------------------------   结 果 =1 0 0 0 1 0 0 0 1 产生进位 产生辅助进位 结果:(A)=11H,(CY)=1,(AC)=1,(OV)=1,(P)=0

More Related