; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc < %s -mtriple=x86_64-apple-macosx10.15.0 -O0 | FileCheck %s define i32 @a() { ; CHECK-LABEL: a: ; CHECK: ## %bb.0: ## %entry ; CHECK-NEXT: pushq %rax ; CHECK-NEXT: .cfi_def_cfa_offset 16 ; CHECK-NEXT: xorl %eax, %eax ; CHECK-NEXT: ## kill: def $al killed $al killed $eax ; CHECK-NEXT: callq _b ; CHECK-NEXT: cvtsi2sd %eax, %xmm1 ; CHECK-NEXT: movq _calloc@GOTPCREL(%rip), %rax ; CHECK-NEXT: subq $-1, %rax ; CHECK-NEXT: setne %al ; CHECK-NEXT: movzbl %al, %eax ; CHECK-NEXT: cvtsi2sd %eax, %xmm0 ; CHECK-NEXT: movsd {{.*#+}} xmm2 = [1.0E+2,0.0E+0] ; CHECK-NEXT: subsd %xmm2, %xmm0 ; CHECK-NEXT: movsd {{.*#+}} xmm3 = [1.0E+0,0.0E+0] ; CHECK-NEXT: movsd {{.*#+}} xmm2 = [3.1400000000000001E+0,0.0E+0] ; CHECK-NEXT: cmplesd %xmm1, %xmm0 ; CHECK-NEXT: movaps %xmm0, %xmm1 ; CHECK-NEXT: andpd %xmm3, %xmm1 ; CHECK-NEXT: andnpd %xmm2, %xmm0 ; CHECK-NEXT: orpd %xmm1, %xmm0 ; CHECK-NEXT: cvttsd2si %xmm0, %eax ; CHECK-NEXT: popq %rcx ; CHECK-NEXT: retq entry: %call = call i32 (...) @b() %conv = sitofp i32 %call to double %sel = select i1 icmp ne (ptr getelementptr (i8, ptr @calloc, i64 1), ptr null), i32 1, i32 0 %sitofp = sitofp i32 %sel to double %fsub = fsub double %sitofp, 1.000000e+02 %cmp = fcmp ole double %fsub, %conv %cond = select i1 %cmp, double 1.000000e+00, double 3.140000e+00 %conv2 = fptosi double %cond to i32 ret i32 %conv2 } declare ptr @calloc(i64, i64) declare i32 @b(...)