llvm/llvm/test/CodeGen/X86/domain-reassignment-implicit-def.ll

; RUN: llc -mcpu=skylake-avx512 -mtriple=x86_64-unknown-linux-gnu %s -o - | FileCheck %s

; Check that the X86 Domain Reassignment pass doesn't drop IMPLICIT_DEF nodes,
; which would later cause crashes (e.g. in LiveVariables) - see PR37430
define void @domain_reassignment_implicit_def(i1 %cond, ptr%mem, float %arg) {
; CHECK:    vxorps %xmm1, %xmm1, %xmm1
; CHECK:    vcmpneqss %xmm1, %xmm0, %k0
; CHECK:    kmovb %k0, (%rsi)
top:
  br i1 %cond, label %L19, label %L15

L15:                                              ; preds = %top
  %tmp47 = fcmp une float 0.000000e+00, %arg
  %tmp48 = zext i1 %tmp47 to i8
  br label %L21

L19:                                              ; preds = %top
  br label %L21

L21:                                              ; preds = %L19, %L15
  %.sroa.0.0 = phi i8 [ undef, %L19 ], [ %tmp48, %L15 ]
  store i8 %.sroa.0.0, ptr %mem, align 1
  ret void
}