htyu wrote:

> > The work sounds interesting. Can you provide a bit more context about it? 
> > Will it be used to improve ICP when it's sufficient to just compare the 
> > vtable address instead of the vfunc address?
> 
> yes -- it can not only eliminate vtable load, but also enable target check 
> combining.
> 
> What is more important is that it can be combined with more aggressive 
> interprocedural type propagation that enables full (unconditional) 
> devirtualization. Example:
> 
> base->foo(); base->bar(); ==> if (base->vptr == Derived) { 
> Derived::foo(base); // base type is known so virtual calls in foo,bar can 
> further be devirtualized. Derived::bar(base); } else {.. }

Thanks for the illustration! Have you enabled this in your fleet, and how much 
performance improvement have you seen?

We've been also thinking about similar work based on sample PGO, in both the 
compiler and bolt.

https://github.com/llvm/llvm-project/pull/66825
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to