• <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>
            隨筆-91  評(píng)論-137  文章-0  trackbacks-0
            1.首先我們需要一個(gè)結(jié)構(gòu)來(lái)表示CPU所有的16位和8位寄存器(見(jiàn)Library\Struct\Register.h)
             1 #pragma once
             2 #include "..\Common\Base.h"
             3 
             4 struct Register_16_Bit
             5 {
             6     // General Register
             7     struct
             8     {
             9         BYTE AH; // 8Bit
            10         BYTE AL; // 8Bit
            11     }AX;
            12     struct
            13     {
            14         BYTE BH; // 8Bit
            15         BYTE BL; // 8Bit
            16     }BX;
            17     struct
            18     {
            19         BYTE CH; // 8Bit
            20         BYTE CL; // 8Bit
            21     }CX;
            22     struct
            23     {
            24         BYTE DH; // 8Bit
            25         BYTE DL; // 8Bit
            26     }DX;
            27 
            28     // Segment Register
            29     USHORT CS;
            30     USHORT DS;
            31     USHORT SS;
            32     USHORT ES;
            33 
            34     // Special Register
            35     USHORT IP;
            36     USHORT SP;
            37     USHORT BP;
            38     USHORT SI;
            39     USHORT DI;
            40     struct
            41     {
            42         BYTE OF : 1;
            43         BYTE DF : 1;
            44         BYTE IF : 1;
            45         BYTE TF : 1;
            46         BYTE SF : 1;
            47         BYTE ZF : 1;
            48         BYTE AF : 1;
            49         BYTE PF : 1;
            50         BYTE CF : 1;
            51         BYTE Reserve : 7;
            52     }FR;
            53 
            54     Register_16_Bit()
            55     {
            56         memset(this,0,sizeof(Register_16_Bit));
            57     }
            58 };
            2.然后我們定義一個(gè)接口來(lái)抽象出分析過(guò)程(見(jiàn)Library\Disasm\DisasmContext.h)
             1 #pragma once
             2 #include "..\Common\Base.h"
             3 
             4 class CDisasmContext
             5 {
             6 public:
             7     virtual bool Disasm(BYTE*& ptr)=0;
             8 protected:
             9     enum OpCodeHeader;
            10 };
            Disasm函數(shù)用于對(duì)機(jī)器碼進(jìn)行分析并確定語(yǔ)義
            OpCodeHeader是個(gè)枚舉類型用于枚舉每條指令的指令頭(詳情見(jiàn)8086指令手冊(cè))
            3.我們定義一個(gè)Jmp類來(lái)對(duì)Jmp指令進(jìn)行分析(見(jiàn)Library\Disasm\Jmp)
             1 #pragma once
             2 #include "..\DisasmContext.h"
             3 
             4 class CJmp : public CDisasmContext
             5 {
             6 public:
             7     virtual bool Disasm(BYTE*& ptr);
             8 protected:
             9     enum OpCodeHeader
            10     {
            11         JMP_SHORT = 0xEB,    // 段內(nèi)直接短跳
            12         JMP_NEAR = 0xE9,    // 段內(nèi)直接跳
            13         JMP_FAR = 0xEA,        // 段間直接跳
            14         JMP_IND = 0xFF,        // 段內(nèi)(外)間接跳
            15     };
            16 
            17     bool Jmp_Short(BYTE*& ptr);
            18     bool Jmp_Near(BYTE*& ptr);
            19     bool Jmp_Far(BYTE*& ptr);
            20 };
            其Disasm函數(shù)為
            1 bool CJmp::Disasm(BYTE*& ptr)
            2 {
            3     if(Jmp_Short(ptr)) return true;
            4     else if(Jmp_Near(ptr)) return true;
            5     else if(Jmp_Far(ptr)) return true;
            6     else return false;
            7 }
            4.我們同樣定義一個(gè)CMov類來(lái)對(duì)Mov指令進(jìn)行分析(見(jiàn)Library\Disasm\Mov)
            5.最后我們定義一個(gè)CDisasm類來(lái)驅(qū)動(dòng)整體框架(見(jiàn)Library\Disasm\Disasm.h)
            1 class CDisasm
            2 {
            3 public:
            4     bool Disasm(BYTE* ptr,int size);
            5 protected:
            6     CJmp Jmp;
            7     CMov Mov;
            8 };
            其Disasm函數(shù)為(見(jiàn)Library\Disasm\Disasm.cpp)
             1 bool CDisasm::Disasm(BYTE* ptr,int size)
             2 {
             3     BYTE* end = ptr + size;
             4     while(ptr < end)
             5     {
             6         if(Jmp.Disasm(ptr));
             7         else if(Mov.Disasm(ptr));
             8         else return false;
             9     }
            10     return true;
            11 }

            具體的分析過(guò)程其實(shí)就是查表的過(guò)程,這里不一一列舉出來(lái)了.
            目前只翻譯了部分Jmp和Mov指令,有興趣的同學(xué)可以查表對(duì)其進(jìn)行擴(kuò)充.
            所有代碼及指令手冊(cè)打包下載
            posted on 2011-07-10 12:30 lwch 閱讀(3874) 評(píng)論(9)  編輯 收藏 引用 所屬分類: 操作系統(tǒng)

            評(píng)論:
            # re: 自制虛擬機(jī)框架 2011-07-10 18:35 | 千暮(zblc)
            這架構(gòu)太不具備復(fù)用性和靈活性了- -。大囧哇大囧   回復(fù)  更多評(píng)論
              
            # re: 自制虛擬機(jī)框架 2011-07-10 22:04 | lwch
            @千暮(zblc)
            你就只會(huì)吃屎其他啥也不會(huì)..  回復(fù)  更多評(píng)論
              
            # re: 自制虛擬機(jī)框架 2011-07-11 08:30 | 欲三更
            祝你早日把linux在你的虛擬機(jī)上boot起來(lái)~  回復(fù)  更多評(píng)論
              
            # re: 自制虛擬機(jī)框架 2011-07-11 09:57 | lwch
            @欲三更
            懶得繼續(xù)寫(xiě)下去了,太復(fù)雜了...  回復(fù)  更多評(píng)論
              
            # re: 自制虛擬機(jī)框架 2011-07-11 21:59 | 千暮(zblc)
            @lwch
            你還不是天天跟著我吃屎,這玩意的虛擬機(jī)米啥好實(shí)現(xiàn)的。  回復(fù)  更多評(píng)論
              
            # re: 自制虛擬機(jī)框架 2011-07-11 22:02 | 千暮(zblc)
            而且你把分析層面的東西,搞進(jìn)了結(jié)構(gòu)里,何其吃屎瓦!!  回復(fù)  更多評(píng)論
              
            # re: 自制虛擬機(jī)框架 2011-07-15 17:24 | willbe
            貌似這應(yīng)該叫做模擬器,而不是叫虛擬機(jī)  回復(fù)  更多評(píng)論
              
            # re: 自制虛擬機(jī)框架 2011-07-15 22:18 | lwch
            @willbe
            我的本意是用他來(lái)分析x86指令結(jié)果發(fā)現(xiàn)太麻煩了...  回復(fù)  更多評(píng)論
              
            # re: 自制虛擬機(jī)框架 2011-10-27 00:02 | coreBugZJ
            面向?qū)ο笏坪醣粸E用了。。。個(gè)人愚見(jiàn)  回復(fù)  更多評(píng)論
              
            A级毛片无码久久精品免费| 免费观看久久精彩视频| 久久久午夜精品福利内容| 亚洲v国产v天堂a无码久久| 久久精品国产精品亚洲精品| 97久久香蕉国产线看观看| 国产精品永久久久久久久久久| 久久精品卫校国产小美女| 91秦先生久久久久久久| 精品久久久无码人妻中文字幕| 26uuu久久五月天| 99久久无色码中文字幕人妻| 一本久久久久久久| 亚洲国产另类久久久精品| 国产精品久久久久一区二区三区 | 久久久久婷婷| 久久妇女高潮几次MBA| 久久久久亚洲AV无码专区桃色| 久久精品无码专区免费东京热| 欧美精品乱码99久久蜜桃| 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲 | 亚洲精品tv久久久久久久久 | 性高湖久久久久久久久| 国产精品伦理久久久久久| 91精品国产乱码久久久久久| 三上悠亚久久精品| 亚洲中文久久精品无码| 午夜视频久久久久一区 | 久久人人爽人人爽人人AV| 理论片午午伦夜理片久久| 丁香久久婷婷国产午夜视频| 99re这里只有精品热久久| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 日韩精品久久久久久久电影| 久久久久无码专区亚洲av| 国产精品成人久久久久三级午夜电影 | 久久婷婷五月综合色高清| 亚洲精品无码久久久久sm| 久久夜色精品国产噜噜噜亚洲AV| 久久精品国产亚洲av麻豆图片| 久久精品国产亚洲AV不卡|