From 578dced0a16fd5011ce61da6d46f63a8aa64dcb5 Mon Sep 17 00:00:00 2001 From: David Majnemer Date: Mon, 16 Nov 2015 17:37:58 +0000 Subject: [PATCH] [LoopStrengthReduce] Don't increment iterator past the end of the BB We tried to move the insertion point beyond instructions like landingpad and cleanuppad. However, we *also* tried to move past catchpad. This is problematic because catchpad is also a terminator. This fixes PR25541. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@253238 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Scalar/LoopStrengthReduce.cpp | 2 +- test/Transforms/LoopStrengthReduce/pr25541.ll | 51 +++++++++++++++++++ 2 files changed, 52 insertions(+), 1 deletion(-) create mode 100644 test/Transforms/LoopStrengthReduce/pr25541.ll diff --git a/lib/Transforms/Scalar/LoopStrengthReduce.cpp b/lib/Transforms/Scalar/LoopStrengthReduce.cpp index 9351a284c86..6f34c9cb8cf 100644 --- a/lib/Transforms/Scalar/LoopStrengthReduce.cpp +++ b/lib/Transforms/Scalar/LoopStrengthReduce.cpp @@ -4435,7 +4435,7 @@ LSRInstance::AdjustInsertPositionForExpand(BasicBlock::iterator LowestIP, while (isa(IP)) ++IP; // Ignore landingpad instructions. - while (IP->isEHPad()) ++IP; + while (!isa(IP) && IP->isEHPad()) ++IP; // Ignore debug intrinsics. while (isa(IP)) ++IP; diff --git a/test/Transforms/LoopStrengthReduce/pr25541.ll b/test/Transforms/LoopStrengthReduce/pr25541.ll new file mode 100644 index 00000000000..fa64875d9af --- /dev/null +++ b/test/Transforms/LoopStrengthReduce/pr25541.ll @@ -0,0 +1,51 @@ +; 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-msvc" + +define void @f() personality i32 (...)* @__CxxFrameHandler3 { +entry: + br label %for.cond.i + +for.cond.i: ; preds = %for.inc.i, %entry + %_First.addr.0.i = phi i32* [ null, %entry ], [ %incdec.ptr.i, %for.inc.i ] + invoke void @g() + to label %for.inc.i unwind label %catch.dispatch.i + +catch.dispatch.i: ; preds = %for.cond.i + %0 = catchpad [i8* null, i32 64, i8* null] + to label %for.cond.1.preheader.i unwind label %catchendblock.i + +for.cond.1.preheader.i: ; preds = %catch.dispatch.i + %cmp.i = icmp eq i32* %_First.addr.0.i, null + br label %for.cond.1.i + +for.cond.1.i: ; preds = %for.body.i, %for.cond.1.preheader.i + br i1 %cmp.i, label %for.end.i, label %for.body.i + +for.body.i: ; preds = %for.cond.1.i + invoke void @g() + to label %for.cond.1.i unwind label %catchendblock.i + +catchendblock.i: ; preds = %for.body.i, %catch.dispatch.i + catchendpad unwind to caller + +for.inc.i: ; preds = %for.cond.i + %incdec.ptr.i = getelementptr inbounds i32, i32* %_First.addr.0.i, i64 1 + br label %for.cond.i + +for.end.i: ; preds = %for.cond.1.i + catchret %0 to label %leave + +leave: ; preds = %for.end.i + ret void +} + +; CHECK-LABEL: define void @f( +; CHECK: %[[PHI:.*]] = phi i64 [ %[[IV_NEXT:.*]], {{.*}} ], [ 0, {{.*}} ] +; CHECK: %[[ITOP:.*]] = inttoptr i64 %[[PHI]] to i32* +; CHECK: %[[CMP:.*]] = icmp eq i32* %[[ITOP]], null +; CHECK: %[[IV_NEXT]] = add i64 %[[PHI]], -4 + +declare void @g() + +declare i32 @__CxxFrameHandler3(...) -- 2.34.1