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

Ay's Blog@CNSSUESTC

關于jmp相對跳的一道程序分析

夜深人靜,嘿嘿 ? 只有這個時候才有時間靜下來看點東西

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

遇到一個問題 ? 通過這個問題發現能深刻理解到 jmp 指令很具內涵的一些內容

甚歡 乃著此文以記之

?

程序如下:

assume cs:codesg

codesg segment

?? mov ax,4c00h

?? int 21h

start :

?? mov ax,0

s:

?? nop

?? nop

?? mov di,offset s 這里應該是計算 s 對于 segment 處的偏移量,賦值給 di

?? mov si,offset s2 計算 s2 對于 segment 處的偏移,保存到 si

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

?? mov cs:[di],ax?? ax 內容寫到 s 處,也就是填充上邊那 2 nop

s0:

?? jmp short s ;跳到 s ,那么這個時候位于 s 處指令應該是 jmp s1 ;接著執行應該是 mov ax 0 然后 int 21

s1:

?? mov ax,0

?? int 21h??

?? mov ax,0

s2:?

?? jmp short s1

?? nop

codesg ends

end start

?

?

結果發現我推測的跟執行的內容完全不一樣 …… 暈厥 ING~

又過了一天 一覺醒來想了想這個結果 哈哈 恍然大悟

?

書上的例子用的是 windows 自帶的 debug 調試 …… 我也只會用這個了 …… windbg 太麻煩 od 好像只能開 32 位的

只能截圖看了

ab.bmp

jmp 指令在被編譯器編譯的時候會自動計算跳轉時指針與目的地址的偏移量 然后通過加減 ip 這個數值實現跳轉的

也就是說 jmp s 這指令實現的是相對位移跳轉,跳到哪那是編譯器編譯的時候就計算好的了

我們來看看 1814 0016 這個地方的 jmp 指令 EBF0 這個指令對應的匯編語句應該是 jmp s

S 是在 1814 0008 所以反編譯的結果是 jmp 0008? 沒錯 跟我們的語句沒出入

那么我們可以看看機器碼 BEF0? BE jmp 指令 F0 代表相對位移 以補碼形式保存

那么我們計算下發現 F0 對應的 10 進制是 -16 也就是說要往后跳 16 個字節(注意是字節, 8bit 一個字節哦 ~

1814 0016 這個是我們執行到 jmp cs ip 的地址,也就是取指令的地址

注意這個時候我們已經取出 jmp s 這個指令了 那么 IP 指針應該 +2 指向 1814 0018 這個位置了

往后跳 16 個字節 1814 0018 – 10 10 進制就是 16 咯) = 1814 0008

應該是跳到 0008 這個位置上了 正好就是 s 對應的位置

那么我們看看 1814 0020 這個指令 EBF6? F6 是跳轉的相對位移 補碼形式存放 換算成 10 進制就是 -10

想象下當程序執行到 s0 那個時候 s 處的那 2 nop 指令已經被填充成 EBF6 ? 根據相對位移的計算

? 這個時候程序運行的步驟應該是

通過 jmp s 跳轉到 1814 0008 地址(這個時候下一個指令對應的機器碼是 BEF0

取出下一個指令 IP+2? 這個時候 IP 指向 1814 000a

執行 BEF6 這個指令(向后跳 10 個字節)

也就是應該跳到 1814 000a – a 10 16 進制表示) = 1814 0000

也就是說這個時候 jmp 指令應該是 jmp 0000 跳到 segment 開始處而不是跳到 s1 處了

接著應該是執行

?? mov ax,4c00h

?? int 21h

實際調試的結果也是這樣的

如下圖示

?

sa.bmp

看到沒 ? 執行 jmp 0008 也就是 jmp s 以后然后就是跳到 1814 0000 而不是跳到 s1 對應的那個偏移處

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

aabb.bmp

?

也就是說我們 jmp 的地址記錄的是相對偏移量 這個程序也說明了 jmp 的地址是在運行時計算出來的而不是編譯器一開始就硬編碼進去的

不過當然也有硬編碼進去的跳轉指令啦 ~~ 好像是 jmp far 地址吧 忘了的說 呵呵 ?

只不過小小闡明下 jmp 相對跳的執行流程和細節部分

這樣也有個小小啟示就是以后用相對跳的時候小心咯 貌似 shellcode 編寫或者改內核代碼的時候可以注意下 呵呵

跳轉的相對地址最好計算出來表直接就來個偏移 ? 一不小心機子就當掉了 ? 哇咔咔 ~

?

posted on 2009-02-13 02:11 __ay 閱讀(1685) 評論(2)  編輯 收藏 引用 所屬分類: 操作系統&&內核

Feedback

# re: 關于jmp相對跳的一道程序分析 2009-02-13 09:43 zuhd

理解jmp的時候,只要理解為ip"平移了n byte"而不是"移動到"這樣就不會搞錯了,我也是uestc的,不過畢業2年了,我郵箱:huhf#21mmo.com,大家一起學習  回復  更多評論   

# re: 關于jmp相對跳的一道程序分析 2009-02-13 10:18 __ay

@zuhd
呵呵 校友?幸會幸會~~  回復  更多評論   


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            午夜免费在线观看精品视频| 亚洲人成网站精品片在线观看| 农夫在线精品视频免费观看| 亚洲欧美在线视频观看| 久久综合中文色婷婷| 欧美一级理论性理论a| 欧美成年人视频网站欧美| 久久精品国产99| 欧美日韩免费高清一区色橹橹| 嫩草影视亚洲| 国产一区三区三区| 亚洲欧美日韩在线不卡| 亚洲免费小视频| 欧美日韩dvd在线观看| 亚洲电影免费在线 | 欧美一区久久| 亚洲一区日韩在线| 欧美精品一区二区三区在线看午夜| 另类专区欧美制服同性| 国产在线麻豆精品观看| 亚洲影院免费| 亚洲欧美国产高清va在线播| 欧美另类综合| 亚洲人成网站色ww在线| 亚洲免费观看视频| 能在线观看的日韩av| 欧美国产日韩免费| 亚洲人成人99网站| 欧美国产第二页| 亚洲人妖在线| 亚洲视频一区二区在线观看| 欧美日韩中文字幕综合视频| 夜夜嗨av色一区二区不卡| 亚洲一区视频在线| 国产精品久久久久久久久免费樱桃 | 欧美一区二区三区在线看| 国产精品免费电影| 亚洲免费视频成人| 欧美一区二区三区在线看| 国产午夜精品久久久久久久| 欧美在线|欧美| 美女精品在线| 亚洲精品资源美女情侣酒店| 欧美日韩高清在线一区| 99re66热这里只有精品4| 亚洲影院高清在线| 国产亚洲福利| 久久免费99精品久久久久久| 亚洲福利电影| 亚洲欧美成人网| 国产日韩一区二区三区| 久久夜色精品亚洲噜噜国产mv | 亚洲女同精品视频| 久久综合一区二区| 91久久视频| 欧美色综合网| 久久国产精品久久久| 亚洲大胆视频| 亚洲女同精品视频| 影音先锋亚洲精品| 欧美日韩视频在线观看一区二区三区| 亚洲午夜三级在线| 快射av在线播放一区| 99精品视频免费| 国产欧美日韩综合| 免费成人高清视频| 国产精品99久久久久久久久久久久| 久久国产黑丝| 亚洲人成人一区二区三区| 欧美视频在线观看视频极品| 久久er精品视频| 亚洲精品乱码久久久久久蜜桃麻豆 | 激情综合视频| 欧美日韩精品伦理作品在线免费观看| 亚洲在线视频网站| 91久久极品少妇xxxxⅹ软件| 亚洲欧美制服中文字幕| 亚洲人久久久| 狠狠爱www人成狠狠爱综合网| 欧美激情亚洲自拍| 91久久精品国产91久久性色| 欧美激情麻豆| 亚洲欧美日韩区| 亚洲国产精品成人精品| 欧美在线影院| 亚洲天堂av高清| 在线观看欧美黄色| 国产午夜精品一区理论片飘花 | 国产伦精品一区二区三区四区免费 | 在线成人免费观看| 国产精品自拍视频| 欧美日韩在线观看一区二区| 裸体歌舞表演一区二区| 午夜国产不卡在线观看视频| av成人免费在线| 欧美激情视频在线免费观看 欧美视频免费一| 先锋影音久久久| 亚洲在线观看视频| 亚洲系列中文字幕| 日韩亚洲精品视频| 亚洲欧洲美洲综合色网| 在线播放中文字幕一区| 国产伪娘ts一区| 国产区二精品视| 国产精品一区二区三区久久久| 欧美日韩免费观看一区=区三区| 欧美成人a∨高清免费观看| 久久久国产视频91| 久久久久久伊人| 久久久久一区| 久久久精品999| 久久久国产精品一区二区三区| 欧美在线观看www| 欧美在线观看视频| 久久av在线| 久久久久久久高潮| 麻豆视频一区二区| 欧美福利在线观看| 欧美日韩情趣电影| 国产精品va在线播放| 国产精品久久久久毛片软件| 国产精品视频一| 国产欧美日韩精品在线| 国产日韩在线亚洲字幕中文| 国产一区二区成人| 影音先锋亚洲精品| 最近中文字幕日韩精品| 日韩一级在线| 亚洲影视九九影院在线观看| 亚洲欧美综合精品久久成人| 久久精品天堂| 欧美不卡一卡二卡免费版| 亚洲国产日韩综合一区| 一本久道久久综合中文字幕| 亚洲免费在线电影| 久久午夜av| 欧美日韩视频不卡| 国产伦精品一区二区三区高清版| 国内自拍一区| aa国产精品| 久久国产精品99久久久久久老狼 | 亚洲欧美日韩天堂一区二区| 久久av资源网| 欧美激情精品久久久久久大尺度| 国产精品都在这里| 尤物精品在线| 中文成人激情娱乐网| 久久久国产一区二区| 亚洲国产天堂久久国产91| 亚洲视频一区二区免费在线观看| 久久精品91久久久久久再现| 欧美精品一区二区三区在线看午夜| 国产精品永久免费观看| 亚洲激情在线激情| 午夜在线视频一区二区区别 | 欧美激情一区二区三区蜜桃视频| 亚洲乱码国产乱码精品精天堂| 欧美一区不卡| 欧美美女操人视频| 狠狠色狠狠色综合日日五| 一区二区冒白浆视频| 久久综合免费视频影院| 一区二区三区国产精华| 另类尿喷潮videofree| 国产精品永久免费视频| 亚洲九九九在线观看| 久久久久久久久久看片| 在线视频欧美一区| 免费观看亚洲视频大全| 国产亚洲欧洲一区高清在线观看| 一区二区av在线| 欧美激情精品久久久久久变态| 亚洲欧美日韩一区二区| 欧美日韩国产在线看| 亚洲国产99| 久久综合色综合88| 亚洲欧美日产图| 欧美调教视频| 日韩午夜黄色| 亚洲高清不卡| 久热精品视频在线观看| 国产视频一区在线| 午夜综合激情| 亚洲一区影院| 国产精品热久久久久夜色精品三区 | 亚洲成色999久久网站| 久久高清国产| 国产亚洲欧洲| 久久精品免视看| 午夜免费在线观看精品视频| 国产精品成人一区二区| 国产精品99久久久久久久vr| 亚洲黄色性网站| 欧美电影在线免费观看网站| 亚洲黄色精品| 亚洲第一中文字幕| 欧美国产一区二区| 亚洲精品美女免费| 亚洲精品欧美极品| 欧美三级电影网|