Mercurial > hg > CbC > CbC_llvm
diff llvm/test/Transforms/GVN/callbr-scalarpre-critedge.ll @ 150:1d019706d866
LLVM10
author | anatofuz |
---|---|
date | Thu, 13 Feb 2020 15:10:13 +0900 |
parents | |
children | c4bab56944e8 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/llvm/test/Transforms/GVN/callbr-scalarpre-critedge.ll Thu Feb 13 15:10:13 2020 +0900 @@ -0,0 +1,43 @@ +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py +; RUN: opt < %s -gvn -S | FileCheck %s + +; This test checks that we don't hang trying to split a critical edge in scalar +; PRE when the control flow uses a callbr instruction. + +define void @wombat(i64 %arg, i64* %arg1, i64 %arg2, i32* %arg3) { +; CHECK-LABEL: @wombat( +; CHECK-NEXT: bb: +; CHECK-NEXT: [[TMP5:%.*]] = or i64 [[ARG2:%.*]], [[ARG:%.*]] +; CHECK-NEXT: callbr void asm sideeffect "", "X,X"(i8* blockaddress(@wombat, [[BB7:%.*]]), i8* blockaddress(@wombat, [[BB9:%.*]])) +; CHECK-NEXT: to label [[BB6:%.*]] [label [[BB7]], label %bb9] +; CHECK: bb6: +; CHECK-NEXT: br label [[BB7]] +; CHECK: bb7: +; CHECK-NEXT: [[TMP8:%.*]] = trunc i64 [[TMP5]] to i32 +; CHECK-NEXT: tail call void @barney(i32 [[TMP8]]) +; CHECK-NEXT: br label [[BB9]] +; CHECK: bb9: +; CHECK-NEXT: [[TMP10:%.*]] = trunc i64 [[TMP5]] to i32 +; CHECK-NEXT: store i32 [[TMP10]], i32* [[ARG3:%.*]] +; CHECK-NEXT: ret void +; +bb: + %tmp5 = or i64 %arg2, %arg + callbr void asm sideeffect "", "X,X"(i8* blockaddress(@wombat, %bb7), i8* blockaddress(@wombat, %bb9)) + to label %bb6 [label %bb7, label %bb9] + +bb6: ; preds = %bb + br label %bb7 + +bb7: ; preds = %bb6, %bb + %tmp8 = trunc i64 %tmp5 to i32 + tail call void @barney(i32 %tmp8) + br label %bb9 + +bb9: ; preds = %bb7, %bb + %tmp10 = trunc i64 %tmp5 to i32 + store i32 %tmp10, i32* %arg3 + ret void +} + +declare void @barney(i32)