summaryrefslogtreecommitdiffstats
path: root/llvm/test
diff options
context:
space:
mode:
authorDavid Majnemer <david.majnemer@gmail.com>2016-03-24 21:40:22 +0000
committerDavid Majnemer <david.majnemer@gmail.com>2016-03-24 21:40:22 +0000
commite09d035dad21efbcd98b3f8c58af75709cc034e5 (patch)
tree55b2c4a3b8a7c5e30f6d24e7450e00051f50b5ca /llvm/test
parent3cf9ff12c51e1a446f019c001472f30024583fda (diff)
downloadbcm5719-llvm-e09d035dad21efbcd98b3f8c58af75709cc034e5.tar.gz
bcm5719-llvm-e09d035dad21efbcd98b3f8c58af75709cc034e5.zip
[LoopStrengthReduce] Don't hoist into a catchswitch
We try to hoist the insertion point as high as possible to encourage sharing. However, we must be careful not to hoist into a catchswitch as it is both an EHPad and a terminator. llvm-svn: 264344
Diffstat (limited to 'llvm/test')
-rw-r--r--llvm/test/Transforms/LoopStrengthReduce/pr27056.ll50
1 files changed, 50 insertions, 0 deletions
diff --git a/llvm/test/Transforms/LoopStrengthReduce/pr27056.ll b/llvm/test/Transforms/LoopStrengthReduce/pr27056.ll
new file mode 100644
index 00000000000..6a255f6f4e8
--- /dev/null
+++ b/llvm/test/Transforms/LoopStrengthReduce/pr27056.ll
@@ -0,0 +1,50 @@
+; RUN: opt < %s -loop-reduce -S | FileCheck %s
+target datalayout = "e-m:w-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-pc-windows-msvc18.0.0"
+
+%struct.L = type { i8, i8* }
+
+declare i32 @__CxxFrameHandler3(...)
+
+@GV1 = external global %struct.L*
+@GV2 = external global %struct.L
+
+define void @b_copy_ctor() personality i32 (...)* @__CxxFrameHandler3 {
+entry:
+ %0 = load %struct.L*, %struct.L** @GV1, align 8
+ br label %for.cond
+
+for.cond: ; preds = %call.i.noexc, %entry
+ %d.0 = phi %struct.L* [ %0, %entry ], [ %incdec.ptr, %call.i.noexc ]
+ invoke void @a_copy_ctor()
+ to label %call.i.noexc unwind label %catch.dispatch
+
+call.i.noexc: ; preds = %for.cond
+ %incdec.ptr = getelementptr inbounds %struct.L, %struct.L* %d.0, i64 1
+ br label %for.cond
+
+catch.dispatch: ; preds = %for.cond
+ %1 = catchswitch within none [label %catch] unwind to caller
+
+catch: ; preds = %catch.dispatch
+ %2 = catchpad within %1 [i8* null, i32 64, i8* null]
+ %cmp16 = icmp eq %struct.L* %0, %d.0
+ br i1 %cmp16, label %for.end, label %for.body
+
+for.body: ; preds = %for.body, %catch
+ %cmp = icmp eq %struct.L* @GV2, %d.0
+ br i1 %cmp, label %for.end, label %for.body
+
+for.end: ; preds = %for.body, %catch
+ catchret from %2 to label %try.cont
+
+try.cont: ; preds = %for.end
+ ret void
+}
+
+; CHECK-LABEL: define void @b_copy_ctor(
+; CHECK: catchpad
+; CHECK-NEXT: icmp eq %struct.L
+; CHECK-NEXT: getelementptr {{.*}} i64 sub (i64 0, i64 ptrtoint (%struct.L* @GV2 to i64))
+
+declare void @a_copy_ctor()
OpenPOWER on IntegriCloud