青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Ay's Blog@CNSSUESTC

關(guān)于jmp相對(duì)跳的一道程序分析

夜深人靜,嘿嘿 ? 只有這個(gè)時(shí)候才有時(shí)間靜下來(lái)看點(diǎn)東西

前幾天在看 16 位匯編語(yǔ)言程序設(shè)計(jì) ? 王爽 老師寫的 ? 寫得真的很好 ? 呵呵 ? 不是賣廣告哈 資源共享嘛

遇到一個(gè)問(wèn)題 ? 通過(guò)這個(gè)問(wèn)題發(fā)現(xiàn)能深刻理解到 jmp 指令很具內(nèi)涵的一些內(nèi)容

甚歡 乃著此文以記之

?

程序如下:

assume cs:codesg

codesg segment

?? mov ax,4c00h

?? int 21h

start :

?? mov ax,0

s:

?? nop

?? nop

?? mov di,offset s 這里應(yīng)該是計(jì)算 s 對(duì)于 segment 處的偏移量,賦值給 di

?? mov si,offset s2 計(jì)算 s2 對(duì)于 segment 處的偏移,保存到 si

?? mov ax , cs:[si]? s 處的 1 個(gè)字節(jié)指令內(nèi)容讀入 ax (注意,基址是 cs ~ 不是 ds

?? mov cs:[di],ax?? ax 內(nèi)容寫到 s 處,也就是填充上邊那 2 個(gè) nop

s0:

?? jmp short s ;跳到 s ,那么這個(gè)時(shí)候位于 s 處指令應(yīng)該是 jmp s1 ;接著執(zhí)行應(yīng)該是 mov ax 0 然后 int 21

s1:

?? mov ax,0

?? int 21h??

?? mov ax,0

s2:?

?? jmp short s1

?? nop

codesg ends

end start

?

?

結(jié)果發(fā)現(xiàn)我推測(cè)的跟執(zhí)行的內(nèi)容完全不一樣 …… 暈厥 ING~

又過(guò)了一天 一覺醒來(lái)想了想這個(gè)結(jié)果 哈哈 恍然大悟

?

書上的例子用的是 windows 自帶的 debug 調(diào)試 …… 我也只會(huì)用這個(gè)了 …… windbg 太麻煩 od 好像只能開 32 位的

只能截圖看了

ab.bmp

jmp 指令在被編譯器編譯的時(shí)候會(huì)自動(dòng)計(jì)算跳轉(zhuǎn)時(shí)指針與目的地址的偏移量 然后通過(guò)加減 ip 這個(gè)數(shù)值實(shí)現(xiàn)跳轉(zhuǎn)的

也就是說(shuō) jmp s 這指令實(shí)現(xiàn)的是相對(duì)位移跳轉(zhuǎn),跳到哪那是編譯器編譯的時(shí)候就計(jì)算好的了

我們來(lái)看看 1814 0016 這個(gè)地方的 jmp 指令 EBF0 這個(gè)指令對(duì)應(yīng)的匯編語(yǔ)句應(yīng)該是 jmp s

S 是在 1814 0008 所以反編譯的結(jié)果是 jmp 0008? 沒(méi)錯(cuò) 跟我們的語(yǔ)句沒(méi)出入

那么我們可以看看機(jī)器碼 BEF0? BE jmp 指令 F0 代表相對(duì)位移 以補(bǔ)碼形式保存

那么我們計(jì)算下發(fā)現(xiàn) F0 對(duì)應(yīng)的 10 進(jìn)制是 -16 也就是說(shuō)要往后跳 16 個(gè)字節(jié)(注意是字節(jié), 8bit 一個(gè)字節(jié)哦 ~

1814 0016 這個(gè)是我們執(zhí)行到 jmp 時(shí) cs ip 的地址,也就是取指令的地址

注意這個(gè)時(shí)候我們已經(jīng)取出 jmp s 這個(gè)指令了 那么 IP 指針應(yīng)該 +2 指向 1814 0018 這個(gè)位置了

往后跳 16 個(gè)字節(jié) 1814 0018 – 10 10 進(jìn)制就是 16 咯) = 1814 0008

應(yīng)該是跳到 0008 這個(gè)位置上了 正好就是 s 對(duì)應(yīng)的位置

那么我們看看 1814 0020 這個(gè)指令 EBF6? F6 是跳轉(zhuǎn)的相對(duì)位移 補(bǔ)碼形式存放 換算成 10 進(jìn)制就是 -10

想象下當(dāng)程序執(zhí)行到 s0 那個(gè)時(shí)候 s 處的那 2 個(gè) nop 指令已經(jīng)被填充成 EBF6 ? 根據(jù)相對(duì)位移的計(jì)算

? 這個(gè)時(shí)候程序運(yùn)行的步驟應(yīng)該是

通過(guò) jmp s 跳轉(zhuǎn)到 1814 0008 地址(這個(gè)時(shí)候下一個(gè)指令對(duì)應(yīng)的機(jī)器碼是 BEF0

取出下一個(gè)指令 IP+2? 這個(gè)時(shí)候 IP 指向 1814 000a

執(zhí)行 BEF6 這個(gè)指令(向后跳 10 個(gè)字節(jié))

也就是應(yīng)該跳到 1814 000a – a 10 16 進(jìn)制表示) = 1814 0000

也就是說(shuō)這個(gè)時(shí)候 jmp 指令應(yīng)該是 jmp 0000 跳到 segment 開始處而不是跳到 s1 處了

接著應(yīng)該是執(zhí)行

?? mov ax,4c00h

?? int 21h

實(shí)際調(diào)試的結(jié)果也是這樣的

如下圖示

?

sa.bmp

看到?jīng)] ? 執(zhí)行 jmp 0008 也就是 jmp s 以后然后就是跳到 1814 0000 而不是跳到 s1 對(duì)應(yīng)的那個(gè)偏移處

接著就是跟我們想的一樣 執(zhí)行了 mov ax 4c 00h 然后就 int 21h

aabb.bmp

?

也就是說(shuō)我們 jmp 的地址記錄的是相對(duì)偏移量 這個(gè)程序也說(shuō)明了 jmp 的地址是在運(yùn)行時(shí)計(jì)算出來(lái)的而不是編譯器一開始就硬編碼進(jìn)去的

不過(guò)當(dāng)然也有硬編碼進(jìn)去的跳轉(zhuǎn)指令啦 ~~ 好像是 jmp far 地址吧 忘了的說(shuō) 呵呵 ?

只不過(guò)小小闡明下 jmp 相對(duì)跳的執(zhí)行流程和細(xì)節(jié)部分

這樣也有個(gè)小小啟示就是以后用相對(duì)跳的時(shí)候小心咯 貌似 shellcode 編寫或者改內(nèi)核代碼的時(shí)候可以注意下 呵呵

跳轉(zhuǎn)的相對(duì)地址最好計(jì)算出來(lái)表直接就來(lái)個(gè)偏移 ? 一不小心機(jī)子就當(dāng)?shù)袅?/span> ? 哇咔咔 ~

?

posted on 2009-02-13 02:11 __ay 閱讀(1680) 評(píng)論(2)  編輯 收藏 引用 所屬分類: 操作系統(tǒng)&&內(nèi)核

Feedback

# re: 關(guān)于jmp相對(duì)跳的一道程序分析 2009-02-13 09:43 zuhd

理解jmp的時(shí)候,只要理解為ip"平移了n byte"而不是"移動(dòng)到"這樣就不會(huì)搞錯(cuò)了,我也是uestc的,不過(guò)畢業(yè)2年了,我郵箱:huhf#21mmo.com,大家一起學(xué)習(xí)  回復(fù)  更多評(píng)論   

# re: 關(guān)于jmp相對(duì)跳的一道程序分析 2009-02-13 10:18 __ay

@zuhd
呵呵 校友?幸會(huì)幸會(huì)~~  回復(fù)  更多評(píng)論   


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲成人在线| 午夜精品在线视频| 午夜精品久久久久久久男人的天堂| 国产自产在线视频一区| 国产日产亚洲精品| 国产精品影视天天线| 国产精品一区二区三区久久久| 亚洲激情成人| 狂野欧美激情性xxxx| 久久中文字幕一区| 亚洲第一精品久久忘忧草社区| 亚洲国产高清一区二区三区| 亚洲精品国产精品乱码不99 | 久久久久免费| 免费在线亚洲| 99精品视频免费观看| 亚洲一区二区三区国产| 久久精品国产69国产精品亚洲| 美女999久久久精品视频| 欧美另类高清视频在线| 国产精品制服诱惑| 亚洲经典三级| 欧美中文在线视频| 亚洲经典视频在线观看| 亚洲免费网站| 欧美日韩国产首页| 一区在线播放| 欧美一级艳片视频免费观看| 欧美电影在线免费观看网站| 一区二区三区欧美亚洲| 欧美va亚洲va国产综合| 国产亚洲精品综合一区91| 亚洲精品一区二区三区福利| 久久精品国产视频| 亚洲乱码日产精品bd| 久久免费视频在线观看| 国产麻豆综合| 亚洲欧美日韩国产综合| 91久久黄色| 久久综合狠狠综合久久综合88| 国产精品一二三四| 中日韩美女免费视频网址在线观看| 久久夜色精品国产| 亚洲欧美日韩国产成人| 欧美三级在线| 中文精品99久久国产香蕉| 欧美国产综合| 美女国产精品| 亚洲精品国产日韩| 欧美国产日本高清在线| 久久一区精品| 亚洲国产精品va在线看黑人动漫 | 欧美aⅴ99久久黑人专区| 国产精品色在线| 亚洲永久字幕| 亚洲香蕉视频| 国产欧美二区| 欧美专区一区二区三区| 亚洲一区二区三区涩| 亚洲网站在线播放| 欧美精品在线一区二区| 91久久极品少妇xxxxⅹ软件| 久久综合色一综合色88| 久久精品亚洲一区二区三区浴池| 国产欧美一区二区在线观看| 性欧美xxxx大乳国产app| 亚洲视频在线观看免费| 国产精品日韩精品欧美在线| 亚洲欧美日韩一区二区| 亚洲欧美国产日韩中文字幕| 国产精品亚洲综合久久| 欧美在线网址| 久久久999国产| 亚洲欧洲日韩综合二区| 91久久精品www人人做人人爽| 欧美女同在线视频| 亚洲小视频在线观看| 亚洲男人的天堂在线观看| 国产日韩欧美一区二区三区在线观看| 久久精品国产999大香线蕉| 久久精品91久久香蕉加勒比| 亚洲国产精品99久久久久久久久| 亚洲国产成人av在线| 欧美日韩视频| 久久精品九九| 欧美极品一区| 欧美一级艳片视频免费观看| 久久综合给合久久狠狠色| 一区二区三区欧美在线观看| 亚洲欧美激情四射在线日 | 欧美色欧美亚洲另类二区| 亚洲在线视频一区| 久久成人资源| 这里是久久伊人| 久久se精品一区精品二区| 亚洲人成在线播放网站岛国| 亚洲色图自拍| 亚洲国产欧美在线人成| 最新日韩欧美| 国产在线麻豆精品观看| 亚洲美女少妇无套啪啪呻吟| 国产亚洲激情视频在线| 亚洲国产精彩中文乱码av在线播放| 欧美日韩在线精品一区二区三区| 久久裸体视频| 国产精品久久999| 亚洲电影欧美电影有声小说| 国产精品欧美日韩| 亚洲二区视频在线| 国产亚洲欧美日韩精品| 日韩午夜电影av| 亚洲激情成人| 久久精品综合一区| 性欧美长视频| 国产精品观看| 亚洲毛片一区二区| 91久久精品国产91性色| 欧美一区二区高清在线观看| 亚洲视频欧美在线| 欧美成人精品一区二区三区| 久久青青草原一区二区| 国产精品日韩欧美综合 | 久久久久久久久久看片| 欧美日韩精品在线播放| 猛男gaygay欧美视频| 国产日韩欧美高清| 一区二区三区高清在线观看| 亚洲精品美女91| 老鸭窝亚洲一区二区三区| 久久久噜噜噜久久中文字免| 国产欧美韩国高清| 亚洲尤物在线视频观看| 亚洲综合色激情五月| 欧美视频在线观看免费网址| 亚洲精品少妇| 亚洲性夜色噜噜噜7777| 欧美日韩午夜| 一本综合久久| 羞羞答答国产精品www一本| 国产精品免费区二区三区观看| 在线视频一区二区| 午夜国产精品视频免费体验区| 久久免费99精品久久久久久| 欧美午夜片欧美片在线观看| 亚洲精品免费看| 亚洲一区二区三区成人在线视频精品 | 欧美国产第一页| 亚洲欧洲精品一区二区三区| 亚洲精品之草原avav久久| 欧美激情一区二区三区在线| 亚洲精品欧美激情| 亚洲在线观看视频| 国产日韩一级二级三级| 欧美影院在线| 欧美激情一区二区三区在线| 99精品免费| 国产精品一二三视频| 欧美在线观看视频| 欧美激情亚洲视频| 亚洲一区成人| 禁断一区二区三区在线| 欧美成人精精品一区二区频| 夜夜嗨av一区二区三区免费区| 欧美一级二区| 亚洲欧洲一级| 国产精品欧美经典| 久久久夜夜夜| 日韩亚洲精品电影| 久久久精品视频成人| 亚洲三级视频| 国产一区二区三区的电影 | 中日韩美女免费视频网址在线观看 | 免费欧美在线视频| 亚洲色诱最新| 亚洲国产综合在线| 国产精品porn| 久久夜色精品国产亚洲aⅴ | 久久精品一区二区三区四区| 亚洲国产成人在线视频| 欧美日韩妖精视频| 久久精品二区| 亚洲视频综合在线| 欧美电影在线观看| 欧美中文字幕不卡| 一本综合精品| 亚洲高清不卡一区| 国产欧美日韩免费| 欧美三级韩国三级日本三斤| 久久亚洲图片| 亚洲女性裸体视频| 亚洲乱码日产精品bd| 欧美国产1区2区| 久久久精品一区| 欧美一区二区大片| 一区二区三区四区五区视频| 亚洲国产精品精华液2区45 | 香蕉久久夜色精品国产| 亚洲美女福利视频网站| 影院欧美亚洲| 国产综合久久久久久鬼色|