; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt -passes=gvn -S < %s | FileCheck %s
; Check that PRE-LOAD across backedge does not
; result in invalid dominator tree.
declare void @use(i32)
define void @test1(i1 %c, i32 %arg) {
; CHECK-LABEL: @test1(
; CHECK-NEXT: br i1 [[C:%.*]], label [[BB1:%.*]], label [[DOTBB2_CRIT_EDGE:%.*]]
; CHECK: .bb2_crit_edge:
; CHECK-NEXT: [[DOTPRE:%.*]] = shl i32 [[ARG:%.*]], 2
; CHECK-NEXT: br label [[BB2:%.*]]
; CHECK: bb1:
; CHECK-NEXT: [[SHL1:%.*]] = shl i32 [[ARG]], 2
; CHECK-NEXT: br label [[BB3:%.*]]
; CHECK: bb2:
; CHECK-NEXT: [[SHL2_PRE_PHI:%.*]] = phi i32 [ [[DOTPRE]], [[DOTBB2_CRIT_EDGE]] ], [ [[SHL3:%.*]], [[BB3]] ]
; CHECK-NEXT: call void @use(i32 [[SHL2_PRE_PHI]])
; CHECK-NEXT: br label [[BB3]]
; CHECK: bb3:
; CHECK-NEXT: [[SHL3]] = shl i32 [[ARG]], 2
; CHECK-NEXT: [[GEP:%.*]] = getelementptr i32, ptr null, i32 [[SHL3]]
; CHECK-NEXT: [[V:%.*]] = load i32, ptr [[GEP]], align 4
; CHECK-NEXT: call void @use(i32 [[V]])
; CHECK-NEXT: br label [[BB2]]
;
br i1 %c, label %bb1, label %bb2
bb1:
%shl1 = shl i32 %arg, 2
br label %bb3
bb2:
%shl2 = shl i32 %arg, 2
call void @use(i32 %shl2)
br label %bb3
bb3:
%shl3 = shl i32 %arg, 2
%gep = getelementptr i32, ptr null, i32 %shl3
%v = load i32, ptr %gep, align 4
call void @use(i32 %v)
br label %bb2
}