My friends, I ran a function pass on a .bc file, intending to insert a CallInst to my self-made check function. The compilation is successful. BUT after I ran that pass on the .bc file, the size of the file didn't get any bigger!! Does this mean my instrumentation work failed?? BTW the opt command I use is "opt -load ../../../Debug+Asserts/lib/Hello.so -hello <hello.bc> -o hello.bc" Does this command mean to run hello pass on hello.bc and send the result to hello.bc??? The source code of the function pass is as follow. // for each function traverse the instruction in it for (Function::iterator BI = F.begin(), BE = F.end(); BI != BE; ++BI) { for(BasicBlock::iterator II = BI->begin(),IE = BI->end();II != IE; ++II) { // we only care the instruction that call for functions and it can be cast to CallInst if(CallInst * III = dyn_cast<CallInst>(II)) { // if the callInst is calling for puts function if(III->getCalledFunction()!=NULL&&III->getCalledFunction()->getName()=="puts") { errs() <<III->getCalledFunction()->getName()<<" function found!\n"; // declare the extern function(int check()) that I want to instrument in the .bc file Function *check = cast<Function>(III->getCalledFunction()->getParent()->getOrInsertFunction("check", Type::getInt32Ty(III->getCalledFunction()->getParent()->getContext()), (Type *)0)); // Create the CallInst to call for the check function! CallInst *callcheck = CallInst::Create(check,"CallCheck"); // insert the CallInst right before II callcheck->insertBefore(II); errs() <<"INSERT SUCCEEDED!!!!!!!!\n"; } else { errs() <<"it's not main function!\n"<<"it is:"<<III->getCalledFunction()->getName()<<'\n'; } } } -- 祝好! 甄凯 ------------------------------------------------------------------------------------------------------ 2012-04-10 ------------------------------------------------------------------------------------------------------ Name: 甄凯(ZhenKai) Homepage:http://www.renren.com/262729393 Email: zhenkaixd at 126.com or 846227103 at qq.com TEL: 15810729006(Beijing) Address: Room I-406, Central Building, Tsinghua University, Beijing, China. 100084. -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20120410/30529ce2/attachment.html>
I figured that my opt command is wrong! How to specify the output file anyway?? if I want hello.bc to be input file and newhello.bc to be output file, is the opt command go like this? opt -load ../../../Debug+Asserts/lib/Hello.so -hello <hello.bc> -o newhello.bc ?? -- 祝好! 甄凯 ------------------------------------------------------------------------------------------------------ 2012-04-10 ------------------------------------------------------------------------------------------------------ Name: 甄凯(ZhenKai) Homepage:http://www.renren.com/262729393 Email: zhenkaixd at 126.com or 846227103 at qq.com TEL: 15810729006(Beijing) Address: Room I-406, Central Building, Tsinghua University, Beijing, China. 100084. At 2012-04-10 19:34:51,15102925731 <zhenkaixd at 126.com> wrote: My friends, I ran a function pass on a .bc file, intending to insert a CallInst to my self-made check function. The compilation is successful. BUT after I ran that pass on the .bc file, the size of the file didn't get any bigger!! Does this mean my instrumentation work failed?? BTW the opt command I use is "opt -load ../../../Debug+Asserts/lib/Hello.so -hello <hello.bc> -o hello.bc" Does this command mean to run hello pass on hello.bc and send the result to hello.bc??? The source code of the function pass is as follow. // for each function traverse the instruction in it for (Function::iterator BI = F.begin(), BE = F.end(); BI != BE; ++BI) { for(BasicBlock::iterator II = BI->begin(),IE = BI->end();II != IE; ++II) { // we only care the instruction that call for functions and it can be cast to CallInst if(CallInst * III = dyn_cast<CallInst>(II)) { // if the callInst is calling for puts function if(III->getCalledFunction()!=NULL&&III->getCalledFunction()->getName()=="puts") { errs() <<III->getCalledFunction()->getName()<<" function found!\n"; // declare the extern function(int check()) that I want to instrument in the .bc file Function *check = cast<Function>(III->getCalledFunction()->getParent()->getOrInsertFunction("check", Type::getInt32Ty(III->getCalledFunction()->getParent()->getContext()), (Type *)0)); // Create the CallInst to call for the check function! CallInst *callcheck = CallInst::Create(check,"CallCheck"); // insert the CallInst right before II callcheck->insertBefore(II); errs() <<"INSERT SUCCEEDED!!!!!!!!\n"; } else { errs() <<"it's not main function!\n"<<"it is:"<<III->getCalledFunction()->getName()<<'\n'; } } } -- 祝好! 甄凯 ------------------------------------------------------------------------------------------------------ 2012-04-10 ------------------------------------------------------------------------------------------------------ Name: 甄凯(ZhenKai) Homepage:http://www.renren.com/262729393 Email: zhenkaixd at 126.com or 846227103 at qq.com TEL: 15810729006(Beijing) Address: Room I-406, Central Building, Tsinghua University, Beijing, China. 100084. -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20120410/70728456/attachment.html>
I 've checked the introduction of the opt-tool on" http://llvm.org/releases/1.0/docs/CommandGuide/opt.html " And it says -o <filename> Specify the output filename. but I tried "opt -load ../../../Debug+Asserts/lib/Hello.so -hello <hello.bc> -o newhello.bc" and get "opt: newhello.bc: error: Could not openinput file: No such file or directory" It's not output file! Any help? -- 祝好! 甄凯 ------------------------------------------------------------------------------------------------------ 2012-04-10 ------------------------------------------------------------------------------------------------------ Name: 甄凯(ZhenKai) Homepage:http://www.renren.com/262729393 Email: zhenkaixd at 126.com or 846227103 at qq.com TEL: 15810729006(Beijing) Address: Room I-406, Central Building, Tsinghua University, Beijing, China. 100084. At 2012-04-10 19:38:36,15102925731 <zhenkaixd at 126.com> wrote: I figured that my opt command is wrong! How to specify the output file anyway?? if I want hello.bc to be input file and newhello.bc to be output file, is the opt command go like this? opt -load ../../../Debug+Asserts/lib/Hello.so -hello <hello.bc> -o newhello.bc ?? -- 祝好! 甄凯 ------------------------------------------------------------------------------------------------------ 2012-04-10 ------------------------------------------------------------------------------------------------------ Name: 甄凯(ZhenKai) Homepage:http://www.renren.com/262729393 Email: zhenkaixd at 126.com or 846227103 at qq.com TEL: 15810729006(Beijing) Address: Room I-406, Central Building, Tsinghua University, Beijing, China. 100084. At 2012-04-10 19:34:51,15102925731 <zhenkaixd at 126.com> wrote: My friends, I ran a function pass on a .bc file, intending to insert a CallInst to my self-made check function. The compilation is successful. BUT after I ran that pass on the .bc file, the size of the file didn't get any bigger!! Does this mean my instrumentation work failed?? BTW the opt command I use is "opt -load ../../../Debug+Asserts/lib/Hello.so -hello <hello.bc> -o hello.bc" Does this command mean to run hello pass on hello.bc and send the result to hello.bc??? The source code of the function pass is as follow. // for each function traverse the instruction in it for (Function::iterator BI = F.begin(), BE = F.end(); BI != BE; ++BI) { for(BasicBlock::iterator II = BI->begin(),IE = BI->end();II != IE; ++II) { // we only care the instruction that call for functions and it can be cast to CallInst if(CallInst * III = dyn_cast<CallInst>(II)) { // if the callInst is calling for puts function if(III->getCalledFunction()!=NULL&&III->getCalledFunction()->getName()=="puts") { errs() <<III->getCalledFunction()->getName()<<" function found!\n"; // declare the extern function(int check()) that I want to instrument in the .bc file Function *check = cast<Function>(III->getCalledFunction()->getParent()->getOrInsertFunction("check", Type::getInt32Ty(III->getCalledFunction()->getParent()->getContext()), (Type *)0)); // Create the CallInst to call for the check function! CallInst *callcheck = CallInst::Create(check,"CallCheck"); // insert the CallInst right before II callcheck->insertBefore(II); errs() <<"INSERT SUCCEEDED!!!!!!!!\n"; } else { errs() <<"it's not main function!\n"<<"it is:"<<III->getCalledFunction()->getName()<<'\n'; } } } -- 祝好! 甄凯 ------------------------------------------------------------------------------------------------------ 2012-04-10 ------------------------------------------------------------------------------------------------------ Name: 甄凯(ZhenKai) Homepage:http://www.renren.com/262729393 Email: zhenkaixd at 126.com or 846227103 at qq.com TEL: 15810729006(Beijing) Address: Room I-406, Central Building, Tsinghua University, Beijing, China. 100084. -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20120410/5080e293/attachment.html>
Hi,> BTW the opt command I use is *"opt -load ../../../Debug+Asserts/lib/Hello.so > -hello <hello.bc> -o hello.bc"*just use hello.bc not <hello.bc> otherwise the shell will redirect input and output. Ciao, Duncan.
I did it !!!! YOU MADE MY DAY !!!!!!!!!!!!!!! -- 祝好! 甄凯 ------------------------------------------------------------------------------------------------------ 2012-04-10 ------------------------------------------------------------------------------------------------------ Name: 甄凯(ZhenKai) Homepage:http://www.renren.com/262729393 Email: zhenkaixd at 126.com or 846227103 at qq.com TEL: 15810729006(Beijing) Address: Room I-406, Central Building, Tsinghua University, Beijing, China. 100084. At 2012-04-10 19:55:04,"Duncan Sands" <baldrick at free.fr> wrote:>Hi, > >> BTW the opt command I use is *"opt -load ../../../Debug+Asserts/lib/Hello.so >> -hello <hello.bc> -o hello.bc"* > >just use hello.bc not <hello.bc> otherwise the shell will redirect input and >output. > >Ciao, Duncan. >_______________________________________________ >LLVM Developers mailing list >LLVMdev at cs.uiuc.edu http://llvm.cs.uiuc.edu >http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev-------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20120410/83ad69da/attachment.html>
Reasonably Related Threads
- [LLVMdev] How to explain this weird phenomenon????????
- [LLVMdev] How to explain this weird phenomenon????????
- [LLVMdev] How to explain this weird phenomenon????????
- [LLVMdev] How to explain this weird phenomenon????????
- [LLVMdev] How to compile a linux module into .bc file using clang or llvm command?