[PATCH] D60004: [WebAssembly] Handle END_LOOP in unreachable BB in CFGStackify

Heejin Ahn via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Fri Mar 29 12:36:33 PDT 2019


This revision was automatically updated to reflect the committed changes.
Closed by commit rL357303: [WebAssembly] Handle END_LOOP in unreachable BB in CFGStackify (authored by aheejin, committed by ).

Repository:
  rL LLVM

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D60004/new/

https://reviews.llvm.org/D60004

Files:
  llvm/trunk/lib/Target/WebAssembly/WebAssemblyCFGStackify.cpp
  llvm/trunk/test/CodeGen/WebAssembly/cfg-stackify-dbg.mir


Index: llvm/trunk/lib/Target/WebAssembly/WebAssemblyCFGStackify.cpp
===================================================================
--- llvm/trunk/lib/Target/WebAssembly/WebAssemblyCFGStackify.cpp
+++ llvm/trunk/lib/Target/WebAssembly/WebAssemblyCFGStackify.cpp
@@ -411,7 +411,9 @@
   // Mark the end of the loop (using arbitrary debug location that branched to
   // the loop end as its location).
   InsertPos = getEarliestInsertPos(AfterLoop, BeforeSet, AfterSet);
-  DebugLoc EndDL = (*AfterLoop->pred_rbegin())->findBranchDebugLoc();
+  DebugLoc EndDL = AfterLoop->pred_empty()
+                       ? DebugLoc()
+                       : (*AfterLoop->pred_rbegin())->findBranchDebugLoc();
   MachineInstr *End =
       BuildMI(*AfterLoop, InsertPos, EndDL, TII.get(WebAssembly::END_LOOP));
   registerScope(Begin, End);
Index: llvm/trunk/test/CodeGen/WebAssembly/cfg-stackify-dbg.mir
===================================================================
--- llvm/trunk/test/CodeGen/WebAssembly/cfg-stackify-dbg.mir
+++ llvm/trunk/test/CodeGen/WebAssembly/cfg-stackify-dbg.mir
@@ -0,0 +1,27 @@
+# RUN: llc -mtriple=wasm32-unknown-unknown -run-pass wasm-cfg-stackify %s -o - | FileCheck %s
+
+# This tests if END_LOOP marker is placed correctly when the BB it is to be
+# placed is unreachable. Regression test for PR41307.
+
+# CHECK-LABEL: unreachable_test
+name: unreachable_test
+liveins:
+  - { reg: '$arguments' }
+body: |
+  bb.0:
+    successors: %bb.1
+
+  bb.1:
+  ; predecessors: %bb.0, %bb.2
+    successors: %bb.2
+
+  bb.2:
+  ; predecessors: %bb.1
+    successors: %bb.1
+    BR %bb.1, implicit-def dead $arguments
+
+  ; CHECK: bb.3
+  ; CHECK: END_LOOP
+  bb.3:
+    UNREACHABLE implicit-def $arguments
+...


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D60004.192891.patch
Type: text/x-patch
Size: 1733 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190329/32c05e4f/attachment-0001.bin>


More information about the llvm-commits mailing list