4.6 offset指令,jmp short指令,far,dword ptr各种跳转指令

4.6 offset指令,jmp short指令,far,dword ptr各种跳转指令

可以修改IP,或同时修改CS和IP的指令统称为转移指令。概括的讲,转移指令就是可以控制CPU执行内存中某处代码的指令

1. 转移指令

1.1 8086CPU的转移行为有以下几类

  • 只修改IP时,称为段内转移,比如:jmp ax
  • 同时修改CS和IP时,称为段间转移,比如:jmp 1000:0

1.2 段内转移又分为:短转移和近转移

  • 短转移IP的修改范围为-128-~127
  • 近转移IP的修改范围为-32768~32767

1.3 8086CPU的转移指令分为以下几类

  • 无条件转移指令(如:jmp)
  • 条件转移指令
  • 循环指令(如:loop)
  • 过程
  • 中断

2. jmp short指令

  • jmp short 标号(转到标号处执行指令),这种格式的jmp指令实现的是段内短转移

  • 它对IP的修改范围为-128~127个字节

  • 转移指令结束后,CS:IP应该指向标号处的指令

  • 这里jmp存的不是目标地址,而是位移距离

    assume cs:codesg
    codesg segment
    start:
    mov ax,0
    jmp short s
    add ax,1

    s:
    inc ax

    codesg ends
    end start

3. jmp far ptr指令

  • 当超出jmp short 范围时,编译会报错
  • 此时使用jmp far ptr指令即可

    assume cs:codesg
    codesg segment
    start:
    mov ax,0
    mov bx,0
    inc cx
    jmp far ptr s
    db 256 dup(0)

    s:
    inc ax

    codesg ends
    end start

  • 注意:此时jmp记录的不是偏移量,而是整个地址,因为位移太大不好计算,直接记录cs:ip地址

4. 转换地址在内存中的jmp指令有两种格式

4.1 jmp word ptr 内存单元地址(段内转移)

  • 功能:从内存单元地址处开始存放着一个字,是转移的目的偏移地址;就是把指定内存单元的地址的数据拿过来作为跳转的地址

  • 例如:

    assume cs:codesg
    codesg segment
    start:
    mov ax,0123h
    mov ds:[0],ax
    jmp word ptr ds:[0] //ds为段地址,[0]处的数据为偏移地址,将ip改为该地址

    codesg ends
    end start

4.2 jmp dword ptr 内存单元地址(段间转移)

  • 如果要cs:ip同时更改,可以用这个

  • 功能:从内存单元地址处开始存放着两个字,高地址处的字是转移的目的段地址,低地址处是转移的目的偏移地址

  • cs = 内存单元地址 + 2;ip = 内存单元地址

    assume cs:codesg
    codesg segment
    start:
    mov ax,0123h
    mov ds:[0],ax //把ax的值赋给该地址的内存数据
    mov word ptr ds:[2],0 //把该地址处的内存数据改为0000
    jmp dword ptr ds:[0] //跳转到cs:ip即0000:0123这个位置

    codesg ends
    end start

  • cs为内存地址+2即ds:[2],0000
  • ip为内存地址即ds:[0],0123

5. jcxz指令

  • cx为0就跳转

6. 操作符offset指令

操作符offset在汇编语言中是由编译器处理的符号,它的功能是取得标号的偏移地址

复制代码
assume cs:codesg  
codesg segment
    start:
    mov ax,offset start
	mov dx,offset s

s:
    mov bx,cx
	inc bx
    
codesg ends
end start
  • start 标号是0,所以offset取出start的偏移地址赋给ax
  • s 标号是6,所以offset取出s的偏移地址赋给dx
相关推荐
small_wh1te_coder2 天前
GCC深度剖析:从编译原理到嵌入式底层实战
汇编·c++·面试·嵌入式·状态模式·c
白书宇3 天前
5.从零开始写LINUX内核--从实模式到保护模式的过渡实现
linux·汇编·数据库·开源
浩浩测试一下3 天前
02高级语言逻辑结构到汇编语言之逻辑结构转换 if (...) {...} else {...} 结构
汇编·数据结构·数据库·redis·安全·网络安全·缓存
蚰蜒螟4 天前
JVM安全点轮询汇编函数解析
汇编·jvm·安全
要记得喝水9 天前
汇编中常用寄存器介绍
开发语言·汇编·windows·c#·.net
技术领导力10 天前
华为开源CANN,再次释放“昇腾转向”信号
汇编
DONG91314 天前
Python 中的可迭代、迭代器与生成器——从协议到实现再到最佳实践
开发语言·汇编·数据结构·python·算法·青少年编程·排序算法
embrace9917 天前
【C语言学习】scanf函数
c语言·开发语言·汇编·学习·青少年编程·c#·编辑器
麦兜*17 天前
【算法】十大排序算法超深度解析,从数学原理到汇编级优化,涵盖 15个核心维度
java·汇编·jvm·算法·spring cloud·ai·排序算法
会掉头发18 天前
x86_64汇编
汇编