| OLD | NEW |
| 1 //===- subzero/runtime/szrt.c - Subzero runtime source ----------*- C++ -*-===// | 1 //===- subzero/runtime/szrt.c - Subzero runtime source ----------*- C++ -*-===// |
| 2 // | 2 // |
| 3 // The Subzero Code Generator | 3 // The Subzero Code Generator |
| 4 // | 4 // |
| 5 // This file is distributed under the University of Illinois Open Source | 5 // This file is distributed under the University of Illinois Open Source |
| 6 // License. See LICENSE.TXT for details. | 6 // License. See LICENSE.TXT for details. |
| 7 // | 7 // |
| 8 //===----------------------------------------------------------------------===// | 8 //===----------------------------------------------------------------------===// |
| 9 // | 9 // |
| 10 // This file implements the runtime helper routines that are needed by | 10 // This file implements wrappers for particular bitcode instructions |
| 11 // Subzero. This needs to be compiled by some non-Subzero compiler. | 11 // that are too uncommon and complex for a particular target to bother |
| 12 // implementing directly in Subzero target lowering. This needs to be |
| 13 // compiled by some non-Subzero compiler. |
| 12 // | 14 // |
| 13 //===----------------------------------------------------------------------===// | 15 //===----------------------------------------------------------------------===// |
| 14 | 16 |
| 15 #include <stdint.h> | 17 #include <stdint.h> |
| 16 #include <stdlib.h> | 18 #include <stdlib.h> |
| 17 | 19 |
| 18 uint32_t cvtftoui32(float value) { return (uint32_t)value; } | 20 // TODO(stichnot): The various NaN cross tests try to map Subzero's |
| 21 // undefined behavior to the same as llc's undefined behavior, as |
| 22 // observed by the cross tests. This will have to be kept up to date |
| 23 // with any future changes to llc, and may also have to be different |
| 24 // for different targets. It would be better to find a more |
| 25 // appropriate set of llc options when building the Subzero runtime. |
| 26 // |
| 27 // We test for NaN using "value==value" instead of using isnan(value) |
| 28 // to avoid an external dependency on fpclassify(). |
| 19 | 29 |
| 20 uint32_t cvtdtoui32(double value) { return (uint32_t)value; } | 30 uint32_t cvtftoui32(float value) { |
| 31 if (value == value) // NaNaN |
| 32 return (uint32_t)value; |
| 33 return 0x80000000; |
| 34 } |
| 35 |
| 36 uint32_t cvtdtoui32(double value) { |
| 37 if (value == value) // NaNaN |
| 38 return (uint32_t)value; |
| 39 return 0x80000000; |
| 40 } |
| 21 | 41 |
| 22 int64_t cvtftosi64(float value) { return (int64_t)value; } | 42 int64_t cvtftosi64(float value) { return (int64_t)value; } |
| 23 | 43 |
| 24 int64_t cvtdtosi64(double value) { return (int64_t)value; } | 44 int64_t cvtdtosi64(double value) { return (int64_t)value; } |
| 25 | 45 |
| 26 uint64_t cvtftoui64(float value) { return (uint64_t)value; } | 46 uint64_t cvtftoui64(float value) { return (uint64_t)value; } |
| 27 | 47 |
| 28 uint64_t cvtdtoui64(double value) { return (uint64_t)value; } | 48 uint64_t cvtdtoui64(double value) { return (uint64_t)value; } |
| 29 | 49 |
| 30 float cvtui32tof(uint32_t value) { return (float)value; } | 50 float cvtui32tof(uint32_t value) { return (float)value; } |
| 31 | 51 |
| 32 float cvtsi64tof(int64_t value) { return (float)value; } | 52 float cvtsi64tof(int64_t value) { return (float)value; } |
| 33 | 53 |
| 34 float cvtui64tof(uint64_t value) { return (float)value; } | 54 float cvtui64tof(uint64_t value) { return (float)value; } |
| 35 | 55 |
| 36 double cvtui32tod(uint32_t value) { return (double)value; } | 56 double cvtui32tod(uint32_t value) { return (double)value; } |
| 37 | 57 |
| 38 double cvtsi64tod(int64_t value) { return (double)value; } | 58 double cvtsi64tod(int64_t value) { return (double)value; } |
| 39 | 59 |
| 40 double cvtui64tod(uint64_t value) { return (double)value; } | 60 double cvtui64tod(uint64_t value) { return (double)value; } |
| 41 | 61 |
| 42 /* TODO(stichnot): | 62 /* TODO(stichnot): |
| 43 Sz_bitcast_v8i1_to_i8 | 63 Sz_bitcast_v8i1_to_i8 |
| 44 Sz_bitcast_v16i1_to_i16 | 64 Sz_bitcast_v16i1_to_i16 |
| 45 Sz_bitcast_i8_to_v8i1 | 65 Sz_bitcast_i8_to_v8i1 |
| 46 Sz_bitcast_i16_to_v16i1 | 66 Sz_bitcast_i16_to_v16i1 |
| 47 */ | 67 */ |
| OLD | NEW |