• <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 閱讀(3006) 評論(1)  編輯 收藏 引用 所屬分類: 匯編語言教程

            評論

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

            那個C代碼是怎么來的?
            2008-07-24 10:06 | akirya
            午夜人妻久久久久久久久| 国产精品99久久久久久猫咪| 区久久AAA片69亚洲| 亚洲AV成人无码久久精品老人| 人妻久久久一区二区三区| 91久久香蕉国产熟女线看| 亚洲精品第一综合99久久| 精品国产乱码久久久久久郑州公司| 曰曰摸天天摸人人看久久久| 精品国产乱码久久久久软件| 1000部精品久久久久久久久| 国内精品伊人久久久影院| 国产成人精品久久二区二区| 7777精品伊人久久久大香线蕉| 精品久久一区二区三区| 亚洲国产精品高清久久久| 久久国产成人午夜AV影院| 97久久超碰国产精品2021| 亚洲精品无码久久毛片| 久久综合九色综合97_久久久| 精品久久久无码人妻中文字幕| 九九热久久免费视频| 色综合久久久久| 久久精品aⅴ无码中文字字幕重口| 午夜精品久久影院蜜桃| 精品久久久久久无码国产| 99国产欧美久久久精品蜜芽| 久久99热这里只频精品6| 欧洲性大片xxxxx久久久| 国产精品99久久久久久猫咪| 精品久久久久久久| 久久91综合国产91久久精品| 久久99国产精品99久久| 狠狠色婷婷综合天天久久丁香| 国内精品伊人久久久久AV影院| 久久久久亚洲av综合波多野结衣| 亚洲国产精品无码久久青草| 欧美亚洲国产精品久久久久| 中文字幕无码av激情不卡久久| 亚洲午夜无码AV毛片久久| 综合久久给合久久狠狠狠97色|