extendxftf2.c 736 B

123456789101112131415161718192021222324
  1. //===-- lib/extendxftf2.c - long double -> quad conversion --------*- C -*-===//
  2. //
  3. // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
  4. // See https://llvm.org/LICENSE.txt for license information.
  5. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  6. //
  7. //===----------------------------------------------------------------------===//
  8. // Assumption: long double is a IEEE 80 bit floating point type padded to 128
  9. // bits.
  10. #define QUAD_PRECISION
  11. #include "fp_lib.h"
  12. #if defined(CRT_HAS_TF_MODE) && __LDBL_MANT_DIG__ == 64 && defined(__x86_64__)
  13. #define SRC_80
  14. #define DST_QUAD
  15. #include "fp_extend_impl.inc"
  16. COMPILER_RT_ABI tf_float __extendxftf2(xf_float a) {
  17. return __extendXfYf2__(a);
  18. }
  19. #endif