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

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運(yùn)轉(zhuǎn),開心的工作
簡(jiǎn)單、開放、平等的公司文化;尊重個(gè)性、自由與個(gè)人價(jià)值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
調(diào)試程序調(diào)試到系統(tǒng)庫函數(shù)的代碼時(shí),總會(huì)發(fā)現(xiàn)系統(tǒng)函數(shù)都是從一條MOVEDI, EDI指令開始的,緊接著這條指令下面才是標(biāo)準(zhǔn)的建立函數(shù)局部棧的代碼。對(duì)系統(tǒng)DLL比如ntdll.dll進(jìn)行反匯編,可以發(fā)現(xiàn)它的每個(gè)導(dǎo)出函數(shù)都是如此,并且每個(gè)導(dǎo)出函數(shù)開始處的MOVEDI, EDI上面緊接著5條NOP指令。比如在WinDbg中查看TextOutA周圍的代碼:
0:000> u TextOutA-0x0a L 10
GDI32!NtGdiTransparentBlt+0xa:
77efc43f ff12?????? ?????call??? dword ptr [edx]
77efc441 c22c00????????? ret???? 2Ch
77efc444 90????????????? nop
77efc445 90????????????? nop
77efc446 90????????????? nop
77efc447 90????????????? nop
77efc448 90????????????? nop
GDI32!TextOutA:
77efc449 8bff??????????? mov ????edi,edi
77efc44b 55????????????? push??? ebp
77efc44c 8bec??????????? mov???? ebp,esp
很明顯,兩個(gè)字節(jié)的MOVEDI,EDI指令什么事情也不做,那么,就有兩個(gè)問題:第一,為什么不直接從函數(shù)體開始而要從這條什么都不做的指令開始呢?第二,即使需要在函數(shù)一開始空出兩個(gè)字節(jié),為什么不直接使用兩條NOP指令,而要使用這條MOV指令呢?在網(wǎng)上查閱一些資料后,得到了答案:
對(duì)于第一個(gè)問題,答案是為了實(shí)現(xiàn)hot-patching技術(shù),即運(yùn)行時(shí)修改一個(gè)函數(shù)的行為。修改過程如下:把MOVEDI, EDI修改為一條短跳轉(zhuǎn)指令(一條短跳轉(zhuǎn)指令恰好兩個(gè)字節(jié)),把MOVEDI, EDI上面的五個(gè)NOP修改為一條長(zhǎng)跳轉(zhuǎn)指令(一條長(zhǎng)跳轉(zhuǎn)指令恰好五個(gè)字節(jié)),短跳轉(zhuǎn)指令跳到長(zhǎng)跳轉(zhuǎn)指令上,長(zhǎng)跳轉(zhuǎn)指令跳到修改后的函數(shù)體上。
對(duì)于第二個(gè)問題,答案是為了提高效率。執(zhí)行一條MOV指令比執(zhí)行兩條NOP指令花費(fèi)更少的時(shí)間。
?
下面是在網(wǎng)上搜索到的相關(guān)資料:
http://blogs.msdn.com/ishai/archive/2004/06/24/165143.aspx
在這篇日志中作者指出這是一種實(shí)現(xiàn)hot-patching和hot-fix的技術(shù),而且解釋了為什么不使用detours技術(shù)來實(shí)現(xiàn)hot-patching。此外,作者提到了具體是如何使用這種技術(shù)來實(shí)現(xiàn)hot-patching的,但是只是一句話帶過。
?
http://msmvps.com/blogs/kernelmustard/archive/2005/04/25/44413.aspx
這篇文章中作者從效率和其它方面詳細(xì)解釋了為什么選擇用這種技術(shù)來實(shí)現(xiàn)hot-patching以及為什么要這樣實(shí)現(xiàn)(短跳轉(zhuǎn)加長(zhǎng)跳轉(zhuǎn)而不是一次性長(zhǎng)跳轉(zhuǎn))。
?
http://xelf.info/knowledge/MemoryCopy.cpp
這里給出了具體的memcpy的C語言源代碼。如果在安裝VC6的時(shí)候選擇了安裝CRT源代碼,則在VC安裝目錄的SRC/INTEL/目錄中有memcmp.asm等文件,它們就是對(duì)應(yīng)的CRT函數(shù)的源代碼,這些源代碼中也都有詳細(xì)的注釋。
?
另外,在自己的日志http://blog.csdn.net/jcwKyl/archive/2008/03/25/2217428.aspx里面,曾經(jīng)對(duì)strcmp函數(shù)中的MOVEDI, EDI指令感到困惑,其實(shí)只要看看strcmp.asm中的源代碼就可以明白,那條MOVEDI, EDI完全是為了內(nèi)存四字節(jié)對(duì)齊的。源代碼中寫的是align 4,在運(yùn)行時(shí),如果需要一個(gè)填充字節(jié),則會(huì)填充一條NOP指令,如果需要兩個(gè)字節(jié)來填充,則會(huì)填充一條MOVEDI, EDI指令,之所以不用兩條NOP,是出于效率的考慮。


標(biāo)?題:?XP系統(tǒng)程序中開頭的MOV?EDI,EDI指令的解釋
發(fā)帖人:chaykovsky
時(shí)?間:?2005-11-25?13:55?
原文鏈接:http://bbs.pediy.com/showthread.php?threadid=18863

Feedback

# re: 函數(shù)開始處的MOV EDI, EDI的作用收藏  回復(fù)  更多評(píng)論   

2015-01-23 10:28 by abc
不錯(cuò),謝謝分享。
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久久999成人| 亚洲欧美日韩一区二区三区在线观看| 久久国产精品久久久| 中文亚洲欧美| 亚洲小少妇裸体bbw| 亚洲午夜av在线| 亚洲嫩草精品久久| 久久久久久有精品国产| 久久精品亚洲一区二区| 久久精品视频一| 欧美综合国产| 久久亚洲综合| 亚洲精品久久久久久下一站| 亚洲国产精品热久久| 亚洲欧洲一区二区三区在线观看| 日韩视频在线你懂得| 欧美一区国产一区| 欧美激情视频一区二区三区在线播放| 欧美成人免费大片| 国产精品女人网站| 亚洲国产另类久久精品| 亚洲欧美日韩一区二区在线 | 欧美专区在线观看一区| 美女图片一区二区| 国产亚洲欧美激情| 欧美一级片在线播放| 亚洲日本欧美| 免费看精品久久片| 在线观看亚洲视频啊啊啊啊| 亚洲欧美日韩综合| 一区二区日韩伦理片| 欧美高清在线视频| 影视先锋久久| 免费成人性网站| 欧美一区二区三区四区在线| 国产精品视频导航| 久久久久综合一区二区三区| 亚洲一区三区电影在线观看| 欧美日韩三级在线| 日韩亚洲欧美综合| 精品9999| 欧美激情在线播放| 玖玖视频精品| 亚洲一区欧美| 性刺激综合网| 亚洲黄色影院| 亚洲最快最全在线视频| 欧美午夜剧场| 久久人人爽人人爽爽久久| 欧美在线免费一级片| 亚洲高清在线观看| 一区二区欧美在线| 亚洲第一区在线观看| 夜夜嗨av一区二区三区四季av| 国产精品嫩草99av在线| 久久综合99re88久久爱| 欧美日韩亚洲一区二| 久久精品国产精品亚洲| 欧美高清视频在线| 欧美aaa级| 国产精品久久网站| 亚洲国产一区二区三区高清| 国产精品视频网址| 亚洲精选91| 亚洲国产你懂的| 性欧美暴力猛交69hd| 99国产精品久久久久久久久久| 欧美中文在线视频| 亚洲欧美在线高清| 国产精品v亚洲精品v日韩精品| 欧美va日韩va| 亚洲激情专区| 欧美日本国产| 99热在线精品观看| 亚洲激情中文1区| 老司机免费视频一区二区| 国产日韩一区二区三区| 国产精品日韩精品| 久久久精彩视频| 国产精品久久久久7777婷婷| 亚洲日本va午夜在线影院| 牛牛国产精品| 久久一区二区精品| 亚洲国产精品第一区二区| 欧美韩国日本一区| 久久婷婷一区| 亚洲巨乳在线| 亚洲午夜免费视频| 国产亚洲成av人在线观看导航 | 最新精品在线| 制服诱惑一区二区| 合欧美一区二区三区| 亚洲第一视频| 欧美日本视频在线| 欧美专区在线观看| 嫩模写真一区二区三区三州| 亚洲一区二区影院| 久久国产精品久久w女人spa| 99成人在线| 性xx色xx综合久久久xx| 亚洲人成毛片在线播放女女| 艳妇臀荡乳欲伦亚洲一区| 狠狠色丁香久久婷婷综合丁香| 亚洲电影在线看| 国产欧美一二三区| 亚洲黄色av| 国产综合在线视频| 亚洲最新在线视频| 91久久久亚洲精品| 性久久久久久久久久久久| 夜夜嗨一区二区| 久久亚洲国产精品日日av夜夜| 亚洲一区二区三区成人在线视频精品| 性欧美1819sex性高清| 一区二区三区四区在线| 久久久久天天天天| 欧美一进一出视频| 欧美日韩一区二区国产| 亚洲大片在线观看| 在线播放一区| 欧美一区二区三区免费大片| 在线亚洲自拍| 欧美精品一区二区久久婷婷| 久久亚洲综合| 国产亚洲视频在线观看| 一区二区三区日韩欧美| 亚洲日本中文字幕| 久久综合一区| 久久夜色精品国产| 国产亚洲欧美在线| 欧美伊人久久久久久久久影院| 亚洲欧美在线磁力| 国产精品国产自产拍高清av王其| 欧美一区二区视频97| 久久婷婷国产麻豆91天堂| 欧美日韩国产123| 亚洲黄色有码视频| 亚洲丶国产丶欧美一区二区三区| 午夜欧美不卡精品aaaaa| 亚洲欧美三级伦理| 国产精品久久久久久av福利软件| 日韩西西人体444www| 亚洲免费大片| 欧美日韩激情小视频| 99精品国产在热久久下载| 一本一本久久a久久精品综合妖精| 欧美国产成人精品| 亚洲精选视频在线| 亚洲一区在线播放| 国产精品青草综合久久久久99 | 久久在线免费视频| 免播放器亚洲| 日韩香蕉视频| 欧美午夜精品久久久久久超碰| 一区二区三区黄色| 午夜精品婷婷| 狠狠色伊人亚洲综合网站色| 久久精品水蜜桃av综合天堂| 欧美.www| 亚洲图片在线观看| 国产日韩欧美综合一区| 久久婷婷国产综合国色天香| 亚洲高清电影| 亚洲欧美大片| 尤物在线观看一区| 欧美精品一区在线| 亚洲免费一级电影| 美女免费视频一区| 99国内精品| 国产亚洲福利一区| 欧美激情中文字幕在线| 亚洲自拍偷拍福利| 欧美aaa级| 欧美一级专区| 亚洲乱码国产乱码精品精| 国产精品日韩欧美一区二区三区| 久久精品一区二区三区中文字幕| 亚洲人成毛片在线播放女女| 欧美一区国产一区| 亚洲精品一二三| 国产亚洲欧美另类一区二区三区| 欧美激情va永久在线播放| 亚洲欧美久久| 亚洲国产日韩美| 久久久97精品| 亚洲视频久久| 亚洲国产一区二区视频| 国产精品无码专区在线观看| 欧美va天堂va视频va在线| 午夜免费在线观看精品视频| 亚洲欧洲精品一区二区三区波多野1战4| 亚洲欧美日韩专区| 亚洲毛片在线免费观看| 国内成人精品视频| 国产精品va在线| 欧美人成免费网站| 免费高清在线视频一区·| 欧美伊人久久久久久午夜久久久久 | 免费欧美在线视频| 久久午夜视频|