[llvm-dev] Function call replacement (original) (raw)
zxhuan via llvm-dev llvm-dev at lists.llvm.org
Wed Mar 3 22:43:02 PST 2021
- Previous message: [llvm-dev] Function call replacement
- Next message: [llvm-dev] reinterpret_cast of pointer-to-member
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
OK. I managed to figure it out. For ppl that might have the same demand, here is the code:
for (auto ui = foo->user_begin(); ui != foo->user_end(); ++ui) { Value *v = *ui; v->replaceAllUsesWith(ConstantExpr::getBitCast(new_foo, i8p_t)); }
Looking back, it's that simple. But it took me quite a while to figure out the right way to do it. Several other approaches were also tried, but all failed eventually. One of them is iterating all vtable global variables. But I can't figure out how to iterate over the function pointers and then get the cast-from type of the elements. Besides, this seems less efficient than the approach above. But still, an interesting exploration experience.
On Wed, Mar 3, 2021 at 9:56 PM zxhuan <huanzhixuan at gmail.com> wrote:
Thanks for the prompt reply! There is this function: ZN7threads11WorkerGroup3RunEv, demangled as threads::WorkerGroup::Run(), in one of the benchmarks from PARSEC. I assume this is similar to the run method of a thread class in Java, that is designed to be invoked by some library function during runtime.
I do notice for the above mentioned function, useempty() returns false. However, creating a call site and then trying to locate the call instruction is futile. That being said, I am not sure if we can use the useiterator returned by userbegin() to do something. Can you give some hint about how to locate and change that array of function pointers(namely, the vtable)? Thanks a lot, Jason On Wed, Mar 3, 2021 at 9:10 PM David Blaikie <dblaikie at gmail.com> wrote:
On Wed, Mar 3, 2021 at 4:50 PM zxhuan <huanzhixuan at gmail.com> wrote:
One example can be a constructor of a class, say class Foo, in C++. When you have a vector of Foo instances, the constructor will be called by the library function of vector.
Even in this example, you'd find the call to Foo's constructor in the module somewhere. The "library function of vector" would be instantiated in this same translation unit and emitted into the LLVM IR module. If the call is really coming from outside the module there's not much you can do to effect it. There are many such functions, that you can't know they are actually executed until the runtime. Beside that, I have done some research today. This has to be done by modifying the class's vtable. If the function is virtual, and if you have access to the vtable (perhaps it's in another module/translation unit too). I have manually modified the IR file and it works. But I just can't find an API function of LLVM to modify the vtable of the class. LLVM IR doesn't know much about vtables - it's "just" another array of function pointers as far as LLVM is concerned. But you could modify that array if you like.
On Wed, Mar 3, 2021 at 3:03 PM David Blaikie <dblaikie at gmail.com> wrote:
On Wed, Mar 3, 2021 at 11:55 AM zxhuan via llvm-dev <_ _llvm-dev at lists.llvm.org> wrote: Hi all, I am trying to replace calls to a function, say foo() with calls to myfoo(). In the IR file, there is no call to foo(). However, foo() will be called during execution. Can't say I'm following here ^ there is no call to foo() but it is called during execution? Is it called indirectly (eg: void (*x)() = foo; x(); )? is the call in another module/not this IR file? I can't use the conventional way to do it (i.e. locate the call instruction, create a call site and then create a call to myfoo(), then replace all uses with the return value of myfoo()), because you can't locate the call instruction. So I tried to swap the name of foo() and myfoo(). However, this only results in the original function with the new name being called. I know I must have missed some steps, resulting in the reference to the original function still existing after the renaming. The question is, what is the missing step? Thank you so much for reading my description. I hope I make my question clear. Best, Jason
LLVM Developers mailing list llvm-dev at lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev
-------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20210304/e44ca0d2/attachment-0001.html>
- Previous message: [llvm-dev] Function call replacement
- Next message: [llvm-dev] reinterpret_cast of pointer-to-member
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]