匯編 JMP使用詳解
匯編 JMP 詳解關(guān)鍵詞說明
RVA: 相對(duì)虛擬地址(Relative Virtual Address),在內(nèi)存中相對(duì)于PE文件裝入地址的偏移位置,是一個(gè)相對(duì)地址。
JMP 的 3 種類型
- 短跳轉(zhuǎn)(Short Jmp,只能跳轉(zhuǎn)到256字節(jié)的范圍內(nèi)),對(duì)應(yīng)機(jī)器碼:EB
- 近跳轉(zhuǎn)(Near Jmp,可跳至同一段范圍內(nèi)的地址),對(duì)應(yīng)機(jī)器碼:E9
- 遠(yuǎn)跳轉(zhuǎn)(Far Jmp,可跳至任意地址),對(duì)應(yīng)機(jī)器碼: EA
短跳轉(zhuǎn) 和 近跳轉(zhuǎn) 指令中包含的操作數(shù)都是相對(duì)于(E)IP的偏移。
遠(yuǎn)跳轉(zhuǎn)指令中包含的是目標(biāo)的絕對(duì)地址。
所以短/近跳轉(zhuǎn)會(huì)出現(xiàn)跳至同一目標(biāo)的指令機(jī)器碼不同,不僅會(huì)不同,而且應(yīng)該不同。
而遠(yuǎn)跳轉(zhuǎn)中包含的是絕對(duì)地址,因此轉(zhuǎn)移到同一地址的指令機(jī)器碼相同 。
至此,我們知道了跳轉(zhuǎn)指令所對(duì)應(yīng)的機(jī)器碼根據(jù)E(IP)計(jì)算出來的,那到底是怎么計(jì)算的呢?
JMP 目標(biāo)地址計(jì)算方式
目標(biāo)地址 = 當(dāng)前指令地址 + 指令長度 + RVA
舉例說明
如圖: 想要從 001392DB 處跳轉(zhuǎn)到 001392E1 這個(gè)地址,那么E9后面應(yīng)該跟多少呢?
RVA = 001392E1 - 001392DB - 5
在計(jì)算機(jī)中使用上面的公式計(jì)算結(jié)果就是 RVA = 1 所以后面應(yīng)該是跟 E9 01 00 00 00
其中 5 是指令長度 E9 后面需要跟 4 字節(jié)的地址,所以指令(1)+地址(4) = 5
ps: 如果計(jì)算結(jié)果是負(fù)數(shù),則數(shù)值后面應(yīng)該用 FF 填充,如負(fù)一則應(yīng)該用 E9 01 FF FF FF
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
匯編語言系列之匯編實(shí)現(xiàn)簡(jiǎn)單數(shù)學(xué)運(yùn)算
這篇文章主要介紹了匯編語言系列之匯編實(shí)現(xiàn)簡(jiǎn)單數(shù)學(xué)運(yùn)算的思路詳解,本文給大家列出了兩種算術(shù)運(yùn)算的代碼,設(shè)計(jì)思路給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-11-11UEFI開發(fā)實(shí)戰(zhàn)用戶交互界面基礎(chǔ)說明
這篇文章主要為大家介紹了UEFI開發(fā)實(shí)戰(zhàn)用戶交互界面的基礎(chǔ)說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06純匯編實(shí)現(xiàn)打飛機(jī)小游戲的示例代碼
這篇文章主要介紹了純匯編實(shí)現(xiàn)打飛機(jī)小游戲的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01淺析ELF轉(zhuǎn)二進(jìn)制允許把 Binary 文件加載到任意位置
本文通過 eip + 偏移地址 實(shí)現(xiàn)了運(yùn)行時(shí)計(jì)算數(shù)據(jù)地址,不再需要把 Binary 文件裝載到固定的位置。本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2020-02-028086匯編開發(fā)環(huán)境搭建和Debug模式介紹(圖文詳解)
這篇文章主要介紹了8086匯編開發(fā)環(huán)境搭建和Debug模式介紹,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-01-01Go 中的循環(huán)是如何轉(zhuǎn)為匯編的(方法詳解)
這篇文章主要介紹了Go 中的循環(huán)是如何轉(zhuǎn)為匯編的,本文通過循環(huán)的匯編代碼給大家講解的非常詳細(xì),代碼簡(jiǎn)單易懂,非常不錯(cuò),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05