8086汇编 call 指令

8086汇编 call 指令

字面意思:调用子程序
实质:流程转移指令,它们都修改IP,或同时修改CS和IP
call指令实现转移的方法和 jmp 指令的原理相似
格式:call 标号

返回指令:ret、retf

call 指令说明

CPU执行call指令,进行两步操作:
  (1)将当前的 IP 或 CS和IP 压入栈中;
  (2)转移到标号处执行指令。

call 标号:

  • 16位位移=“标号”处的地址-call指令后的第一个字节的地址;
  • 16位位移的范围为 -32768~32767,用补码表示;
  • 16位位移由编译程序在编译时算出。

CPU执行“call far ptr 标号”时的操作:

  (1) (sp) = (sp) – 2
       ((ss) ×16+(sp)) = (CS)
       (sp) = (sp) – 2
            ((ss) ×16+(sp)) = (IP)
      (2) (CS) = 标号所在的段地址
            (IP) = 标号所在的偏移地址

CPU执行“call near ptr 标号”时的操作:

“call 标号”类似”jmp near ptr 标号”,对应的机器指令中为相对于当前IP的转移位移,而不是转移的目的地址,实现段内转移。指令“call far ptr 标号”实现的是段间转移!

ret、retf

使用案例

1、案例模板

说明:在程序走到call s时会直接跳转到 s: add ax, 1 这里列处理返回值ret以上指令当遇到ret后会返回到 mov ax, 4c00h 行接着往下执行。

    mov ax, 0
    ; 使用主程序 s
    call s
    mov ax, 4c00h
    int 21h
; 创建主程序s
s: add ax, 1
    ; 返回
    ret

 

posted @ 2020-03-13 10:24  kevin.Xiang  阅读(...)  评论(...编辑  收藏