[llvm] r277072 - Do not remove empty lifetime.start/lifetime.end ranges
Vitaly Buka via llvm-commits
llvm-commits at lists.llvm.org
Thu Jul 28 15:59:03 PDT 2016
Author: vitalybuka
Date: Thu Jul 28 17:59:03 2016
New Revision: 277072
URL: http://llvm.org/viewvc/llvm-project?rev=277072&view=rev
Log:
Do not remove empty lifetime.start/lifetime.end ranges
Summary:
Asan stack-use-after-scope check should poison alloca even if there is
no access between start and end.
This is possible for code like this:
for (int i = 0; i < 3; i++) {
int x;
p = &x;
}
"Loop Invariant Code Motion" will move "p = &x;" out of the loop, making
start/end range empty.
PR27453
Reviewers: eugenis
Differential Revision: https://reviews.llvm.org/D22842
Added:
llvm/trunk/test/Transforms/InstCombine/lifetime-asan.ll
Modified:
llvm/trunk/lib/Transforms/InstCombine/InstCombineCalls.cpp
Modified: llvm/trunk/lib/Transforms/InstCombine/InstCombineCalls.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/InstCombine/InstCombineCalls.cpp?rev=277072&r1=277071&r2=277072&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/InstCombine/InstCombineCalls.cpp (original)
+++ llvm/trunk/lib/Transforms/InstCombine/InstCombineCalls.cpp Thu Jul 28 17:59:03 2016
@@ -2243,6 +2243,11 @@ Instruction *InstCombiner::visitCallInst
break;
}
case Intrinsic::lifetime_start:
+ // Asan needs to poison memory to detect invalid access which is possible
+ // even for empty lifetime range.
+ if (II->getFunction()->hasFnAttribute(Attribute::SanitizeAddress))
+ break;
+
if (removeTriviallyEmptyRange(*II, Intrinsic::lifetime_start,
Intrinsic::lifetime_end, *this))
return nullptr;
Added: llvm/trunk/test/Transforms/InstCombine/lifetime-asan.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstCombine/lifetime-asan.ll?rev=277072&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/InstCombine/lifetime-asan.ll (added)
+++ llvm/trunk/test/Transforms/InstCombine/lifetime-asan.ll Thu Jul 28 17:59:03 2016
@@ -0,0 +1,35 @@
+; RUN: opt < %s -instcombine -S | FileCheck %s
+
+declare void @llvm.lifetime.start(i64, i8* nocapture)
+declare void @llvm.lifetime.end(i64, i8* nocapture)
+declare void @foo(i8* nocapture)
+
+define void @asan() sanitize_address {
+entry:
+ ; CHECK-LABEL: @asan(
+ %text = alloca i8, align 1
+
+ call void @llvm.lifetime.start(i64 1, i8* %text)
+ call void @llvm.lifetime.end(i64 1, i8* %text)
+ ; CHECK: call void @llvm.lifetime.start
+ ; CHECK-NEXT: call void @llvm.lifetime.end
+
+ call void @foo(i8* %text) ; Keep alloca alive
+
+ ret void
+}
+
+
+define void @no_asan() {
+entry:
+ ; CHECK-LABEL: @no_asan(
+ %text = alloca i8, align 1
+
+ call void @llvm.lifetime.start(i64 1, i8* %text)
+ call void @llvm.lifetime.end(i64 1, i8* %text)
+ ; CHECK-NO: call void @llvm.lifetime
+
+ call void @foo(i8* %text) ; Keep alloca alive
+
+ ret void
+}
More information about the llvm-commits
mailing list