80386ASM程序设计基础(五)

原创 2003年03月10日 10:24:00

  控制转移指令,串操作指令
  80386控制转移指令包括:转移指令,循环指令,过程调用和返回指令。
  A.转移指令包括无条件转移指令JMP和条件转移指令,无条件转移指令分为段内直接转移,段内间接转移,段间直接转移,段间间接转移。由于80386有保护模式和实模式,在实模式下,段内转移的范围在-128~127,段间转移最大范围为64K。在保护模式需要用48位指针,即CS:EIP(16位+32位)。条件转移指令有很多包括JCXZ,JECXZ,JBE,JAE,JA,JB等,其用法和8086相似。
 
  B.循环指令LOOP,LOOPZ,LOO0PE,LOOPNZ,LOOPNE,TASM支持助记符LOOP,LOOPWE,LOOPWZ,LOOPWNZ,LOOPWNE,LOOPD,LOOPWD,LOOPDE,LOOPDNE,LOOPDNZ。以CX作为计数器时,就可用LOOP,LOOPWE,LOOPWZ,LOOPWNZ,LOOPWNE;在以ECX作为计数器时,以LOOPD,LOOPDE,LOOPDZ,LOOPDNZ,LOOPDNE,下面的一段例子可以说明问题:
  ABC PROC
     MOV CX,100H
     AA:
       ;ADD YOUR CODES HERE
       LOOP AA
  ABC END

  C.过程调用和返回调用CALL,RET
  这两个指令与8086的用法相同,但由于80386下有实模式和保护模式下。在实模式下,无论是段内调用还是段间调用均采用32位指针,即CS:IP,它们的用法与8086下相同。在保护模式下,段间调用和段内调用均用48位指针,即ECS:IP。RET用于返回,具体实现过程会比较复杂,在介绍完80386的地址的管理机制后会作介绍,先介绍一下以下CALL指令在8086中的用法:
  a.段内直接转移,具体格式:CALL 过程名。此时CS不入栈,IP的内栈入栈,入栈后再将加上目的地址与CALL指令的下一条指令的偏移地址之差值就可以转移到目的地址,详细过程:
  SP-2=>SP;将堆栈指针SP减2
  (SP)<=IP;将IP进栈
  IP+偏移地址之差;转到目的地址
  b.段内间接转移,具体格式:CALL OPRD,那么在这里OPRD可以寄存器或内存单元,它的具体实现过程:
  SP-2=>SP;将堆栈指针SP减2
  (SP)<=IP;将IP进栈
  IP<=(OPRD);转到目的地址
  同a一样,CS不入栈
  c.段间直接转移,具体格式:CALL 过程名 [FAR],此时CS,IP均要入栈,详细的实现过程:
  SP-2=>SP;将堆栈指针减2
  (SP)<=CS;将CS入栈
  SP-2=>SP;将堆栈指针再减2
  (SP)<=IP;将IP入栈
  ;装入新的CS,IP
  IP<=过程入口的偏移地址
  CS<=过程入口的段地址
  d.段间间接转移,具体格式:CALL OPRD [FAR],此时CS,IP均要入栈,OPRD是32位,你知道在8086中没有32位寄存器。因此,这里的OPRD一定是存储单元,高16位是CS的值,低16位是IP值,详细的实现过程:
  SP-2=>SP;将堆栈指针减2
  (SP)<=CS;将CS入栈
  SP-2=>SP;将堆栈指针再减2
  (SP)<=IP;将IP入栈
  ;装入新的CS,IP
  IP<=(OPRD+2,OPRD+3)
  CS<=(OPRD,OPRD1)  
  e.段内返回
  格式:RET。实际上它的实现过程:
  (SP)=>IP;从当前栈顶弹出一个字,将它送给IP指令计数器
  SP+2=>SP;SP
  f.段间返回
  格式:RET,实际上它的实现过程:
  (SP)=>IP;IP出栈
  SP+2=>SP;
  (SP)=>CS;CS出栈
  SP+2=>SP;
 
  D.中断返回指令IRET
  功能和用法与8086相同,这里顺便介绍一下8086的中断返回指令
  IRET,具体的实现过程:
  IP<=(SP);IP出栈
  SP+2=>SP;
  CS<=(SP);CS出栈
  SP+2=>SP;
  FLAGS<=(SP);标志寄存器出栈
  SP+2=>SP;
 
  E.串操作指令
  80386在串操作指令方面增加了双字操作,在8086五条指令的基础上增加了INS,OUTS。
  a.LOADSD,和8086的用法和功能相同,不过是对32位操作数操作。
  b.STOSD,和8086的用法和功能相同,不过是对32位操作数操作。
  c.CMPSD,和8086的用法和功能相同,不过是对32位操作数操作。
  d.SCANSD,和8086的用法和功能相同,不过是对32位操作数操作。
  e.MOVSD,和8086的用法和功能相同,不过是对32位操作数操作。
  f.重复前缀REP,和8086的功能与用法相同,仍以CX为计数器,看下面的一小程序:
  ROR ECX,2
  REP MOVSD;以CX为计数器,每次传送双字
  ROL ECX,1
  REP MOVSW;以CX为计数器,每次传送一字
  ROL ECX,1
  REP MOVSB;以CX为计数器,每个传送一个字节 
  g.INSB,INSW,INSD,OUTSB,OUTSW,OUTSD
  g1.INSB,串输入指令,以字节单位,该指令的功能是从DX指定的端口读入一个字节到ES:DI指定的内存单元中。 
  g2.INSW,串输入指令,以字单位,该指令的功能是从DX指定的端口读入一个字节到ES:DI指定的内存单元中。
  g3.INSD,串输入指令,以双字单位,该指令的功能是从DX指定的端口读入一个字节到ES:DI指定的内存单元中。
  g4.OUTSB, 串输出指令,以字节为单位,将DS:SI内存单元的内容送往DX指定的端口。
  g5.OUTSW, 串输出指令,以字为单位,将DS:SI内存单元的内容送往DX指定的端口。
  g6.OUTSD, 串输出指令,以双字为单位,将DS:SI内存单元的内容送往DX指定的端口。
  g7.串输入和串输出指令不影响标志寄存器中的各标志位,串操作指令可以与REP一起使用
 

80386ASM程序设计基础(四)

   算术运算指令,逻辑运算指令,移位指令   AA.算术运算指令   A.加减法运算ADD,ADC,INC,SUB,SBB,DEC,CMP,NEG   a.ADD,和8086功能,用法相同,不过支持...
  • kingcaiyao
  • kingcaiyao
  • 2003年03月10日 10:24
  • 1500

80386ASM程序设计基础(十)

主要介绍段描述符,段选择子   在保护模式下,段是实现虚拟地址到线性地址转换的基础。在保护方下,每个段有三个参数:段基址,段界限,段属性。段基址规定了线性地址空间中段的开始地址,段基址长度为32位,所...
  • kingcaiyao
  • kingcaiyao
  • 2003年03月18日 08:55
  • 1566

80386ASM程序设计基础

虽然80386处理器要较以前的处理器的功能大大增强,但这些功能只能在保护模式下才能全部得到发挥。在实模式下最大寻址空间只有1M,但在保护模式最大寻址空间可达4G,可以访问到所有的物理内存。同时由于引入...
  • bfboys
  • bfboys
  • 2016年09月04日 11:31
  • 118

80386ASM程序设计基础

    80386ASM程序设计基础     kingcaiyao        80386 ASM程序设计基础,呵呵,这是最近一段时间我的业余爱好。本期将连续推出若干篇有关80386ASM程序设计的...
  • wascm
  • wascm
  • 2006年04月08日 01:09
  • 2082

80386ASM程序设计基础(十一)

 主要介绍系统地址寄存器和控制寄存器以及在程序中实方式下与保护方式下的切换   80386处理器新增了一组控制寄存器CR0,CR1,CR2,CR3和一组系统地址寄存器GDTR,LDTR,IDTR,TR...
  • kingcaiyao
  • kingcaiyao
  • 2003年03月18日 08:55
  • 2179

80386ASM程序设计基础(三)

   在接下来的四篇里将介绍80386的汇编指令及用法,并和8086的指令进行比较。   80386的指令集包含了8086/8088,80186,80286的指令集,可以分为几个大类:数据传送指令,算...
  • kingcaiyao
  • kingcaiyao
  • 2003年03月08日 14:57
  • 2124

80386ASM程序设计基础(七)

 位操作指令,处理器控制指令 AA.位操作指令,8086新增的一组指令,包括位测试,位扫描。BT,BTC,BTR,BTS,BSF,BSR a.BT(Bit Test),位测试指令,指令格式:   BT...
  • kingcaiyao
  • kingcaiyao
  • 2003年03月10日 10:24
  • 1394

80386ASM程序设计基础(六)

高级语言支持,条件字节设置指令  AA.高级语言支持指令,开始于80186,主要是用来简化高级语言的某些特征,总共有3条指令:ENTER,LEAVE,BOUND  a.ENTER,LEAVE,建立与释...
  • kingcaiyao
  • kingcaiyao
  • 2003年03月10日 10:25
  • 1225

80386ASM程序设计基础(九)

 虽然80386处理器要较以前的处理器的功能大大增强,但这些功能只能在保护模式下才能全部得到发挥。在实模式下最大寻址空间只有1M,但在保护模式最大寻址空间可达4G,可以访问到所有的物理内存。同时由于引...
  • kingcaiyao
  • kingcaiyao
  • 2003年03月18日 08:55
  • 1929

80386ASM程序设计基础(一)

    80386 ASM程序设计基础,呵呵,这是最近一段时间我的业余爱好。本期将连续推出若干篇有关80386ASM程序设计的基础,主要介绍80386ASM指令的详细用法及如何在80386实模式下,保...
  • kingcaiyao
  • kingcaiyao
  • 2003年03月10日 10:25
  • 2608
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:80386ASM程序设计基础(五)
举报原因:
原因补充:

(最多只允许输入30个字)