MASM中JMP跳转到绝对地址

发布时间 2023-09-07 23:58:56作者: 美洲象

  MASM中如果将程序直接跳转到指定地址执行,如1234:5678,如果直接这样jmp 1234:5678或jmp [1234]:[5678]都无法通过编译,在debug中jmp 1234:5678倒是可以。那么如何能到达这个目的呢?

  一、普通方法:

  1、通过将地址保存到变量,然后far  jmp:
jmppos db  78h,56h,34h,12h
jmp dword  ptr [jmppos]

  2、通过将地址入栈的方式,然后retf:

push 5678h
push 1234h
retf

  二、标准方法:

  定义段,把段地址定位到需要的段地址,偏移地址定位到需要的偏移地址,然后跳转到标号(DOS系统的源码就是这样操作的)

jmpseg segment at 1234h;定位段地址
    org 5678h;重新定位偏移地址
    jmppos label far
jmpseg ends

;三种方法都行
jmp far ptr jmppos
jmp jmpseg:jmppos
jmp jmppos