• <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>
            穩定盈利的期貨交易方法-量化趨勢交易

            alantop -專業量化投資者

            愛好:量化投資,逆向工程,滲透
            隨筆 - 595, 文章 - 0, 評論 - 921, 引用 - 0
            數據加載中……

            使用ida pro做反編譯時,要注意類型轉換

            使用ida pro做反編譯時,要注意類型轉換

            反編譯器常常在反編譯的時候做一些假設,想調用call常常返回,內存模式是flat,函數框架被正確設置等。當這些假設是正確的,輸出代碼是正確的。當假設是錯誤的話,那么得到的代碼就和真實的代碼不一定一致。來看個例子,

            使用反編譯器得到如下偽碼。

            顯然,變量v3(相當于edx)根本沒有被初始化,為什么?

            發生這樣的時候,是因為被調用函數常常破壞寄存器的值。在x86約定中,只有esiediebxebp可以跨越call保存。換句話說,其他的寄存器可以通過一個函數調用改變它們的值。因此,反編譯器假定函數遵守調用約定,它在函數調用前和函數調用后,把edx識別成兩個變量。第一個變量被優化成a1,第二個變量v3成了未初始化的。

            實際上 edx有以下三種可能。

            1. 未修改
            2. 用來返回一個值
            3. 被毀壞

            通過被調用的函數,反編譯器選擇了第三種情況。來我們來看看如果是對的,會出現什么

            正如我們看到,edx寄存器根本沒有被引用。于是我們發現是第一種情況。

            As we see, the edx register is not referenced at all, so we have the case #1. If the decompiler could find it out itself, without our help, our life would be much easier (maybe it will do so in the future!) Meanwhile, we have to add the required information ourselves. We do it using the Edit, Functions, Set function type command in IDA. The callee does not spoil any registers:

            反編譯器產生不同的偽碼

            因此,我們知道edx并沒有通過call被修改。它不過是在調用前后建立了兩個實例。

            通過調用函數利用edx返回值。我們如下操作設置類型

            上面表達式的意識是,函數帶有一個參數,參數被調用者壓棧,并把結果返回給edx

            在第三種情況下,反編譯器為edx建立兩個不同的變量,第一個被優化掉,第二個被用來放返回值。

            正如我們看到的,類型信息在反編譯器中扮演了一個很重要的角色。為了得到一個正確的代碼,我們要特別注意類型。

            posted on 2008-07-02 19:35 AlanTop 閱讀(3022) 評論(1)  編輯 收藏 引用 所屬分類: 匯編語言教程

            評論

            # re: 使用ida pro做反編譯時,要注意類型轉換  回復  更多評論   

            那個C代碼是怎么來的?
            2008-07-24 10:06 | akirya
            久久99国产精品二区不卡| 欧美日韩精品久久久免费观看| 久久久噜噜噜www成人网| 久久精品夜夜夜夜夜久久| 伊人色综合久久天天| 亚洲精品国产美女久久久| 91性高湖久久久久| 欧美一区二区三区久久综合| 国产精品久久久久一区二区三区 | 久久久久久九九99精品| 国产精品成人精品久久久| 97精品伊人久久久大香线蕉| 狠狠人妻久久久久久综合蜜桃| 国产精品免费看久久久| 国产精品久久婷婷六月丁香| 国产巨作麻豆欧美亚洲综合久久| 色综合久久无码五十路人妻| 久久国产精品无| 久久久99精品成人片中文字幕 | 久久96国产精品久久久| 久久国产精品成人影院| 欧美黑人激情性久久| 亚洲国产精品狼友中文久久久| 9999国产精品欧美久久久久久| 国产精品久久久久影院嫩草| 久久av无码专区亚洲av桃花岛| 伊人久久综合无码成人网| 伊人久久大香线蕉av一区| 国内精品伊人久久久久妇| 久久中文字幕精品| 一级做a爰片久久毛片免费陪| 久久天天日天天操综合伊人av| 久久99精品国产99久久| 99久久精品免费看国产| 狠狠色伊人久久精品综合网| 久久精品国产精品亚洲| 日韩电影久久久被窝网| 久久久久99这里有精品10 | 婷婷伊人久久大香线蕉AV| 看久久久久久a级毛片| 国产成人久久AV免费|