llvm/llvm/test/tools/llvm-reduce/reduce-bb-unreachable-does-not-dominate-error2.ll

; RUN: llvm-reduce --abort-on-invalid-reduction --delta-passes=basic-blocks --test FileCheck --test-arg --check-prefixes=CHECK-INTERESTINGNESS --test-arg %s --test-arg --input-file %s -o %t
; RUN: FileCheck %s < %t

; Make sure an invalid reduction isn't produced due to leaving behind
; invalid code in %bb8 after it becomes unreachable.

; CHECK-INTERESTINGNESS: store i32 0,
; CHECK-INTERESTINGNESS: store i32 1,
; CHECK-INTERESTINGNESS: store i32 2,


; CHECK: bb:
; CHECK-NEXT: store i32 0, ptr addrspace(3) null, align 4

; CHECK: bb6: ; preds = %bb8, %bb
; CHECK-NEXT: store i32 1, ptr addrspace(3) null, align 4

; CHECK: bb8: ; preds = %bb6
; CHECK-NEXT: %tmp = phi ptr addrspace(5) [ null, %bb6 ]
define amdgpu_kernel void @foo(i32 %arg) {
bb:
  store i32 0, ptr addrspace(3) null
  br label %bb6

bb6:                                              ; preds = %bb10, %bb9, %bb8, %bb
  store i32 1, ptr addrspace(3) null
  switch i32 0, label %bb7 [
    i32 0, label %bb8
  ]

bb7:                                              ; preds = %bb6
  unreachable

bb8:                                              ; preds = %bb6
  %tmp = phi ptr addrspace(5) [ null, %bb6 ]
  store i32 2, ptr addrspace(5) %tmp
  switch i32 %arg, label %bb6 [
    i32 0, label %bb10
    i32 1, label %bb9
  ]

bb9:                                              ; preds = %bb8
  br label %bb6

bb10:                                             ; preds = %bb8
  br label %bb6
}