Files
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
Raw Normal View History

//===--------------------------- 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