MASM实现跳转到绝对地址

  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:
mov ax,5678h
push ax
mov ax,1234h
push ax
retf

  二、标准方法:

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

jmpseg segment at 1234h;定位段地址
    org 5678h;重新定位偏移地址
    jmppos label far;这里有个label伪指令,请参考其他文章
jmpseg ends

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

 

posted @ 2023-09-07 23:52  美洲象  阅读(105)  评论(0编辑  收藏  举报