• <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>

            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 閱讀(1666) 評論(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
            呵呵 校友?幸會幸會~~  回復  更多評論   


            日本久久久精品中文字幕| 伊人久久无码中文字幕| 精品久久久久久国产三级| 欧美精品丝袜久久久中文字幕| 青青热久久国产久精品| 久久婷婷国产综合精品| 国产精品99久久久久久www| 久久久久久久久久久| 青青青伊人色综合久久| 国产精品99久久久精品无码 | 欧美日韩中文字幕久久伊人| 韩国三级中文字幕hd久久精品| 色综合久久久久综合99| 国产精品一久久香蕉产线看| 久久露脸国产精品| 美女写真久久影院| 99久久99这里只有免费的精品| 成人亚洲欧美久久久久| 久久婷婷五月综合色奶水99啪| 色诱久久av| 久久国产热这里只有精品| 欧美丰满熟妇BBB久久久| 亚洲国产成人久久综合野外| 精品免费tv久久久久久久| 国内精品综合久久久40p| 亚洲精品无码久久毛片| 国产亚洲美女精品久久久| 午夜久久久久久禁播电影| 国产精品99久久久久久宅男小说| 狠狠色丁香婷婷综合久久来来去| 国产精品免费福利久久| 99国产欧美久久久精品蜜芽| 日韩精品久久久久久免费| 日韩AV无码久久一区二区| 婷婷五月深深久久精品| 久久人人爽人人爽人人AV | A级毛片无码久久精品免费| 狠狠人妻久久久久久综合蜜桃| 久久精品免费观看| 国产精品九九久久精品女同亚洲欧美日韩综合区| 怡红院日本一道日本久久|