亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

關于hook設置函數如何支持多核CPU的一個說明

系統 1985 0

前兩天看Intel網站上貼了一篇關于設置HOOK的文章,講到在多核CPU上,由于執行代碼可能存在CPU CACHE里,因此當更改了函數起始6字節后,CPU CACHE里的對應內容并沒有被修改,所以需要調用 FlushInstructionCache() 函數來更新CACHE。

更新后的代碼如下,增加的代碼以粗體標出了。

/**?通過地址來設置某個函數的鉤子函數

?@param?HANDLE hApiHook - 由ApiHook_Init()函數生成的句柄?
?@param?DWORD dwSrcFuncAddr - 源函數地址?
?@param?DWORD dwNewFuncAddr - 鉤子函數地址?
?@return?INT (by default) - -1表示失敗,>=0表示在hook數組中的序號?
*/
INT ApiHook_SetByAddr(HANDLE hApiHook, DWORD dwSrcFuncAddr, DWORD dwNewFuncAddr)
{
?DWORD?dwOldProtect;
?DWORD?dwNewProtect;
?DWORD?? lpSrcFunc;
??? DWORD?? lppNewFunc;
??? UINT???? i;
?INT??nAlreadyFlag = 0;

?APIHOOK??*pApiHook = (APIHOOK *)hApiHook;
?if ( NULL == hApiHook )
?{
??return -1;
?}

?lpSrcFunc = dwSrcFuncAddr;
??? /* 查找是否已被設置了鉤子 */
?for ( i = 0; i < pApiHook->uMaxFunctions; i++ )
?{
??if ( pApiHook->pHookData[i].dwSrcFuncAddr == lpSrcFunc )
??{
???/* 如果已經被設置了鉤子,僅僅改變. */
???nAlreadyFlag = 1;
???break;
??}

?}
?/* 如果沒有設置源函數的鉤子函數,在表中找出一個可供記錄的位置. */
?if ( i == pApiHook->uMaxFunctions )
?{
??for ( i = 0; i < pApiHook->uMaxFunctions; i++ )
??{
???if (pApiHook->pHookData[i].wFlag == 0 )
???{
????break;
???}
??}??
??if ( i == pApiHook->uMaxFunctions )
??{
???return -1;
??}
?}

??? /* 將新的鉤子函數地址記錄到表中 */
?pApiHook->pHookData[i].dwNewFuncAddr = dwNewFuncAddr;
?
?/* 以下這段代碼將源函數頭部6個字節保存到表中 */
?lppNewFunc = (DWORD)(&(pApiHook->pHookData[i].dwNewFuncAddr) );

?if ( !nAlreadyFlag )
?{
??/* 將源函數起始處6個字節保存到 byHeaderCode.中 */
??????? memcpy( pApiHook->pHookData[i].byHeaderCode, (const void *)lpSrcFunc, 6);
?}

??? /* 以下這段代碼將源函數首部6個字節改成為一條跳轉到新函數地址的指令 */
??? if ( VirtualProtect( (LPVOID)lpSrcFunc,
???????????????????????? 6,
???????????????????????? PAGE_EXECUTE_READWRITE,
???????????????????????? &dwOldProtect ) == 0 )
??? {
??????? /*
???????? * Failure.
???????? */
??????? return -1;
??? }
?
??? *(unsigned char *)lpSrcFunc = (unsigned char)0xff;
??? *(((unsigned char *)lpSrcFunc)+1) = (unsigned char)0x25;

??? memcpy( (void *)(lpSrcFunc+2),
??????????? (const void *)&lppNewFunc,
??????????? 4 );??????????????????????????? /* address? */

??? if ( VirtualProtect( (LPVOID)lpSrcFunc,
???????????????????????? 6,
???????????????????????? dwOldProtect,
?????? &dwNewProtect) == 0 ) {
??????? /*
???????? * Failure.
???????? */
??????? return -1;
??? };

?pApiHook->pHookData[i].wFlag = 1;
?pApiHook->pHookData[i].dwSrcFuncAddr = lpSrcFunc;

?/* 使用以下FlushInstructionCache調用來支持多核CPU上的CACAHE的更新,
? * 上面的代碼只更改了內存里的地址,沒有更改CPU CACHE里的對應內容。
? */
?FlushInstructionCache(GetCurrentProcess(), NULL, NULL);

?return (INT)i;
}

?



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1209218


關于hook設置函數如何支持多核CPU的一個說明


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲区中文字幕 | 日本中文字幕免费 | 在线亚洲成人 | 国产99欧美精品久久精品久久 | 欧美视频第二页 | 成人深夜网站 | 波霸欧美性猛交xxxxxx | 日本激情一区二区三区 | 四虎在线精品免费高清在线 | 国内女高中生一级毛片 | 欧美成人一区二区 | 成年黄网站免费大全毛片 | 欧美日韩一区二区三区毛片 | 国产精品久久久久久福利 | 九九热九九| 四虎影视成人永久在线播放 | 香蕉视频黄色在线观看 | dyav午夜片| 久久免费视频网 | 国产一区二区三区在线视频 | 欧美日韩加勒比一区二区三区 | 久久99精品九九九久久婷婷 | 日韩一级大毛片欧美一级 | 香蕉色香蕉在线视频 | www.日日日 | 色综合色综合色综合色综合 | 在线成人中文字幕 | 日本亚洲精品成人 | 亚洲美女视频在线观看 | 欧美高清在线视频一区二区 | 久久久久夜色精品波多野结衣 | 97久久精品视频 | 精品久久伦理中文字幕 | 综合在线视频 | 狠狠色丁香婷综合久久 | xxxx日本在线播放免费不卡 | 欧美乱大交xxxxxx喷潮免费 | 成人在线免费观看 | 国产精品19p | 久久国产高清一区二区三区 | 综合热久久|