You've already forked linux-packaging-mono
acceptance-tests
data
debian
docs
external
Newtonsoft.Json
api-doc-tools
api-snapshot
aspnetwebstack
bdwgc
binary-reference-assemblies
bockbuild
boringssl
cecil
cecil-legacy
corefx
corert
helix-binaries
ikdasm
ikvm
illinker-test-assets
linker
llvm-project
clang
clang-tools-extra
compiler-rt
cmake
docs
include
lib
test
BlocksRuntime
asan
builtins
TestCases
Unit
arm
ppc
absvdi2_test.c
absvsi2_test.c
absvti2_test.c
adddf3vfp_test.c
addsf3vfp_test.c
addtf3_test.c
addvdi3_test.c
addvsi3_test.c
addvti3_test.c
ashldi3_test.c
ashlti3_test.c
ashrdi3_test.c
ashrti3_test.c
bswapdi2_test.c
bswapsi2_test.c
clear_cache_test.c
clzdi2_test.c
clzsi2_test.c
clzti2_test.c
cmpdi2_test.c
cmpti2_test.c
comparedf2_test.c
comparesf2_test.c
cpu_model_test.c
ctzdi2_test.c
ctzsi2_test.c
ctzti2_test.c
divdc3_test.c
divdf3vfp_test.c
divdi3_test.c
divmodsi4_test.c
divsc3_test.c
divsf3vfp_test.c
divsi3_test.c
divtc3_test.c
divtf3_test.c
divti3_test.c
divxc3_test.c
enable_execute_stack_test.c
endianness.h
eqdf2vfp_test.c
eqsf2vfp_test.c
eqtf2_test.c
extebdsfdf2vfp_test.c
extenddftf2_test.c
extendhfsf2_test.c
extendsftf2_test.c
ffsdi2_test.c
ffssi2_test.c
ffsti2_test.c
fixdfdi_test.c
fixdfsivfp_test.c
fixdfti_test.c
fixsfdi_test.c
fixsfsivfp_test.c
fixsfti_test.c
fixtfdi_test.c
fixtfsi_test.c
fixtfti_test.c
fixunsdfdi_test.c
fixunsdfsi_test.c
fixunsdfsivfp_test.c
fixunsdfti_test.c
fixunssfdi_test.c
fixunssfsi_test.c
fixunssfsivfp_test.c
fixunssfti_test.c
fixunstfdi_test.c
fixunstfsi_test.c
fixunstfti_test.c
fixunsxfdi_test.c
fixunsxfsi_test.c
fixunsxfti_test.c
fixxfdi_test.c
fixxfti_test.c
floatdidf_test.c
floatdisf_test.c
floatditf_test.c
floatdixf_test.c
floatsidfvfp_test.c
floatsisfvfp_test.c
floatsitf_test.c
floattidf_test.c
floattisf_test.c
floattitf_test.c
floattixf_test.c
floatundidf_test.c
floatundisf_test.c
floatunditf_test.c
floatundixf_test.c
floatunsitf_test.c
floatunssidfvfp_test.c
floatunssisfvfp_test.c
floatuntidf_test.c
floatuntisf_test.c
floatuntitf_test.c
floatuntixf_test.c
fp_test.h
gcc_personality_test.c
gcc_personality_test_helper.cxx
gedf2vfp_test.c
gesf2vfp_test.c
getf2_test.c
gtdf2vfp_test.c
gtsf2vfp_test.c
gttf2_test.c
ledf2vfp_test.c
lesf2vfp_test.c
letf2_test.c
lit.cfg
lit.site.cfg.in
lshrdi3_test.c
lshrti3_test.c
ltdf2vfp_test.c
ltsf2vfp_test.c
lttf2_test.c
moddi3_test.c
modsi3_test.c
modti3_test.c
muldc3_test.c
muldf3vfp_test.c
muldi3_test.c
mulodi4_test.c
mulosi4_test.c
muloti4_test.c
mulsc3_test.c
mulsf3vfp_test.c
multc3_test.c
multf3_test.c
multi3_test.c
mulvdi3_test.c
mulvsi3_test.c
mulvti3_test.c
mulxc3_test.c
nedf2vfp_test.c
negdf2vfp_test.c
negdi2_test.c
negsf2vfp_test.c
negti2_test.c
negvdi2_test.c
negvsi2_test.c
negvti2_test.c
nesf2vfp_test.c
netf2_test.c
paritydi2_test.c
paritysi2_test.c
parityti2_test.c
popcountdi2_test.c
popcountsi2_test.c
popcountti2_test.c
powidf2_test.c
powisf2_test.c
powitf2_test.c
powixf2_test.c
subdf3vfp_test.c
subsf3vfp_test.c
subtf3_test.c
subvdi3_test.c
subvsi3_test.c
subvti3_test.c
test
trampoline_setup_test.c
truncdfhf2_test.c
truncdfsf2_test.c
truncdfsf2vfp_test.c
truncsfhf2_test.c
trunctfdf2_test.c
trunctfsf2_test.c
ucmpdi2_test.c
ucmpti2_test.c
udivdi3_test.c
udivmoddi4_test.c.REMOVED.git-id
udivmodsi4_test.c
udivmodti4_test.c.REMOVED.git-id
udivsi3_test.c
udivti3_test.c
umoddi3_test.c
umodsi3_test.c
umodti3_test.c
unorddf2vfp_test.c
unordsf2vfp_test.c
unordtf2_test.c
timing
CMakeLists.txt
lit.cfg
lit.site.cfg.in
cfi
dfsan
esan
fuzzer
hwasan
interception
lsan
msan
profile
safestack
sanitizer_common
scudo
tsan
ubsan
ubsan_minimal
xray
CMakeLists.txt
lit.common.cfg
lit.common.configured.in
unittests
www
.arcconfig
.gitignore
CMakeLists.txt
CODE_OWNERS.TXT
CREDITS.TXT
LICENSE.TXT
README.txt
libcxx
libcxxabi
libunwind
lld
lldb
llvm
openmp
polly
nuget-buildtasks
nunit-lite
roslyn-binaries
rx
xunit-binaries
how-to-bump-roslyn-binaries.md
ikvm-native
llvm
m4
man
mcs
mk
mono
msvc
netcore
po
runtime
samples
scripts
support
tools
COPYING.LIB
LICENSE
Makefile.am
Makefile.in
NEWS
README.md
acinclude.m4
aclocal.m4
autogen.sh
code_of_conduct.md
compile
config.guess
config.h.in
config.rpath
config.sub
configure.REMOVED.git-id
configure.ac.REMOVED.git-id
depcomp
install-sh
ltmain.sh.REMOVED.git-id
missing
mkinstalldirs
mono-uninstalled.pc.in
test-driver
winconfig.h
280 lines
6.0 KiB
C
280 lines
6.0 KiB
C
![]() |
//===--------------------------- fp_test.h - ------------------------------===//
|
||
|
//
|
||
|
// The LLVM Compiler Infrastructure
|
||
|
//
|
||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||
|
// Source Licenses. See LICENSE.TXT for details.
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
//
|
||
|
// This file defines shared functions for the test.
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
|
||
|
#include <stdlib.h>
|
||
|
#include <limits.h>
|
||
|
#include <string.h>
|
||
|
#include <stdint.h>
|
||
|
|
||
|
enum EXPECTED_RESULT {
|
||
|
LESS_0, LESS_EQUAL_0, EQUAL_0, GREATER_0, GREATER_EQUAL_0, NEQUAL_0
|
||
|
};
|
||
|
|
||
|
static inline uint16_t fromRep16(uint16_t x)
|
||
|
{
|
||
|
return x;
|
||
|
}
|
||
|
|
||
|
static inline float fromRep32(uint32_t x)
|
||
|
{
|
||
|
float ret;
|
||
|
memcpy(&ret, &x, 4);
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
static inline double fromRep64(uint64_t x)
|
||
|
{
|
||
|
double ret;
|
||
|
memcpy(&ret, &x, 8);
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
#if __LDBL_MANT_DIG__ == 113
|
||
|
static inline long double fromRep128(uint64_t hi, uint64_t lo)
|
||
|
{
|
||
|
__uint128_t x = ((__uint128_t)hi << 64) + lo;
|
||
|
long double ret;
|
||
|
memcpy(&ret, &x, 16);
|
||
|
return ret;
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
static inline uint16_t toRep16(uint16_t x)
|
||
|
{
|
||
|
return x;
|
||
|
}
|
||
|
|
||
|
static inline uint32_t toRep32(float x)
|
||
|
{
|
||
|
uint32_t ret;
|
||
|
memcpy(&ret, &x, 4);
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
static inline uint64_t toRep64(double x)
|
||
|
{
|
||
|
uint64_t ret;
|
||
|
memcpy(&ret, &x, 8);
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
#if __LDBL_MANT_DIG__ == 113
|
||
|
static inline __uint128_t toRep128(long double x)
|
||
|
{
|
||
|
__uint128_t ret;
|
||
|
memcpy(&ret, &x, 16);
|
||
|
return ret;
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
static inline int compareResultH(uint16_t result,
|
||
|
uint16_t expected)
|
||
|
{
|
||
|
uint16_t rep = toRep16(result);
|
||
|
|
||
|
if (rep == expected){
|
||
|
return 0;
|
||
|
}
|
||
|
// test other possible NaN representation(signal NaN)
|
||
|
else if (expected == 0x7e00U){
|
||
|
if ((rep & 0x7c00U) == 0x7c00U &&
|
||
|
(rep & 0x3ffU) > 0){
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
static inline int compareResultF(float result,
|
||
|
uint32_t expected)
|
||
|
{
|
||
|
uint32_t rep = toRep32(result);
|
||
|
|
||
|
if (rep == expected){
|
||
|
return 0;
|
||
|
}
|
||
|
// test other possible NaN representation(signal NaN)
|
||
|
else if (expected == 0x7fc00000U){
|
||
|
if ((rep & 0x7f800000U) == 0x7f800000U &&
|
||
|
(rep & 0x7fffffU) > 0){
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
static inline int compareResultD(double result,
|
||
|
uint64_t expected)
|
||
|
{
|
||
|
uint64_t rep = toRep64(result);
|
||
|
|
||
|
if (rep == expected){
|
||
|
return 0;
|
||
|
}
|
||
|
// test other possible NaN representation(signal NaN)
|
||
|
else if (expected == 0x7ff8000000000000UL){
|
||
|
if ((rep & 0x7ff0000000000000UL) == 0x7ff0000000000000UL &&
|
||
|
(rep & 0xfffffffffffffUL) > 0){
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
#if __LDBL_MANT_DIG__ == 113
|
||
|
// return 0 if equal
|
||
|
// use two 64-bit integers intead of one 128-bit integer
|
||
|
// because 128-bit integer constant can't be assigned directly
|
||
|
static inline int compareResultLD(long double result,
|
||
|
uint64_t expectedHi,
|
||
|
uint64_t expectedLo)
|
||
|
{
|
||
|
__uint128_t rep = toRep128(result);
|
||
|
uint64_t hi = rep >> 64;
|
||
|
uint64_t lo = rep;
|
||
|
|
||
|
if (hi == expectedHi && lo == expectedLo){
|
||
|
return 0;
|
||
|
}
|
||
|
// test other possible NaN representation(signal NaN)
|
||
|
else if (expectedHi == 0x7fff800000000000UL && expectedLo == 0x0UL){
|
||
|
if ((hi & 0x7fff000000000000UL) == 0x7fff000000000000UL &&
|
||
|
((hi & 0xffffffffffffUL) > 0 || lo > 0)){
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
return 1;
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
static inline int compareResultCMP(int result,
|
||
|
enum EXPECTED_RESULT expected)
|
||
|
{
|
||
|
switch(expected){
|
||
|
case LESS_0:
|
||
|
if (result < 0)
|
||
|
return 0;
|
||
|
break;
|
||
|
case LESS_EQUAL_0:
|
||
|
if (result <= 0)
|
||
|
return 0;
|
||
|
break;
|
||
|
case EQUAL_0:
|
||
|
if (result == 0)
|
||
|
return 0;
|
||
|
break;
|
||
|
case NEQUAL_0:
|
||
|
if (result != 0)
|
||
|
return 0;
|
||
|
break;
|
||
|
case GREATER_EQUAL_0:
|
||
|
if (result >= 0)
|
||
|
return 0;
|
||
|
break;
|
||
|
case GREATER_0:
|
||
|
if (result > 0)
|
||
|
return 0;
|
||
|
break;
|
||
|
default:
|
||
|
return 1;
|
||
|
}
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
static inline char *expectedStr(enum EXPECTED_RESULT expected)
|
||
|
{
|
||
|
switch(expected){
|
||
|
case LESS_0:
|
||
|
return "<0";
|
||
|
case LESS_EQUAL_0:
|
||
|
return "<=0";
|
||
|
case EQUAL_0:
|
||
|
return "=0";
|
||
|
case NEQUAL_0:
|
||
|
return "!=0";
|
||
|
case GREATER_EQUAL_0:
|
||
|
return ">=0";
|
||
|
case GREATER_0:
|
||
|
return ">0";
|
||
|
default:
|
||
|
return "";
|
||
|
}
|
||
|
return "";
|
||
|
}
|
||
|
|
||
|
static inline uint16_t makeQNaN16()
|
||
|
{
|
||
|
return fromRep16(0x7e00U);
|
||
|
}
|
||
|
|
||
|
static inline float makeQNaN32()
|
||
|
{
|
||
|
return fromRep32(0x7fc00000U);
|
||
|
}
|
||
|
|
||
|
static inline double makeQNaN64()
|
||
|
{
|
||
|
return fromRep64(0x7ff8000000000000UL);
|
||
|
}
|
||
|
|
||
|
#if __LDBL_MANT_DIG__ == 113
|
||
|
static inline long double makeQNaN128()
|
||
|
{
|
||
|
return fromRep128(0x7fff800000000000UL, 0x0UL);
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
static inline uint16_t makeNaN16(uint16_t rand)
|
||
|
{
|
||
|
return fromRep16(0x7c00U | (rand & 0x7fffU));
|
||
|
}
|
||
|
|
||
|
static inline float makeNaN32(uint32_t rand)
|
||
|
{
|
||
|
return fromRep32(0x7f800000U | (rand & 0x7fffffU));
|
||
|
}
|
||
|
|
||
|
static inline double makeNaN64(uint64_t rand)
|
||
|
{
|
||
|
return fromRep64(0x7ff0000000000000UL | (rand & 0xfffffffffffffUL));
|
||
|
}
|
||
|
|
||
|
#if __LDBL_MANT_DIG__ == 113
|
||
|
static inline long double makeNaN128(uint64_t rand)
|
||
|
{
|
||
|
return fromRep128(0x7fff000000000000UL | (rand & 0xffffffffffffUL), 0x0UL);
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
static inline uint16_t makeInf16()
|
||
|
{
|
||
|
return fromRep16(0x7c00U);
|
||
|
}
|
||
|
|
||
|
static inline float makeInf32()
|
||
|
{
|
||
|
return fromRep32(0x7f800000U);
|
||
|
}
|
||
|
|
||
|
static inline double makeInf64()
|
||
|
{
|
||
|
return fromRep64(0x7ff0000000000000UL);
|
||
|
}
|
||
|
|
||
|
#if __LDBL_MANT_DIG__ == 113
|
||
|
static inline long double makeInf128()
|
||
|
{
|
||
|
return fromRep128(0x7fff000000000000UL, 0x0UL);
|
||
|
}
|
||
|
#endif
|