blob: c39c69839ae56957463f2eef01a066bea4df7f1c [file] [log] [blame]
Nick Kledzikad160c02009-09-14 23:26:56 +00001//===-- fixunssfsivfp.S - Implement fixunssfsivfp -------------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10
11//
12// extern unsigned int __fixunssfsivfp(float a);
13//
14// Converts single precision float to a 32-bit unsigned int rounding towards
15// zero. All negative values become zero.
16// Uses Darwin calling convention where a single precision parameter is
17// passed in a GPR..
18//
19 .globl ___fixunssfsivfp
20___fixunssfsivfp:
21 fmsr s15, r0 // load float register from R0
22 ftouizs s15, s15 // convert single to 32-bit unsigned into s15
23 fmrs r0, s15 // move s15 to result register
24 bx lr