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
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章