; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -mtriple=i686-- -mcpu=i386 | FileCheck %s --check-prefix=BASE
; RUN: llc < %s -mtriple=i686-- -mcpu=pentiumpro | FileCheck %s --check-prefix=CMOV
; PR6679
define float @foo(ptr %col) {
; BASE-LABEL: foo:
; BASE: # %bb.0:
; BASE-NEXT: movl {{[0-9]+}}(%esp), %eax
; BASE-NEXT: flds (%eax)
; BASE-NEXT: fld %st(0)
; BASE-NEXT: fchs
; BASE-NEXT: fucom %st(1)
; BASE-NEXT: fnstsw %ax
; BASE-NEXT: # kill: def $ah killed $ah killed $ax
; BASE-NEXT: sahf
; BASE-NEXT: ja .LBB0_2
; BASE-NEXT: # %bb.1:
; BASE-NEXT: fstp %st(0)
; BASE-NEXT: fldz
; BASE-NEXT: fxch %st(1)
; BASE-NEXT: .LBB0_2:
; BASE-NEXT: fstp %st(1)
; BASE-NEXT: retl
;
; CMOV-LABEL: foo:
; CMOV: # %bb.0:
; CMOV-NEXT: movl {{[0-9]+}}(%esp), %eax
; CMOV-NEXT: flds (%eax)
; CMOV-NEXT: fld %st(0)
; CMOV-NEXT: fchs
; CMOV-NEXT: fucomi %st(1), %st
; CMOV-NEXT: fxch %st(1)
; CMOV-NEXT: fcmovnbe %st(1), %st
; CMOV-NEXT: fstp %st(1)
; CMOV-NEXT: retl
%t = load float, ptr %col
%t16 = fcmp olt float %t, 0.0
%t20 = fsub float -0.000000e+00, %t
%ift = select i1 %t16, float %t20, float %t
ret float %ift
}