[llvm] bc302bf - BasicAA: Recognize inttoptr as isEscapeSource
Joseph Tremoulet via llvm-commits
llvm-commits at lists.llvm.org
Fri May 7 07:49:08 PDT 2021
Author: Joseph Tremoulet
Date: 2021-05-07T07:48:50-07:00
New Revision: bc302bfbef84bd778a9e5e0a1b5851c6a55c1d9c
URL: https://github.com/llvm/llvm-project/commit/bc302bfbef84bd778a9e5e0a1b5851c6a55c1d9c
DIFF: https://github.com/llvm/llvm-project/commit/bc302bfbef84bd778a9e5e0a1b5851c6a55c1d9c.diff
LOG: BasicAA: Recognize inttoptr as isEscapeSource
Pointers escape when converted to integers, so a pointer produced by
converting an integer to a pointer must not be a local non-escaping
object.
Reviewed By: nikic, nlopes, aqjune
Differential Revision: https://reviews.llvm.org/D101541
Added:
llvm/test/Analysis/BasicAA/noalias-inttoptr.ll
Modified:
llvm/lib/Analysis/BasicAliasAnalysis.cpp
Removed:
################################################################################
diff --git a/llvm/lib/Analysis/BasicAliasAnalysis.cpp b/llvm/lib/Analysis/BasicAliasAnalysis.cpp
index 963fb1aa9ca30..dec7fcbfb3366 100644
--- a/llvm/lib/Analysis/BasicAliasAnalysis.cpp
+++ b/llvm/lib/Analysis/BasicAliasAnalysis.cpp
@@ -129,6 +129,14 @@ static bool isEscapeSource(const Value *V) {
if (isa<LoadInst>(V))
return true;
+ // The inttoptr case works because isNonEscapingLocalObject considers all
+ // means of converting or equating a pointer to an int (ptrtoint, ptr store
+ // which could be followed by an integer load, ptr<->int compare) as
+ // escaping, and objects located at well-known addresses via platform-specific
+ // means cannot be considered non-escaping local objects.
+ if (isa<IntToPtrInst>(V))
+ return true;
+
return false;
}
diff --git a/llvm/test/Analysis/BasicAA/noalias-inttoptr.ll b/llvm/test/Analysis/BasicAA/noalias-inttoptr.ll
new file mode 100644
index 0000000000000..ee3fd53875b0b
--- /dev/null
+++ b/llvm/test/Analysis/BasicAA/noalias-inttoptr.ll
@@ -0,0 +1,60 @@
+; RUN: opt < %s -basic-aa -aa-eval -print-all-alias-modref-info -disable-output 2>&1 | FileCheck %s
+target datalayout = "p:64:64"
+
+declare void @escape(i8* %ptr)
+
+; Verify that unescaped noalias parameter does not alias inttoptr
+define void @test1(i8* noalias %P, i64 %Q_as_int) {
+ ; CHECK-LABEL: Function: test1:
+ ; CHECK: NoAlias: i8* %P, i8* %Q
+ %Q = inttoptr i64 %Q_as_int to i8*
+ store i8 0, i8* %P
+ store i8 1, i8* %Q
+ ret void
+}
+
+; Verify that unescaped alloca does not alias inttoptr
+define void @test2(i64 %Q_as_int) {
+ ; CHECK-LABEL: Function: test2:
+ ; CHECK: NoAlias: i8* %P, i8* %Q
+ %P = alloca i8
+ %Q = inttoptr i64 %Q_as_int to i8*
+ store i8 0, i8* %P
+ store i8 1, i8* %Q
+ ret void
+}
+
+; Verify that escaped noalias parameter may alias inttoptr
+define void @test3(i8* noalias %P, i64 %Q_as_int) {
+ ; CHECK-LABEL: Function: test3:
+ ; CHECK: MayAlias: i8* %P, i8* %Q
+ call void @escape(i8* %P)
+ %Q = inttoptr i64 %Q_as_int to i8*
+ store i8 0, i8* %P
+ store i8 1, i8* %Q
+ ret void
+}
+
+; Verify that escaped alloca may alias inttoptr
+define void @test4(i64 %Q_as_int) {
+ ; CHECK-LABEL: Function: test4:
+ ; CHECK: MayAlias: i8* %P, i8* %Q
+ %P = alloca i8
+ call void @escape(i8* %P)
+ %Q = inttoptr i64 %Q_as_int to i8*
+ store i8 0, i8* %P
+ store i8 1, i8* %Q
+ ret void
+}
+
+
+; Verify that global may alias inttoptr
+ at G = external global i8
+define void @test5(i64 %Q_as_int) {
+ ; CHECK-LABEL: Function: test5:
+ ; CHECK: MayAlias: i8* %Q, i8* @G
+ %Q = inttoptr i64 %Q_as_int to i8*
+ store i8 0, i8* @G
+ store i8 1, i8* %Q
+ ret void
+}
More information about the llvm-commits
mailing list