; 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 }