From f56813d057512d1ac5c99dd14578bb456e89400d Mon Sep 17 00:00:00 2001 From: Chad Rosier Date: Mon, 7 Nov 2016 14:11:45 +0000 Subject: [PATCH] [AliasSetTracker] Make AST smarter about assume intrinsics that don't actually affect memory. Differential Revision: https://reviews.llvm.org/D26252 llvm-svn: 286108 --- lib/Analysis/AliasSetTracker.cpp | 12 ++++++++++++ test/Analysis/AliasSet/intrinsics.ll | 19 +++++++++++++++++++ 2 files changed, 31 insertions(+) create mode 100644 test/Analysis/AliasSet/intrinsics.ll 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)