; RUN: llvm-reduce -abort-on-invalid-reduction --delta-passes=basic-blocks --test FileCheck --test-arg --check-prefix=CHECK-INTERESTINGNESS0 --test-arg %s --test-arg --input-file %s -o %t.0
; RUN: FileCheck -check-prefix=RESULT0 %s < %t.0
; RUN: llvm-reduce -abort-on-invalid-reduction --delta-passes=basic-blocks --test FileCheck --test-arg --check-prefix=CHECK-INTERESTINGNESS1 --test-arg %s --test-arg --input-file %s -o %t.1
; RUN: FileCheck -check-prefix=RESULT1 %s < %t.1
; CHECK-INTERESTINGNESS0: store i32 1,
; CHECK-INTERESTINGNESS0: store i32 2,
; CHECK-INTERESTINGNESS1: store i32 2,
; RESULT0: bb:
; RESULT0-NEXT: %bb.load = load i32, ptr null, align 4
; RESULT0-NEXT: store i32 0, ptr null, align 4
; RESULT0-NEXT: br i1 %arg0, label %bb1, label %bb2
; RESULT0: bb1:
; RESULT0-NEXT: store i32 1, ptr null, align 4
; RESULT0-NEXT: ret void
; RESULT0: bb2: ; preds = %bb
; RESULT0-NEXT: store i32 2, ptr null, align 4
; RESULT0-NEXT: switch i32 %bb.load, label %bb1 [
; RESULT0-NEXT: i32 0, label %bb1
; RESULT0-NEXT: ]
; RESULT1: bb:
; RESULT1-NEXT: %bb.load = load i32, ptr null, align 4
; RESULT1-NEXT: store i32 0, ptr null, align 4
; RESULT1-NEXT: br label %bb2
; RESULT1: bb2:
; RESULT1-NEXT: store i32 2, ptr null, align 4
; RESULT1-NEXT: ret void
define void @main(i1 %arg0) {
bb:
%bb.load = load i32, ptr null
store i32 0, ptr null
br i1 %arg0, label %bb1, label %bb2
bb1:
%bb1.phi = phi i32 [%bb.load, %bb], [9, %bb3], [%bb2.phi, %bb2]
store i32 1, ptr null
ret void
bb2:
%bb2.phi = phi i32 [%bb.load, %bb], [%bb3.load, %bb3]
store i32 2, ptr null
switch i32 %bb2.phi, label %bb3 [
i32 0, label %bb1
i32 1, label %bb4
]
bb3:
%bb3.load = load i32, ptr null
store i32 3, ptr null
br i1 true, label %bb2, label %bb1
bb4:
store i32 4, ptr null
ret void
}