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

關于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條評論
主站蜘蛛池模板: 欧洲97色综合成人网 | 色综合a怡红院怡红院首页 色综合h | 男人天堂a | 国产精品呦呦 | 国产欧美另类久久久精品免费 | 夜夜女人国产香蕉久久精品 | 欧美精品久久 | 色色在线视频 | 国产精品久久视频 | 久久一区二区三区免费 | 中国女人内谢69xxxxx高清 | 免费一级成人毛片 | 天天看天天射 | 国产亚洲欧美另类一区二区三区 | 久久网站在线观看 | 日本黄色mv | 香蕉成人国产精品免费看网站 | 77777奇米 | 777色狠狠一区二区三区 | 国产 色 | 国产在线观看自拍 | 九九99久久精品在免费线bt | 看毛片视频| 亚洲国产精品一区二区第四页 | 久久香蕉影视 | 91在线精品视频 | 九九国产在线视频 | 天天操人人爱 | 国产原创精品 | 老子影院午夜精品欧美视频 | 亚洲 欧美 日韩在线综合福利 | 四虎综合九九色九九综合色 | 国产主播福利在线 | 久久频这里精品香蕉久久 | 久久精品国产半推半就 | 欧美男女爱爱视频 | 日本精品一区二区三区在线观看 | 国产在线91观看免费观看 | 国产午夜精品久久理论片 | 国产免费私人影院永久免费 | 国产成人精品日本亚洲专一区 |