Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / compiler-rt / lib / builtins / int_to_fp.h
blob2c1218f1e89c4fa9908037d9fb11b2806aaf46de
1 //===-- int_to_fp.h - integer to floating point conversion ----------------===//
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 //
9 // Set source and destination defines in order to use a correctly
10 // parameterised floatXiYf implementation.
12 //===----------------------------------------------------------------------===//
14 #ifndef INT_TO_FP_H
15 #define INT_TO_FP_H
17 #include "int_lib.h"
19 #if defined SRC_I64
20 typedef int64_t src_t;
21 typedef uint64_t usrc_t;
22 static __inline int clzSrcT(usrc_t x) { return __builtin_clzll(x); }
24 #elif defined SRC_U64
25 typedef uint64_t src_t;
26 typedef uint64_t usrc_t;
27 static __inline int clzSrcT(usrc_t x) { return __builtin_clzll(x); }
29 #elif defined SRC_I128
30 typedef __int128_t src_t;
31 typedef __uint128_t usrc_t;
32 static __inline int clzSrcT(usrc_t x) { return __clzti2(x); }
34 #elif defined SRC_U128
35 typedef __uint128_t src_t;
36 typedef __uint128_t usrc_t;
37 static __inline int clzSrcT(usrc_t x) { return __clzti2(x); }
39 #else
40 #error Source should be a handled integer type.
41 #endif
43 #if defined DST_SINGLE
44 typedef float dst_t;
45 typedef uint32_t dst_rep_t;
46 #define DST_REP_C UINT32_C
48 enum {
49 dstSigBits = 23,
52 #elif defined DST_DOUBLE
53 typedef double dst_t;
54 typedef uint64_t dst_rep_t;
55 #define DST_REP_C UINT64_C
57 enum {
58 dstSigBits = 52,
61 #elif defined DST_QUAD
62 typedef tf_float dst_t;
63 typedef __uint128_t dst_rep_t;
64 #define DST_REP_C (__uint128_t)
66 enum {
67 dstSigBits = 112,
70 #else
71 #error Destination should be a handled floating point type
72 #endif
74 static __inline dst_t dstFromRep(dst_rep_t x) {
75 const union {
76 dst_t f;
77 dst_rep_t i;
78 } rep = {.i = x};
79 return rep.f;
82 #endif // INT_TO_FP_H