1*3cab2bb3Spatrick//===-- floatsisfvfp.S - Implement floatsisfvfp ---------------------------===// 2*3cab2bb3Spatrick// 3*3cab2bb3Spatrick// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4*3cab2bb3Spatrick// See https://llvm.org/LICENSE.txt for license information. 5*3cab2bb3Spatrick// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6*3cab2bb3Spatrick// 7*3cab2bb3Spatrick//===----------------------------------------------------------------------===// 8*3cab2bb3Spatrick 9*3cab2bb3Spatrick#include "../assembly.h" 10*3cab2bb3Spatrick 11*3cab2bb3Spatrick// 12*3cab2bb3Spatrick// extern float __floatsisfvfp(int a); 13*3cab2bb3Spatrick// 14*3cab2bb3Spatrick// Converts single precision float to a 32-bit int rounding towards zero. 15*3cab2bb3Spatrick// Uses Darwin calling convention where a single precision result is 16*3cab2bb3Spatrick// return in a GPR.. 17*3cab2bb3Spatrick// 18*3cab2bb3Spatrick .syntax unified 19*3cab2bb3Spatrick .p2align 2 20*3cab2bb3SpatrickDEFINE_COMPILERRT_FUNCTION(__floatsisfvfp) 21*3cab2bb3Spatrick#if defined(COMPILER_RT_ARMHF_TARGET) 22*3cab2bb3Spatrick vmov s0, r0 23*3cab2bb3Spatrick vcvt.f32.s32 s0, s0 24*3cab2bb3Spatrick#else 25*3cab2bb3Spatrick vmov s15, r0 // move int to float register s15 26*3cab2bb3Spatrick vcvt.f32.s32 s15, s15 // convert 32-bit int in s15 to float in s15 27*3cab2bb3Spatrick vmov r0, s15 // move s15 to result register 28*3cab2bb3Spatrick#endif 29*3cab2bb3Spatrick bx lr 30*3cab2bb3SpatrickEND_COMPILERRT_FUNCTION(__floatsisfvfp) 31*3cab2bb3Spatrick 32*3cab2bb3SpatrickNO_EXEC_STACK_DIRECTIVE 33*3cab2bb3Spatrick 34