1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-25 04:02:41 +01:00
llvm-mirror/test/Transforms/LoopRotate/catchret.ll
Alina Sbirlea 91e00bac96 Update MemorySSA in LoopRotate.
Summary:
Teach LoopRotate to preserve MemorySSA.
Enable tests for correctness, dependency disabled by default.

Subscribers: sanjoy, jlebar, Prazek, george.burgess.iv, llvm-commits

Differential Revision: https://reviews.llvm.org/D51718

llvm-svn: 345216
2018-10-24 22:46:45 +00:00

43 lines
1009 B
LLVM
Executable File

; RUN: opt < %s -loop-rotate -S | FileCheck %s
; RUN: opt < %s -loop-rotate -enable-mssa-loop-dependency=true -verify-memoryssa -S | FileCheck %s
target triple = "x86_64-pc-windows-msvc"
declare void @always_throws()
define i32 @test() personality i8* bitcast (i32 (...)* @__CxxFrameHandler3 to i8*) {
entry:
invoke void @always_throws()
to label %continue unwind label %catch.dispatch
continue:
unreachable
catch.dispatch:
%t0 = catchswitch within none [label %catch] unwind to caller
catch:
%t1 = catchpad within %t0 [i8* null, i32 64, i8* null]
catchret from %t1 to label %for.cond
for.cond:
%sum = phi i32 [ %add, %for.body ], [ 0, %catch ]
%i = phi i32 [ %inc, %for.body ], [ 0, %catch ]
%cmp = icmp slt i32 %i, 1
br i1 %cmp, label %for.body, label %return
for.body:
%add = add nsw i32 1, %sum
%inc = add nsw i32 %i, 1
br label %for.cond
return:
ret i32 0
}
; CHECK: catch:
; CHECK-NEXT: catchpad
; CHECK-NEXT: catchret
declare i32 @__CxxFrameHandler3(...)