[PATCH] D34862: [CGP] Relax a bit restriction for optimizeMemoryInst to extend scope

Serguei Katkov via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Wed Jul 5 06:16:19 PDT 2017


skatkov updated this revision to Diff 105261.
skatkov added a comment.

This should be better, please take a look.


https://reviews.llvm.org/D34862

Files:
  lib/CodeGen/CodeGenPrepare.cpp
  test/CodeGen/X86/sink-gep-before-mem-inst.ll


Index: test/CodeGen/X86/sink-gep-before-mem-inst.ll
===================================================================
--- /dev/null
+++ test/CodeGen/X86/sink-gep-before-mem-inst.ll
@@ -0,0 +1,25 @@
+; RUN: opt < %s -S -codegenprepare -mtriple=x86_64-unknown-linux-gnu | FileCheck %s
+
+define i64 @test.after(i8 addrspace(1)* readonly align 8) {
+; CHECK-LABEL: test.after
+; CHECK: sunkaddr
+entry:
+  %.0 = getelementptr inbounds i8, i8 addrspace(1)* %0, i64 8
+  %addr = bitcast i8 addrspace(1)* %.0 to i32 addrspace(1)*
+  br label %header
+
+header:
+  %addr.in.loop = phi i32 addrspace(1)* [ %addr, %entry ], [ %addr.after, %header ]
+  %local_2_ = phi i64 [ 0, %entry ], [ %.9, %header ]
+  %.7 = load i32, i32 addrspace(1)* %addr.in.loop, align 8
+  fence acquire
+  %.1 = getelementptr inbounds i8, i8 addrspace(1)* %0, i64 8
+  %addr.after = bitcast i8 addrspace(1)* %.1 to i32 addrspace(1)*
+  %.8 = sext i32 %.7 to i64
+  %.9 = add i64 %local_2_, %.8
+  %not. = icmp sgt i64 %.9, 999
+  br i1 %not., label %exit, label %header
+
+exit:
+  ret i64 %.9
+}
Index: lib/CodeGen/CodeGenPrepare.cpp
===================================================================
--- lib/CodeGen/CodeGenPrepare.cpp
+++ lib/CodeGen/CodeGenPrepare.cpp
@@ -4345,8 +4345,23 @@
   if (none_of(AddrModeInsts, [&](Value *V) {
         return IsNonLocalValue(V, MemoryInst->getParent());
       })) {
-    DEBUG(dbgs() << "CGP: Found      local addrmode: " << AddrMode << "\n");
-    return false;
+    // All instructions are in the same basic block.
+    // Let's ensure that all of them earlier in basic block than memory
+    // instruction.
+    SmallPtrSet<Instruction *, 16> AddrModeInstsSet(AddrModeInsts.begin(),
+                                                    AddrModeInsts.end());
+    unsigned Count = AddrModeInstsSet.size();
+    for (Instruction &I : *(MemoryInst->getParent())) {
+      if (&I == MemoryInst)
+        break;
+      Count -= AddrModeInstsSet.count(&I);
+      if (!Count)
+        break;
+    }
+    if (!Count) {
+      DEBUG(dbgs() << "CGP: Found      local addrmode: " << AddrMode << "\n");
+      return false;
+    }
   }
 
   // Insert this computation right after this user.  Since our caller is


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D34862.105261.patch
Type: text/x-patch
Size: 2226 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20170705/3a1e1a59/attachment-0001.bin>


More information about the llvm-commits mailing list