我正在尝试将函数调用替换为另一个函数调用。例如,以下是具有3个功能的代码-print1,print2和main:
#include <stdio.h>
extern "C" {
int print1()
{
printf("Inside print1\n");
return 0xdeadbeef;
}
int print2()
{
printf("Inside print2\n");
return 0xbeefdead;
}
int main(void)
{
return print1();
}
}"
我的目标是将print1(主要是)替换为print2。我将上面的代码编译成llvm :: Module *(在下面的代码中称为main),然后从中创建执行引擎。
std::string errMsg;
llvm::ExecutionEngine *ee =
llvm::EngineBuilder( main ).setErrorStr( &errMsg ).create();
ASSERT_NE( ee, nullptr )<<"Execution engine is nullptr:"<<errMsg;
至此,我能够从执行引擎中获得所有3个功能(print1,print2和main),并且能够很好地执行它们。但是,当我尝试将函数“ print1”替换为“ print2”时,会出现问题,如下所示:
llvm::Function *print1f = main->getFunction( "print1" );
llvm::Function *print2f = main->getFunction( "print2" );
llvm::Function *mainf = main->getFunction( "main" );
//carry out the replacement
print2f->takeName( print1f );
ee->freeMachineCodeForFunction( mainf );
ee->freeMachineCodeForFunction( print1f );
print1f->replaceAllUsesWith( print2f );
print1f->deleteBody();
print1f->dropAllReferences();
print1f->eraseFromParent();
//run main
void *mainfPtr = ee->getPointerToFunction( mainf );
mainfPtr = ee->recompileAndRelinkFunction( mainf );
ASSERT_NE( mainfPtr, nullptr );
ret = ((int(*)(void))(mainfPtr))();
*EXPECT_EQ(0xbeefdead, ret);*
但是,ret返回为0xdeadbeef,就像正在调用print1而不是print2一样。有人可以让我知道我是否按照正确的步骤替换了函数调用。如果还有其他方法,请告诉我。
谢谢维卡斯。
==========
如果编译器内联print1
的main
,功能永远不会真正被称为; 相反,main
将print1
粘贴自己的私有代码版本。由于实际上print1
不再需要引用共享了,因此换入print2
可能不会影响main
的行为。
如果要验证这是问题所在(和/或避免它发生,请尝试告诉编译器不要内联)。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句