25 lines
		
	
	
		
			895 B
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			25 lines
		
	
	
		
			895 B
		
	
	
	
		
			LLVM
		
	
	
	
; 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
 | 
						|
}
 |