[cfe-dev] [LLVMdev] Clang devirtualization proposal
Hal Finkel
hfinkel at anl.gov
Sat Jul 25 12:30:47 PDT 2015
----- Original Message -----
> From: "Richard Smith" <richard at metafoo.co.uk>
> To: "Piotr Padlewski" <prazek at google.com>
> Cc: "llvmdev at cs.uiuc.edu Mailing List" <llvmdev at cs.uiuc.edu>, "cfe-dev at cs.uiuc.edu Developers" <cfe-dev at cs.uiuc.edu>
> Sent: Thursday, July 23, 2015 4:21:42 PM
> Subject: Re: [cfe-dev] [LLVMdev] Clang devirtualization proposal
>
> On Thu, Jul 23, 2015 at 11:42 AM, Piotr Padlewski < prazek at google.com
> > wrote:
>
>
>
> HI,
> Yep, our proposal doesn't cover it, because this load ; icmp ;
> assume; will land global initilizer function, and main will not see
> it.
> At least if foo would be called multiple times, then we would only
> have one load from vtable, but unfortunatelly we will not be able to
> inline, or make direct call to it with this approach.
> I think that this case is rare enough to solve it right now.
>
>
> Piotr
>
>
> On Thu, Jul 23, 2015 at 10:30 AM, Geoff Berry < gberry at codeaurora.org
> > wrote:
>
>
>
>
>
>
> Hi Piotr,
>
>
>
> You may be interested in a recent patch I posted:
> http://reviews.llvm.org/D11043
>
>
>
> This patch addresses a de-virtualization case that I’m not sure would
> be handled by your current proposal, namely that of a virtual call
> where the ‘this’ object is a global variable.
>
> For example:
>
>
>
> struct A {
>
> A();
>
> virtual void foo();
>
> };
>
> void g(A * a) {
>
> a->foo();
>
> }
>
>
>
> A a;
>
> int main() {
>
> g(&a);
>
>
> We could in principle emit the load/icmp/assume for a's vptr here,
> but I'm concerned that this is not actually sound in general.
> Consider:
>
>
> struct A;
> extern A a;
> void *p = &a; // emit load/icmp/assume here?
> struct A { virtual void f(); };
> A a;
>
>
> If we emit an assume on the vptr at the point where the address of a
> is taken, we get:
>
>
> @a = global %A zeroinitializer
> void @global_init() {
> load @a
> %x = icmp @a, @A.vtable
> call @llvm.assume(%x)
> store @a, @p
> call @A::A(@a)
> }
>
>
> ... where the assume call can be folded to "call @llvm.assume(i1
> false)", which (presumably) can be reduced further to "unreachable"
To confirm, yes, @llvm.assume(false) -> unreachable by llvm::removeUnreachableBlocks.
-Hal
> (oops). (In Geoff's example, this is sound only because we're
> guaranteed that 'a' is initialized before we enter 'main', but an
> optimization that only fires for code within 'main' doesn't sound
> very useful.)
>
>
> We could support this with something weaker than the current
> load/icmp/assume pattern: we could imagine an instruction/intrinsic
> that says "any later load of pointer %p with !invariant.group !g
> will load the value %q", but that does not imply that the value %q
> is currently stored in %p. It's not clear to me whether that has
> sufficient value to be worthwhile.
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
> }
>
>
>
> It might be worth considering if your approach could be extended to
> handle this case.
>
>
>
>
> --
>
> Geoff Berry
>
> Employee of Qualcomm Innovation Center, Inc.
>
> Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a
> Linux Foundation Collaborative Project
>
>
>
> From: llvmdev-bounces at cs.uiuc.edu [mailto:
> llvmdev-bounces at cs.uiuc.edu ] On Behalf Of Piotr Padlewski
> Sent: Wednesday, July 22, 2015 5:56 PM
> To: cfe-dev at cs.uiuc.edu Developers; llvmdev at cs.uiuc.edu
> Subject: [LLVMdev] Clang devirtualization proposal
>
>
>
>
>
> Hi folks,
>
>
> this summer I will work with Richard Smith on clang devirtualization.
> Check out our proposal:
>
>
>
>
> https://docs.google.com/document/d/1f2SGa4TIPuBGm6y6YO768GrQsA8awNfGEJSBFukLhYA/edit?usp=sharing
>
>
>
>
>
> And modified LangRef
>
>
> http://reviews.llvm.org/D11399
>
>
>
>
>
> You can also check out previous disscussion that was started before
> our proposal was ready -
> http://lists.cs.uiuc.edu/pipermail/cfe-dev/2015-July/044052.html
>
>
>
>
>
> Regards
>
>
> Piotr Padlewski
>
> _______________________________________________
> cfe-dev mailing list
> cfe-dev at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev
>
>
>
> _______________________________________________
> cfe-dev mailing list
> cfe-dev at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev
>
--
Hal Finkel
Assistant Computational Scientist
Leadership Computing Facility
Argonne National Laboratory
More information about the cfe-dev
mailing list