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

隨筆 - 505  文章 - 1034  trackbacks - 0
<2007年8月>
2930311234
567891011
12131415161718
19202122232425
2627282930311
2345678


子曾經曰過:編程無他,唯手熟爾!

常用鏈接

留言簿(94)

隨筆分類(649)

隨筆檔案(505)

相冊

BCB

Crytek

  • crymod
  • Crytek's Offical Modding Portal

Game Industry

OGRE

other

Programmers

Qt

WOW Stuff

搜索

  •  

積分與排名

  • 積分 - 918837
  • 排名 - 14

最新隨筆

最新評論

閱讀排行榜

評論排行榜

重劍點評: cool! try it! 現在都是5.0了
http://developer.nvidia.com/object/nvperfhud_home.html  上面的視頻很直觀,功能一目了然


用NVPerfHud4剖析Farcry的繪制過程







    NVPerfHud4是Nvidia推出的配合Geforce6系列顯卡對DX9應用程序進行性能剖析的強大工具,通過它可以從宏觀和微觀兩個角度剖析圖形應用程序性能。宏觀上可以看到整體繪制中CPU、GPU分別占用了多少時間,PS、VS分別占用了多少時間,CPU等待時間,GPU等待時間。微觀上可以看到每一個DP調用的過程,顯示每一個DP調用過程中PS、VS和光柵化分別占用了多少時間以及每個DP調用所使用的VS、PS代碼,所用到的貼圖和所有繪制狀態。得到如此強大的功能對應用程序代碼的修改卻只需要一句,就是用下面的方式創建3D設備:
g_pD3D->CreateDevice( g_pD3D->GetAdapterCount()-1, D3DDEVTYPE_REF, hWnd, D3DCREATE_HARDWARE_VERTEXPROCESSING, &d3dpp, &g_pd3dDevice );
其中最關鍵的參數是前兩個,也就是說只要按照上面方法創建3D設備的應用程序都可以通過NVPerfHud進行剖析。要用NVPerfHud對Farcry進行剖析就是要在Farcry的二進制代碼中找到CreateDevice()函數的調用位置,并將調用參數按要求修改。下面簡單說說這個過程。

    用IDA打開Farcry的D3D9繪制模塊XRenderD3D9.dll,在Strings窗口發現了我們感興趣的字符串"Creating D3D device (Adapter format: %s, BackBuffer format: %s, Depth format: %s)",用右鍵菜單跳到引用這個字符串的地址發現如下代碼:

01 push    offset aCreatingD3dDev ; "Creating D3D device (Adapter format: %s"...
02 .text:38054CF3                 push    ecx
03 .text:38054CF4                 call    dword ptr [edi+8]
04 .text:38054CF7                 mov     eax, dword_389E67D8
05 .text:38054CFC                 add     esp, 14h
06 .text:38054CFF                 test    eax, eax
07 .text:38054D01                 jnz     short loc_38054D51
08 .text:38054D03                 mov     al, [esi+1D650h]
09 .text:38054D09                 test    al, al
10 .text:38054D0B                 jz      short loc_38054D15
11 .text:38054D0D                 mov     eax, [esi+1D65Ch]
12 .text:38054D13                 jmp     short loc_38054D1B
13 .text:38054D15
14 .text:38054D15 loc_38054D15:                           ; CODE XREF: sub_38054B00+20Bj
15 .text:38054D15                 mov     eax, [esi+1D694h]
16 .text:38054D1B
17 .text:38054D1B loc_38054D1B:                           ; CODE XREF: sub_38054B00+213j
18 .text:38054D1B                 mov     ebp, [esp+21Ch+var_20C]
19 .text:38054D1F                 mov     ecx, [eax]
20 .text:38054D21                 mov     eax, [esi+1D620h]
21 .text:38054D27                 mov     edx, [eax]
22 .text:38054D29                 lea     edi, [esi+1E698h]
23 .text:38054D2F                 push    edi
24 .text:38054D30                 lea     ebx, [esi+1D6C0h]
25 .text:38054D36                 push    ebx
26 .text:38054D37                 push    ebp
27 .text:38054D38                 mov     ebp, [esi+1F494h]
28 .text:38054D3E                 mov     ebp, [ebp+0]
29 .text:38054D41                 push    ebp
30 .text:38054D42                 mov     ebp, [esp+22Ch+var_208]
31 .text:38054D46                 mov     ebp, [ebp+4]
32 .text:38054D49                 push    ebp
33 .text:38054D4A                 push    ecx
34 .text:38054D4B                 push    eax
35 .text:38054D4C                 call    dword ptr [edx+40h]
36 .text:38054D4F                 jmp     short loc_38054D8A
37 .text:38054D51
38 .text:38054D51 loc_38054D51:                           ; CODE XREF: sub_38054B00+201j
39 .text:38054D51                 mov     ecx, [esp+21Ch+var_20C]
40 .text:38054D55                 mov     edx, [esi+1F494h]
41 .text:38054D5B                 mov     eax, [esi+1D620h]
42 .text:38054D61                 mov     ebp, [eax]
43 .text:38054D63                 lea     edi, [esi+1E698h]
44 .text:38054D69                 push    edi
45 .text:38054D6A                 lea     ebx, [esi+1D6C0h]
46 .text:38054D70                 push    ebx
47 .text:38054D71                 and     ecx, 0FFFFFFEFh
48 .text:38054D74                 push    ecx
49 .text:38054D75                 mov     ecx, [edx]
50 .text:38054D77                 push    ecx
51 .text:38054D78                 push    2
52 .text:38054D7A                 push    eax
53 .text:38054D7B                 call    dword ptr [ebp+10h]
54 .text:38054D7E                 mov     edx, [esi+1D620h]
55 .text:38054D84                 dec     eax
56 .text:38054D85                 push    eax
57 .text:38054D86                 push    edx
58 .text:38054D87                 call    dword ptr [ebp+40h]

第1行將我們感興趣的字符串地址壓入堆棧,第3行應該是輸出日志之類的調用,下面應該離創建設備的調用(CreateDevice)不遠了。再看看IDirect3D9接口的定義:

DECLARE_INTERFACE_(IDirect3D9, IUnknown)
{
    /*** IUnknown methods ***/
    STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE;
    STDMETHOD_(ULONG,AddRef)(THIS) PURE;
    STDMETHOD_(ULONG,Release)(THIS) PURE;

    /*** IDirect3D9 methods ***/
    STDMETHOD(RegisterSoftwareDevice)(THIS_ void* pInitializeFunction) PURE;
    STDMETHOD_(UINT, GetAdapterCount)(THIS) PURE;
    STDMETHOD(GetAdapterIdentifier)(THIS_ UINT Adapter,DWORD Flags,D3DADAPTER_IDENTIFIER9* pIdentifier) PURE;
    STDMETHOD_(UINT, GetAdapterModeCount)(THIS_ UINT Adapter,D3DFORMAT Format) PURE;
    STDMETHOD(EnumAdapterModes)(THIS_ UINT Adapter,D3DFORMAT Format,UINT Mode,D3DDISPLAYMODE* pMode) PURE;
    STDMETHOD(GetAdapterDisplayMode)(THIS_ UINT Adapter,D3DDISPLAYMODE* pMode) PURE;
    STDMETHOD(CheckDeviceType)(THIS_ UINT Adapter,D3DDEVTYPE DevType,D3DFORMAT AdapterFormat,D3DFORMAT BackBufferFormat,BOOL bWindowed) PURE;
    STDMETHOD(CheckDeviceFormat)(THIS_ UINT Adapter,D3DDEVTYPE DeviceType,D3DFORMAT AdapterFormat,DWORD Usage,D3DRESOURCETYPE RType,D3DFORMAT CheckFormat) PURE;
    STDMETHOD(CheckDeviceMultiSampleType)(THIS_ UINT Adapter,D3DDEVTYPE DeviceType,D3DFORMAT SurfaceFormat,BOOL Windowed,D3DMULTISAMPLE_TYPE MultiSampleType,DWORD* pQualityLevels) PURE;
    STDMETHOD(CheckDepthStencilMatch)(THIS_ UINT Adapter,D3DDEVTYPE DeviceType,D3DFORMAT AdapterFormat,D3DFORMAT RenderTargetFormat,D3DFORMAT DepthStencilFormat) PURE;
    STDMETHOD(CheckDeviceFormatConversion)(THIS_ UINT Adapter,D3DDEVTYPE DeviceType,D3DFORMAT SourceFormat,D3DFORMAT TargetFormat) PURE;
    STDMETHOD(GetDeviceCaps)(THIS_ UINT Adapter,D3DDEVTYPE DeviceType,D3DCAPS9* pCaps) PURE;
    STDMETHOD_(HMONITOR, GetAdapterMonitor)(THIS_ UINT Adapter) PURE;
    STDMETHOD(CreateDevice)(THIS_ UINT Adapter,D3DDEVTYPE DeviceType,HWND hFocusWindow,DWORD BehaviorFlags,D3DPRESENT_PARAMETERS* pPresentationParameters,IDirect3DDevice9** ppReturnedDeviceInterface) PURE;
   
    #ifdef D3D_DEBUG_INFO
    LPCWSTR Version;
    #endif
};

    仔細數一數可以看到CreateDevice()是接口的第17個函數,也就是說它在虛函數表里的偏移量應該是0x40。再回頭看上面的匯編代碼,可以發現有兩處"call    dword ptr [ebp+40h]"這樣的函數調用,這應該就是對CreateDevice()函數的兩次調用了。再看第53行還有這樣一個調用"call    dword ptr [ebp+10h]",對照IDirect3D9接口定義我們知道這是GetAdapterCount()函數,第55行對函數GetAdapterCount()的返回值減一,這不正是我們需要的CreateDevice()函數的第一個參數嗎,那再看看第二個參數是不是也是我們需要的D3DDEVTYPE_REF。第51行的指令"push    2"壓入CreateDevice()函數的第二個參數,查找相關頭文件我們發現D3DDEVTYPE_REF的值正好是2,這使我們相信第58行的CreateDevice()調用就是為NVPerfHud提供的,我們甚至都不需要修改調用參數,只需要把程序的執行路徑引到這里就行了。

    將IDA的代碼窗口切換到圖形視圖可以更容易地看到代碼跳轉路徑。



    可以看到代碼在最上面分為兩叉,右邊的綠色箭頭指向我們需要的CreateDevice()調用,我們只需要把最上面那個框里的"jnz     short loc_38054D51"指令修改成"jz     short loc_38054D51",也就是取反條件判斷,就能讓代碼走我們需要的執行路徑。在十六進制編輯窗口找到相關代碼,將75改為74(jnz改為jz),然后存盤就完成了對XRenderD3D9.dll的修改。

posted on 2007-08-29 11:03 七星重劍 閱讀(300) 評論(0)  編輯 收藏 引用 所屬分類: Game Graphics
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美精品| 久久精品国产亚洲高清剧情介绍| 欧美国产精品一区| 欧美刺激午夜性久久久久久久| 久久久久国产免费免费| 欧美在线免费观看视频| 午夜精品在线| 久久久777| 欧美jizz19性欧美| 欧美日韩国产大片| 国产精品永久入口久久久| 国产精品午夜久久| 好看的日韩视频| 亚洲日本va午夜在线影院| 在线一区日本视频| 久久精品电影| 亚洲黄色av一区| 99精品免费视频| 欧美一区二区在线看| 欧美福利一区| 国产精品日韩一区| 亚洲人成网站999久久久综合| 亚洲性夜色噜噜噜7777| 久久精品99国产精品日本| 欧美电影资源| 久久蜜臀精品av| 欧美国产欧美亚洲国产日韩mv天天看完整 | 亚洲免费视频在线观看| 久久精品国产欧美亚洲人人爽| 另类尿喷潮videofree| 亚洲国产成人av| 亚洲欧美国产制服动漫| 蜜臀av在线播放一区二区三区 | 狠狠干综合网| 亚洲私人黄色宅男| 农夫在线精品视频免费观看| 日韩午夜激情av| 久久婷婷国产综合尤物精品| 国产精品久久久久久久久免费桃花| 在线免费观看日本欧美| 欧美一区二区三区免费看| 最新中文字幕亚洲| 久久精品人人爽| 国产精品va在线| 99视频精品在线| 欧美jizzhd精品欧美喷水| 亚洲欧美国产精品桃花| 欧美三级视频在线观看| 亚洲免费观看在线观看| 牛牛影视久久网| 久久精品人人做人人爽| 国产欧美一级| 午夜久久影院| 亚洲午夜精品久久久久久app| 欧美精品色网| 亚洲美女电影在线| 亚洲福利视频在线| 欧美91精品| 亚洲人www| 亚洲国产成人精品久久| 鲁大师成人一区二区三区| 伊人成年综合电影网| 久久夜色精品亚洲噜噜国产mv| 亚洲欧美日韩精品一区二区| 欧美午夜片欧美片在线观看| 夜夜嗨av一区二区三区网站四季av | 久久久久久久综合色一本| 国产欧美二区| 久久亚洲高清| 欧美高清在线一区二区| 久久综合色88| 久久女同互慰一区二区三区| 国产亚洲va综合人人澡精品| 午夜宅男欧美| 欧美一区二区三区在线视频| 国产一区二区中文| 免费成人美女女| 欧美成年人视频网站| 亚洲精品日本| 一区二区三区精密机械公司| 国产精品高清在线| 欧美在线视频免费观看| 欧美一区二区| 亚洲国产一区二区a毛片| 欧美激情一区二区三区全黄| 欧美激情一区二区三区成人 | 老巨人导航500精品| 老鸭窝毛片一区二区三区| 亚洲激情网站| 亚洲系列中文字幕| 黄色免费成人| 亚洲欧洲另类| 国产日韩欧美二区| 亚洲电影在线看| 国产精品久久久久久久第一福利 | 久久五月天婷婷| 麻豆精品视频在线观看视频| 99精品99| 久久www免费人成看片高清| av成人免费| 久久精品国产99精品国产亚洲性色| 亚洲经典在线| 亚洲欧美综合网| 亚洲精品欧美日韩专区| 亚洲欧美日韩精品综合在线观看| 亚洲国产成人tv| 亚洲男人影院| 亚洲毛片av在线| 久久成人精品一区二区三区| 在线视频亚洲一区| 久久久久.com| 欧美一区二区在线视频| 欧美片在线观看| 久久精品30| 国产精品www网站| 亚洲国产小视频| 极品尤物一区二区三区| 亚洲一区综合| 亚洲一区二区三区四区视频| 老司机67194精品线观看| 久久精品免费看| 国产精品日韩在线播放| 亚洲精品永久免费| 亚洲欧洲综合另类在线| 久久国产视频网站| 欧美在线视频在线播放完整版免费观看| 久久久爽爽爽美女图片| 欧美在线视频不卡| 国产久一道中文一区| 宅男噜噜噜66一区二区| 亚洲深夜福利| 欧美在线地址| 国产精品综合| 亚洲一区二区视频在线| 亚洲图片欧美午夜| 欧美国产高清| 亚洲国产高清在线| 亚洲第一视频网站| 狼人天天伊人久久| 欧美成人官网二区| 91久久在线播放| 蜜臀av在线播放一区二区三区| 久久在线免费视频| 极品av少妇一区二区| 久久精品一区二区三区不卡牛牛| 欧美专区在线观看| 国内自拍一区| 久久亚洲欧美国产精品乐播| 蜜桃av一区二区三区| 亚洲国产成人午夜在线一区| 久热精品视频在线免费观看| 欧美 日韩 国产精品免费观看| 伊人精品久久久久7777| 麻豆freexxxx性91精品| 亚洲国产专区| 亚洲一区二区少妇| 国产欧美一二三区| 久久久久久成人| 亚洲国产另类精品专区| 亚洲色图制服丝袜| 国产一区二区在线免费观看 | 欧美日韩高清在线一区| 一区二区三区精品在线| 欧美在线国产精品| 在线观看的日韩av| 欧美日韩成人网| 亚洲一区制服诱惑| 美女脱光内衣内裤视频久久影院 | 久久精品视频亚洲| 亚洲国产女人aaa毛片在线| 一区二区三区不卡视频在线观看| 国产精品久在线观看| 欧美中文在线观看| 亚洲国产高清视频| 亚洲欧美日韩爽爽影院| 影音先锋久久久| 欧美日韩性视频在线| 欧美在线免费一级片| 亚洲三级电影全部在线观看高清| 欧美一级播放| 99热在这里有精品免费| 国产一区二区三区在线观看精品 | 99国产成+人+综合+亚洲欧美| 国产精品久久久久7777婷婷| 久久免费视频这里只有精品| 一区二区三区视频免费在线观看| 玖玖综合伊人| 亚洲欧美中文字幕| 日韩视频免费| 伊人久久婷婷| 国产女主播一区二区三区| 欧美日本韩国在线| 老司机午夜精品视频| 午夜综合激情| 欧美特黄a级高清免费大片a级| 久久久精品久久久久| 亚洲综合日韩在线| 一本到12不卡视频在线dvd| 欧美国产激情二区三区| 久久精品国产亚洲aⅴ|