| Nick Kledzik | ad160c0 | 2009-09-14 23:26:56 +0000 | [diff] [blame^] | 1 | //===-- fixsfsivfp.S - Implement fixsfsivfp -----------------------===// | 
|  | 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 int __fixsfsivfp(float a); | 
|  | 13 | // | 
|  | 14 | // Converts single precision float to a 32-bit int rounding towards zero. | 
|  | 15 | // Uses Darwin calling convention where a single precision parameter is | 
|  | 16 | // passed in a GPR.. | 
|  | 17 | // | 
|  | 18 | .globl ___fixsfsivfp | 
|  | 19 | ___fixsfsivfp: | 
|  | 20 | fmsr	s15, r0      // load float register from R0 | 
|  | 21 | ftosizs	s15, s15     // convert single to 32-bit int into s15 | 
|  | 22 | fmrs	r0, s15	     // move s15 to result register | 
|  | 23 | bx	lr |