From: Chad Rosier Date: Mon, 7 Nov 2016 14:11:45 +0000 (+0000) Subject: [AliasSetTracker] Make AST smarter about assume intrinsics that don't actually affect... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=4438f466744584cda5b8cf8c630341e9ae8bc022;p=llvm [AliasSetTracker] Make AST smarter about assume intrinsics that don't actually affect memory. Differential Revision: https://reviews.llvm.org/D26252 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@286108 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/AliasSetTracker.cpp b/lib/Analysis/AliasSetTracker.cpp index 954b22037ed..701b0e1a592 100644 --- a/lib/Analysis/AliasSetTracker.cpp +++ b/lib/Analysis/AliasSetTracker.cpp @@ -413,6 +413,18 @@ void AliasSetTracker::add(MemTransferInst *MTI) { void AliasSetTracker::addUnknown(Instruction *Inst) { if (isa(Inst)) return; // Ignore DbgInfo Intrinsics. + + if (auto *II = dyn_cast(Inst)) { + // These intrinsics will show up as affecting memory, but they are just + // markers. + switch (II->getIntrinsicID()) { + default: + break; + // FIXME: Add lifetime/invariant intrinsics (See: PR30807). + case Intrinsic::assume: + return; + } + } if (!Inst->mayReadOrWriteMemory()) return; // doesn't alias anything diff --git a/test/Analysis/AliasSet/intrinsics.ll b/test/Analysis/AliasSet/intrinsics.ll new file mode 100644 index 00000000000..100b5a10134 --- /dev/null +++ b/test/Analysis/AliasSet/intrinsics.ll @@ -0,0 +1,19 @@ +; RUN: opt -basicaa -print-alias-sets -S -o - < %s 2>&1 | FileCheck %s + +; CHECK: Alias sets for function 'test1': +; CHECK: Alias Set Tracker: 2 alias sets for 2 pointer values. +; CHECK: AliasSet[0x{{[0-9a-f]+}}, 1] must alias, Mod Pointers: (i8* %a, 1) +; CHECK-NOT: 1 Unknown instruction +; CHECK: AliasSet[0x{{[0-9a-f]+}}, 1] must alias, Mod Pointers: (i8* %b, 1) +define void @test1(i32 %c) { +entry: + %a = alloca i8, align 1 + %b = alloca i8, align 1 + store i8 1, i8* %a, align 1 + %cond1 = icmp ne i32 %c, 0 + call void @llvm.assume(i1 %cond1) + store i8 1, i8* %b, align 1 + ret void +} + +declare void @llvm.assume(i1)