1e80e978d6aa211056beddf4582390e374d1935abNick Kledzik//===-- gesf2vfp.S - Implement gesf2vfp -----------------------------------===//
2e80e978d6aa211056beddf4582390e374d1935abNick Kledzik//
3e80e978d6aa211056beddf4582390e374d1935abNick Kledzik//                     The LLVM Compiler Infrastructure
4e80e978d6aa211056beddf4582390e374d1935abNick Kledzik//
59ad441ffec97db647fee3725b3424284fb913e14Howard Hinnant// This file is dual licensed under the MIT and the University of Illinois Open
69ad441ffec97db647fee3725b3424284fb913e14Howard Hinnant// Source Licenses. See LICENSE.TXT for details.
7e80e978d6aa211056beddf4582390e374d1935abNick Kledzik//
8e80e978d6aa211056beddf4582390e374d1935abNick Kledzik//===----------------------------------------------------------------------===//
9e80e978d6aa211056beddf4582390e374d1935abNick Kledzik
1019336a2d6b9b375ac106125950f4ff09742d1aecDaniel Dunbar#include "../assembly.h"
11e80e978d6aa211056beddf4582390e374d1935abNick Kledzik
12e80e978d6aa211056beddf4582390e374d1935abNick Kledzik//
13e80e978d6aa211056beddf4582390e374d1935abNick Kledzik// extern int __gesf2vfp(float a, float b);
14e80e978d6aa211056beddf4582390e374d1935abNick Kledzik//
15e80e978d6aa211056beddf4582390e374d1935abNick Kledzik// Returns one iff a >= b and neither is NaN.
16e80e978d6aa211056beddf4582390e374d1935abNick Kledzik// Uses Darwin calling convention where single precision arguments are passsed
17e80e978d6aa211056beddf4582390e374d1935abNick Kledzik// like 32-bit ints
18e80e978d6aa211056beddf4582390e374d1935abNick Kledzik//
19c20f862690410045fc8c77879f7e78918d2372e4Bob Wilson	.syntax unified
20d016b38b065fbe3e22584728c3b8bc55fc8a5f9cNick Kledzik	.align 2
21b4b1e8c5085cf83a50242057775a33ae4323d402Daniel DunbarDEFINE_COMPILERRT_FUNCTION(__gesf2vfp)
22c20f862690410045fc8c77879f7e78918d2372e4Bob Wilson	vmov	s14, r0	    // move from GPR 0 to float register
23c20f862690410045fc8c77879f7e78918d2372e4Bob Wilson	vmov	s15, r1	    // move from GPR 1 to float register
24c20f862690410045fc8c77879f7e78918d2372e4Bob Wilson	vcmp.f32 s14, s15
25c20f862690410045fc8c77879f7e78918d2372e4Bob Wilson	vmrs	apsr_nzcv, fpscr
26e80e978d6aa211056beddf4582390e374d1935abNick Kledzik	movge	r0, #1      // set result register to 1 if greater than or equal
27e80e978d6aa211056beddf4582390e374d1935abNick Kledzik	movlt	r0, #0
28e80e978d6aa211056beddf4582390e374d1935abNick Kledzik	bx	lr
29e80e978d6aa211056beddf4582390e374d1935abNick Kledzik
30