//===-- lib/fp_compare_impl.inc - Floating-point comparison -------*- C -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "fp_lib.h" // GCC uses long (at least for x86_64) as the return type of the comparison // functions. We need to ensure that the return value is sign-extended in the // same way as GCC expects (since otherwise GCC-generated __builtin_isinf // returns true for finite 128-bit floating-point numbers). #ifdef __aarch64__ // AArch64 GCC overrides libgcc_cmp_return to use int instead of long. typedef int CMP_RESULT; #elif __SIZEOF_POINTER__ == 8 && __SIZEOF_LONG__ == 4 // LLP64 ABIs use long long instead of long. typedef long long CMP_RESULT; #elif __AVR__ // AVR uses a single byte for the return value. typedef char CMP_RESULT; #else // Otherwise the comparison functions return long. CMP_RESULT; #endif #if !defined(__clang__) && defined(__GNUC__) // GCC uses a special __libgcc_cmp_return__ mode to define the return type, so // check that we are ABI-compatible when compiling the builtins with GCC. typedef int GCC_CMP_RESULT __attribute__((__mode__(__libgcc_cmp_return__))); _Static_assert(sizeof(GCC_CMP_RESULT) == sizeof(CMP_RESULT), "SOFTFP ABI not compatible with GCC"); #endif enum { … }; static inline CMP_RESULT __leXf2__(fp_t a, fp_t b) { … } enum { … }; static inline CMP_RESULT __geXf2__(fp_t a, fp_t b) { … } static inline CMP_RESULT __unordXf2__(fp_t a, fp_t b) { … }