MASM中JMP跳转到绝对地址

  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系统的boot.asm源码就是这样操作的)

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

;三种方法都行
jmp far ptr jmppos
jmp jmpseg:jmppos
jmp jmppos
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章