]> granicus.if.org Git - llvm/commitdiff
Fix AAResults::callCapturesBefore for operand bundles
authorSanjoy Das <sanjoy@playingwithpointers.com>
Mon, 13 Jun 2016 19:55:04 +0000 (19:55 +0000)
committerSanjoy Das <sanjoy@playingwithpointers.com>
Mon, 13 Jun 2016 19:55:04 +0000 (19:55 +0000)
Summary:
AAResults::callCapturesBefore would previously ignore operand
bundles. It was possible for a later instruction to miss its memory
dependency on a call site that would only access the pointer through a
bundle.

Patch by Oscar Blumberg!

Reviewers: sanjoy

Differential Revision: http://reviews.llvm.org/D21286

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@272580 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/AliasAnalysis.cpp
test/CodeGen/X86/statepoint-memdep.ll [new file with mode: 0644]

index 117f8cb123f466194a99130fee454d30876f57c0..263dd48bfea3b0be4920182bbcc17384d7013b32 100644 (file)
@@ -445,7 +445,7 @@ ModRefInfo AAResults::callCapturesBefore(const Instruction *I,
 
   unsigned ArgNo = 0;
   ModRefInfo R = MRI_NoModRef;
-  for (ImmutableCallSite::arg_iterator CI = CS.arg_begin(), CE = CS.arg_end();
+  for (auto CI = CS.data_operands_begin(), CE = CS.data_operands_end();
        CI != CE; ++CI, ++ArgNo) {
     // Only look at the no-capture or byval pointer arguments.  If this
     // pointer were passed to arguments that were neither of these, then it
diff --git a/test/CodeGen/X86/statepoint-memdep.ll b/test/CodeGen/X86/statepoint-memdep.ll
new file mode 100644 (file)
index 0000000..c22a25e
--- /dev/null
@@ -0,0 +1,17 @@
+; RUN: opt -S -dse < %s | FileCheck %s
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+define void @f() {
+  ; CHECK-LABEL: @f(
+  %s = alloca i64
+  ; Verify that this first store is not considered killed by the second one
+  ; since it could be observed from the deopt continuation.
+  ; CHECK: store i64 1, i64* %s
+  store i64 1, i64* %s
+  call void @g() [ "deopt"(i64* %s) ]
+  store i64 0, i64* %s
+  ret void
+}
+
+declare void @g()