llvm-project/llvm/test/CodeGen/X86/pr44396.ll

48 lines
1.4 KiB
LLVM

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -mtriple=i386-apple-macosx10.15.0 -mattr=+cmov | FileCheck %s
@b = global i32 0, align 4
@a = global i64 0, align 8
define double @c() nounwind {
; CHECK-LABEL: c:
; CHECK: ## %bb.0: ## %entry
; CHECK-NEXT: pushl %esi
; CHECK-NEXT: subl $16, %esp
; CHECK-NEXT: movl _b, %eax
; CHECK-NEXT: movl %eax, %ecx
; CHECK-NEXT: sarl $31, %ecx
; CHECK-NEXT: movl _a+4, %edx
; CHECK-NEXT: movl _a, %esi
; CHECK-NEXT: subl %eax, %esi
; CHECK-NEXT: sbbl %ecx, %edx
; CHECK-NEXT: setb %al
; CHECK-NEXT: xorl %ecx, %ecx
; CHECK-NEXT: testl %edx, %edx
; CHECK-NEXT: setns %cl
; CHECK-NEXT: movl %esi, (%esp)
; CHECK-NEXT: movl %edx, {{[0-9]+}}(%esp)
; CHECK-NEXT: fildll (%esp)
; CHECK-NEXT: fadds LCPI0_0(,%ecx,4)
; CHECK-NEXT: fstpl {{[0-9]+}}(%esp)
; CHECK-NEXT: fldl {{[0-9]+}}(%esp)
; CHECK-NEXT: fldz
; CHECK-NEXT: testb %al, %al
; CHECK-NEXT: fxch %st(1)
; CHECK-NEXT: fcmovne %st(1), %st
; CHECK-NEXT: fstp %st(1)
; CHECK-NEXT: addl $16, %esp
; CHECK-NEXT: popl %esi
; CHECK-NEXT: retl
entry:
%0 = load i32, i32* @b, align 4
%conv = sext i32 %0 to i64
%1 = load i64, i64* @a, align 8
%cmp = icmp ult i64 %1, %conv
%sub = sub i64 %1, %conv
%conv3 = uitofp i64 %sub to double
%cond = select i1 %cmp, double 0.000000e+00, double %conv3
ret double %cond
}