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

雁過無痕

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  弄著玩的。功能是簡單的實(shí)現(xiàn)函數(shù)轉(zhuǎn)發(fā),即
      調(diào)用CALL(func),轉(zhuǎn)為調(diào)用func(),
      調(diào)用CALL(func, arg1, arg2) ,轉(zhuǎn)為調(diào)用func(arg1, arg2)

  代碼中,宏CALL/STDCALL分別用來調(diào)用  __cdecl/__stdcall 調(diào)用規(guī)定的函數(shù)
             unsafe_call 兩者都可調(diào)用,但它不是多線程安全的。

  代碼只支持x86 32位, 除內(nèi)嵌匯編部分,盡量符合C++11標(biāo)準(zhǔn)。
       
原理:
     剛進(jìn)入函數(shù)時(shí),
     [esp]           函數(shù)返回地址
     [esp + 4]     第一個(gè)參數(shù),即轉(zhuǎn)發(fā)函數(shù)的地址
     [esp + 8]     第二個(gè)參數(shù),即轉(zhuǎn)發(fā)函數(shù)的的第一個(gè)參數(shù)
     ... 
   
      只要寫三行匯編指令實(shí)現(xiàn)一個(gè)c_call函數(shù),就可調(diào)用轉(zhuǎn)發(fā)函數(shù)
      pop eax                             ; eax為函數(shù)返回地址
      xchg dword ptr[esp], eax     ; eax為轉(zhuǎn)發(fā)函數(shù)的地址,[esp]為函數(shù)返回地址
      jmp eax
     
     當(dāng)轉(zhuǎn)發(fā)函數(shù)是__cdecl,即轉(zhuǎn)發(fā)函數(shù)不會(huì)調(diào)節(jié)棧,由于在c_call,pop eax,使esp多加了4,因而在調(diào)用完c_call后應(yīng)該手動(dòng)將esp值減4,保證棧平衡。
   
    當(dāng)轉(zhuǎn)發(fā)函數(shù)是__stdcall,轉(zhuǎn)發(fā)函數(shù)會(huì)調(diào)節(jié)棧,調(diào)用轉(zhuǎn)發(fā)函數(shù)完畢后,棧已經(jīng)保持平衡,因而調(diào)用c_call完畢,不應(yīng)該進(jìn)行棧指針調(diào)節(jié)。似乎將c_call的調(diào)用改為__stdcall即可,但實(shí)際上c_call有變長參數(shù),改成__stdcall沒效果,每次調(diào)用編譯器還是會(huì)自動(dòng)生成調(diào)節(jié)棧指針代碼。因而只能每次調(diào)用完畢,編譯器給esp加了多少,就手動(dòng)減多少。(編譯器不一定會(huì)生成 call  xxxx; add esp, xx這樣的代碼,通過改函數(shù)返回地址,忽略后面的add esp, xx指令是很糟糕的做法。)
call_redirect
posted on 2012-08-05 21:02 flyinghearts 閱讀(1856) 評(píng)論(8)  編輯 收藏 引用 所屬分類: C++

評(píng)論

# re: 內(nèi)嵌匯編實(shí)現(xiàn)的函數(shù)轉(zhuǎn)發(fā) 2012-08-06 14:02 rix
typedef int (*func_ptr)(...);
int call_fun(func_ptr func, ...);
#define PUSH __asm push 0
int call_fun(func_ptr func, ...)
{
*((int*)(&func)-1) = (*((int*)(&func)-1))^(*((int*)(&func)));
*((int*)(&func)) = (*((int*)(&func)-1))^(*((int*)(&func)));
*((int*)(&func)-1) = (*((int*)(&func)-1))^(*((int*)(&func)));
return (int)func;
}

#define START_CALL PUSH
#define END_CALL

int main (int argc, char * argv[])
{
START_CALL;
call_fun((func_ptr)func_1, 1, 2);
END_CALL;
START_CALL;
printf("func_2 return=%d\n", call_fun((func_ptr)func_2));
END_CALL;
START_CALL;
call_fun((func_ptr)func_3, "printf this:%d, %s\n", 1, "ok");
END_CALL;
return 0;
}  回復(fù)  更多評(píng)論
  

# re: 內(nèi)嵌匯編實(shí)現(xiàn)的函數(shù)轉(zhuǎn)發(fā)[未登錄] 2012-08-06 15:31 heroboy
這樣?
template<class T,class A1>
T Call(T(*f)())
{
return f();
}

template<class T,class A1>
T Call(T(*f)(A1),A1 a)
{
return f(a);
}

template<class T,class A1,class A2>
T Call(T(*f)(A1),A1 a,A2 b)
{
return f(a,b);
}
  回復(fù)  更多評(píng)論
  

# re: 內(nèi)嵌匯編實(shí)現(xiàn)的函數(shù)轉(zhuǎn)發(fā) 2012-08-06 21:43 flyinghearts
@rix
這個(gè)代碼顯然是錯(cuò)的。
call_fun只是簡單返回 func的值而已。  回復(fù)  更多評(píng)論
  

# re: 內(nèi)嵌匯編實(shí)現(xiàn)的函數(shù)轉(zhuǎn)發(fā) 2012-08-06 21:57 flyinghearts
@heroboy
你的模板寫錯(cuò)了。

用模板優(yōu)點(diǎn)不說了,就說說缺點(diǎn)吧:
如果轉(zhuǎn)發(fā)函數(shù)的參數(shù)是不定的,模板無法匹配到。
另外,類型匹配太嚴(yán)格了,若參數(shù)類型是const char*, 傳入"123"字符串都要先轉(zhuǎn)下類型,特別是參數(shù)是數(shù)字時(shí),非要查看下參數(shù)是int還是long,還是其它的。用起來太累人。



  回復(fù)  更多評(píng)論
  

# re: 內(nèi)嵌匯編實(shí)現(xiàn)的函數(shù)轉(zhuǎn)發(fā) 2012-08-13 12:03 rix
@flyinghearts
自己調(diào)用下就知道了。
*((int*)(&func)-1) = (*((int*)(&func)-1))^(*((int*)(&func)));
*((int*)(&func)) = (*((int*)(&func)-1))^(*((int*)(&func)));
*((int*)(&func)-1) = (*((int*)(&func)-1))^(*((int*)(&func)));
關(guān)鍵在這個(gè)交換的地方,而不是返回值。  回復(fù)  更多評(píng)論
  

# re: 內(nèi)嵌匯編實(shí)現(xiàn)的函數(shù)轉(zhuǎn)發(fā) 2012-08-14 21:10 flyinghearts
@rix
你的做法,還是避免不了要 內(nèi)嵌匯編。這個(gè)做法似乎可行,但卻存在很大問題:過于依賴于編譯器怎么優(yōu)化。有些編譯器會(huì)認(rèn)為那段代碼在做無意義的事,直接優(yōu)化掉。你用gcc試試。

另外,交換兩個(gè)數(shù),那樣寫法,可讀性差,效率也差,。







  回復(fù)  更多評(píng)論
  

# re: 內(nèi)嵌匯編實(shí)現(xiàn)的函數(shù)轉(zhuǎn)發(fā) 2012-08-17 21:25 flyinghearts
@rix
你那樣寫不可取,至少要寫成下面這樣,保證不被優(yōu)化掉:

void* c_call(void* func, ...)
{
typedef void* type;
const type tmp = func;
volatile type& eip = func;
volatile type& ret_addr = *(&func - 1);
eip = ret_addr;
ret_addr = tmp;
return (void*)tmp;
}

但是這樣又存在一個(gè)大問題:要保證調(diào)用這個(gè)函數(shù)時(shí),不會(huì)被內(nèi)聯(lián),一但被內(nèi)聯(lián),bug就來了。




  回復(fù)  更多評(píng)論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            狼狼综合久久久久综合网| 亚洲电影一级黄| 亚洲一区二区三区高清不卡| 亚洲人成人99网站| 久久综合亚州| 亚洲精品国产视频| 99re66热这里只有精品3直播 | 欧美一级夜夜爽| 午夜视频一区| 亚洲国产精品日韩| 亚洲乱码一区二区| 国产日韩欧美在线播放| 久久噜噜亚洲综合| 欧美黑人在线观看| 小黄鸭视频精品导航| 久久久久久一区二区三区| 亚洲国产精品第一区二区| 亚洲美女免费视频| 国际精品欧美精品| 亚洲日本中文| 国产欧美在线观看| 亚洲第一色在线| 国产精品亚洲欧美| 欧美一区二区三区啪啪| 亚洲欧美美女| 亚洲在线中文字幕| 最新日韩av| 午夜精品久久久久影视| 亚洲精品一区二区三区不| 亚洲欧美精品| 日韩亚洲欧美在线观看| 欧美一级在线播放| 亚洲视频专区在线| 老司机成人网| 久久精品91久久久久久再现| 欧美人成网站| 欧美sm重口味系列视频在线观看| 国产精品国产三级国产aⅴ9色| 欧美大秀在线观看| 国产欧美一区二区精品忘忧草 | 午夜综合激情| 欧美激情网站在线观看| 免费成人在线观看视频| 国产精品一级二级三级| 亚洲精品久久久蜜桃| 欲香欲色天天天综合和网| 亚洲永久免费| 亚洲一区二区三区在线观看视频 | 久久精品国产99精品国产亚洲性色 | 一区二区高清视频在线观看| 91久久久在线| 久久免费精品日本久久中文字幕| 欧美一区二区视频在线| 欧美视频二区| 日韩视频免费| 一级日韩一区在线观看| 欧美成人精品激情在线观看| 免费h精品视频在线播放| 国内成人精品一区| 欧美主播一区二区三区美女 久久精品人| 在线一区二区三区做爰视频网站| 欧美高清自拍一区| 亚洲黄页视频免费观看| 亚洲毛片在线观看| 欧美激情精品| 日韩视频在线免费| 亚洲一区二区三区午夜| 国产精品女同互慰在线看| 亚洲天堂成人| 亚洲欧美中日韩| 国产欧美激情| 久久国产免费看| 久久亚洲私人国产精品va媚药| 韩日欧美一区二区| 久久午夜国产精品| 亚洲国产高清自拍| 夜夜嗨一区二区| 国产精品激情| 香蕉久久夜色精品国产| 久久久久久久久久久久久女国产乱| 国产亚洲一区二区在线观看| 久久久久久精| 亚洲片国产一区一级在线观看| 中文精品视频一区二区在线观看| 国产精品激情| 国产精品99久久99久久久二8 | 亚洲一区二区在线观看视频| 欧美一区二区三区播放老司机| 国产无遮挡一区二区三区毛片日本| 久久久xxx| 日韩视频一区二区三区在线播放免费观看| 一区二区三区不卡视频在线观看| 欧美性猛交视频| 久久久国产精品亚洲一区| 欧美顶级少妇做爰| 亚洲欧美大片| 亚洲激情视频在线| 国产精品户外野外| 久久噜噜亚洲综合| av成人黄色| 免费欧美网站| 午夜亚洲性色视频| 亚洲激情小视频| 国产精品综合久久久| 欧美成人四级电影| 性亚洲最疯狂xxxx高清| 亚洲青涩在线| 另类天堂av| 午夜精品久久久久久| 91久久在线观看| 国产亚洲欧美日韩在线一区| 欧美精品一区二区在线播放| 欧美在线免费播放| 正在播放亚洲一区| 亚洲国产一区二区三区青草影视| 久久激情中文| 亚洲免费在线视频一区 二区| 亚洲国产成人午夜在线一区| 国产欧美日韩综合一区在线观看| 欧美全黄视频| 欧美va天堂va视频va在线| 欧美专区在线播放| 亚洲一区在线免费观看| 亚洲九九精品| 91久久精品网| 欧美福利电影网| 狼人天天伊人久久| 性欧美在线看片a免费观看| 亚洲最新中文字幕| 日韩图片一区| 亚洲日本在线观看| 亚洲人成网站精品片在线观看 | 亚洲国产成人在线| 尤妮丝一区二区裸体视频| 国产亚洲欧美日韩美女| 国产午夜精品全部视频播放| 国产精品狼人久久影院观看方式| 欧美日韩亚洲综合一区| 欧美人与禽猛交乱配视频| 欧美激情综合色| 欧美精品久久99久久在免费线| 麻豆91精品| 欧美99久久| 欧美精品三级在线观看| 欧美精品自拍偷拍动漫精品| 欧美激情一区在线| 欧美日韩亚洲一区二区三区在线观看 | 欧美电影免费观看高清| 欧美顶级艳妇交换群宴| 亚洲福利在线视频| 亚洲乱码国产乱码精品精可以看| 亚洲精品久久久久久一区二区| 亚洲人成网站在线播| 久久久午夜视频| 乱人伦精品视频在线观看| 欧美激情aⅴ一区二区三区| 欧美国产成人精品| 国产精品爱久久久久久久| 国产精品一区二区男女羞羞无遮挡 | 免费一级欧美片在线播放| 欧美 日韩 国产 一区| 欧美精品一区二区三| 欧美午夜剧场| 国产一区二区欧美日韩| 亚洲国产精品热久久| 亚洲特色特黄| 久久久精品性| 亚洲国产日韩欧美在线图片 | 久久成人综合网| 欧美国产激情| 在线一区二区日韩| 久久av最新网址| 欧美久久在线| 国产一区二区日韩| 亚洲精选大片| 久久国产精品免费一区| 欧美岛国激情| 亚洲一区视频| 欧美99在线视频观看| 国产精品自在在线| 亚洲人成在线观看一区二区| 欧美亚洲综合网| 亚洲国产精品视频| 欧美亚洲视频在线观看| 欧美精品自拍| 在线观看日韩专区| 香蕉成人久久| 亚洲国产精品第一区二区| 欧美一区成人| 国产精品白丝av嫩草影院| 亚洲电影免费观看高清完整版在线观看 | 亚洲精品1区2区| 欧美在线观看视频| 日韩亚洲欧美高清| 乱码第一页成人| 韩日欧美一区二区三区| 性视频1819p久久| 亚洲伦理在线免费看| 免费欧美在线视频| 伊人久久亚洲美女图片|