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
377 lines
7.5 KiB
C
377 lines
7.5 KiB
C
![]() |
// RUN: %clang_builtins %s %librt -o %t && %run %t
|
||
|
//===-- multc3_test.c - Test __multc3 -------------------------------------===//
|
||
|
//
|
||
|
// 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 tests __multc3 for the compiler_rt library.
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
|
||
|
#include <stdio.h>
|
||
|
|
||
|
#if _ARCH_PPC || __aarch64__
|
||
|
|
||
|
#include "int_lib.h"
|
||
|
#include <math.h>
|
||
|
#include <complex.h>
|
||
|
|
||
|
// Returns: the product of a + ib and c + id
|
||
|
|
||
|
COMPILER_RT_ABI long double _Complex
|
||
|
__multc3(long double __a, long double __b, long double __c, long double __d);
|
||
|
|
||
|
enum {zero, non_zero, inf, NaN, non_zero_nan};
|
||
|
|
||
|
int
|
||
|
classify(long double _Complex x)
|
||
|
{
|
||
|
if (x == 0)
|
||
|
return zero;
|
||
|
if (isinf(creall(x)) || isinf(cimagl(x)))
|
||
|
return inf;
|
||
|
if (isnan(creall(x)) && isnan(cimagl(x)))
|
||
|
return NaN;
|
||
|
if (isnan(creall(x)))
|
||
|
{
|
||
|
if (cimagl(x) == 0)
|
||
|
return NaN;
|
||
|
return non_zero_nan;
|
||
|
}
|
||
|
if (isnan(cimagl(x)))
|
||
|
{
|
||
|
if (creall(x) == 0)
|
||
|
return NaN;
|
||
|
return non_zero_nan;
|
||
|
}
|
||
|
return non_zero;
|
||
|
}
|
||
|
|
||
|
int test__multc3(long double a, long double b, long double c, long double d)
|
||
|
{
|
||
|
long double _Complex r = __multc3(a, b, c, d);
|
||
|
// printf("test__multc3(%Lf, %Lf, %Lf, %Lf) = %Lf + I%Lf\n",
|
||
|
// a, b, c, d, creall(r), cimagl(r));
|
||
|
long double _Complex dividend;
|
||
|
long double _Complex divisor;
|
||
|
|
||
|
__real__ dividend = a;
|
||
|
__imag__ dividend = b;
|
||
|
__real__ divisor = c;
|
||
|
__imag__ divisor = d;
|
||
|
|
||
|
switch (classify(dividend))
|
||
|
{
|
||
|
case zero:
|
||
|
switch (classify(divisor))
|
||
|
{
|
||
|
case zero:
|
||
|
if (classify(r) != zero)
|
||
|
return 1;
|
||
|
break;
|
||
|
case non_zero:
|
||
|
if (classify(r) != zero)
|
||
|
return 1;
|
||
|
break;
|
||
|
case inf:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
case NaN:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
case non_zero_nan:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
}
|
||
|
break;
|
||
|
case non_zero:
|
||
|
switch (classify(divisor))
|
||
|
{
|
||
|
case zero:
|
||
|
if (classify(r) != zero)
|
||
|
return 1;
|
||
|
break;
|
||
|
case non_zero:
|
||
|
if (classify(r) != non_zero)
|
||
|
return 1;
|
||
|
if (r != a * c - b * d + _Complex_I*(a * d + b * c))
|
||
|
return 1;
|
||
|
break;
|
||
|
case inf:
|
||
|
if (classify(r) != inf)
|
||
|
return 1;
|
||
|
break;
|
||
|
case NaN:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
case non_zero_nan:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
}
|
||
|
break;
|
||
|
case inf:
|
||
|
switch (classify(divisor))
|
||
|
{
|
||
|
case zero:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
case non_zero:
|
||
|
if (classify(r) != inf)
|
||
|
return 1;
|
||
|
break;
|
||
|
case inf:
|
||
|
if (classify(r) != inf)
|
||
|
return 1;
|
||
|
break;
|
||
|
case NaN:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
case non_zero_nan:
|
||
|
if (classify(r) != inf)
|
||
|
return 1;
|
||
|
break;
|
||
|
}
|
||
|
break;
|
||
|
case NaN:
|
||
|
switch (classify(divisor))
|
||
|
{
|
||
|
case zero:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
case non_zero:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
case inf:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
case NaN:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
case non_zero_nan:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
}
|
||
|
break;
|
||
|
case non_zero_nan:
|
||
|
switch (classify(divisor))
|
||
|
{
|
||
|
case zero:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
case non_zero:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
case inf:
|
||
|
if (classify(r) != inf)
|
||
|
return 1;
|
||
|
break;
|
||
|
case NaN:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
case non_zero_nan:
|
||
|
if (classify(r) != NaN)
|
||
|
return 1;
|
||
|
break;
|
||
|
}
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
long double x[][2] =
|
||
|
{
|
||
|
{ 1.e-6, 1.e-6},
|
||
|
{-1.e-6, 1.e-6},
|
||
|
{-1.e-6, -1.e-6},
|
||
|
{ 1.e-6, -1.e-6},
|
||
|
|
||
|
{ 1.e+6, 1.e-6},
|
||
|
{-1.e+6, 1.e-6},
|
||
|
{-1.e+6, -1.e-6},
|
||
|
{ 1.e+6, -1.e-6},
|
||
|
|
||
|
{ 1.e-6, 1.e+6},
|
||
|
{-1.e-6, 1.e+6},
|
||
|
{-1.e-6, -1.e+6},
|
||
|
{ 1.e-6, -1.e+6},
|
||
|
|
||
|
{ 1.e+6, 1.e+6},
|
||
|
{-1.e+6, 1.e+6},
|
||
|
{-1.e+6, -1.e+6},
|
||
|
{ 1.e+6, -1.e+6},
|
||
|
|
||
|
{NAN, NAN},
|
||
|
{-INFINITY, NAN},
|
||
|
{-2, NAN},
|
||
|
{-1, NAN},
|
||
|
{-0.5, NAN},
|
||
|
{-0., NAN},
|
||
|
{+0., NAN},
|
||
|
{0.5, NAN},
|
||
|
{1, NAN},
|
||
|
{2, NAN},
|
||
|
{INFINITY, NAN},
|
||
|
|
||
|
{NAN, -INFINITY},
|
||
|
{-INFINITY, -INFINITY},
|
||
|
{-2, -INFINITY},
|
||
|
{-1, -INFINITY},
|
||
|
{-0.5, -INFINITY},
|
||
|
{-0., -INFINITY},
|
||
|
{+0., -INFINITY},
|
||
|
{0.5, -INFINITY},
|
||
|
{1, -INFINITY},
|
||
|
{2, -INFINITY},
|
||
|
{INFINITY, -INFINITY},
|
||
|
|
||
|
{NAN, -2},
|
||
|
{-INFINITY, -2},
|
||
|
{-2, -2},
|
||
|
{-1, -2},
|
||
|
{-0.5, -2},
|
||
|
{-0., -2},
|
||
|
{+0., -2},
|
||
|
{0.5, -2},
|
||
|
{1, -2},
|
||
|
{2, -2},
|
||
|
{INFINITY, -2},
|
||
|
|
||
|
{NAN, -1},
|
||
|
{-INFINITY, -1},
|
||
|
{-2, -1},
|
||
|
{-1, -1},
|
||
|
{-0.5, -1},
|
||
|
{-0., -1},
|
||
|
{+0., -1},
|
||
|
{0.5, -1},
|
||
|
{1, -1},
|
||
|
{2, -1},
|
||
|
{INFINITY, -1},
|
||
|
|
||
|
{NAN, -0.5},
|
||
|
{-INFINITY, -0.5},
|
||
|
{-2, -0.5},
|
||
|
{-1, -0.5},
|
||
|
{-0.5, -0.5},
|
||
|
{-0., -0.5},
|
||
|
{+0., -0.5},
|
||
|
{0.5, -0.5},
|
||
|
{1, -0.5},
|
||
|
{2, -0.5},
|
||
|
{INFINITY, -0.5},
|
||
|
|
||
|
{NAN, -0.},
|
||
|
{-INFINITY, -0.},
|
||
|
{-2, -0.},
|
||
|
{-1, -0.},
|
||
|
{-0.5, -0.},
|
||
|
{-0., -0.},
|
||
|
{+0., -0.},
|
||
|
{0.5, -0.},
|
||
|
{1, -0.},
|
||
|
{2, -0.},
|
||
|
{INFINITY, -0.},
|
||
|
|
||
|
{NAN, 0.},
|
||
|
{-INFINITY, 0.},
|
||
|
{-2, 0.},
|
||
|
{-1, 0.},
|
||
|
{-0.5, 0.},
|
||
|
{-0., 0.},
|
||
|
{+0., 0.},
|
||
|
{0.5, 0.},
|
||
|
{1, 0.},
|
||
|
{2, 0.},
|
||
|
{INFINITY, 0.},
|
||
|
|
||
|
{NAN, 0.5},
|
||
|
{-INFINITY, 0.5},
|
||
|
{-2, 0.5},
|
||
|
{-1, 0.5},
|
||
|
{-0.5, 0.5},
|
||
|
{-0., 0.5},
|
||
|
{+0., 0.5},
|
||
|
{0.5, 0.5},
|
||
|
{1, 0.5},
|
||
|
{2, 0.5},
|
||
|
{INFINITY, 0.5},
|
||
|
|
||
|
{NAN, 1},
|
||
|
{-INFINITY, 1},
|
||
|
{-2, 1},
|
||
|
{-1, 1},
|
||
|
{-0.5, 1},
|
||
|
{-0., 1},
|
||
|
{+0., 1},
|
||
|
{0.5, 1},
|
||
|
{1, 1},
|
||
|
{2, 1},
|
||
|
{INFINITY, 1},
|
||
|
|
||
|
{NAN, 2},
|
||
|
{-INFINITY, 2},
|
||
|
{-2, 2},
|
||
|
{-1, 2},
|
||
|
{-0.5, 2},
|
||
|
{-0., 2},
|
||
|
{+0., 2},
|
||
|
{0.5, 2},
|
||
|
{1, 2},
|
||
|
{2, 2},
|
||
|
{INFINITY, 2},
|
||
|
|
||
|
{NAN, INFINITY},
|
||
|
{-INFINITY, INFINITY},
|
||
|
{-2, INFINITY},
|
||
|
{-1, INFINITY},
|
||
|
{-0.5, INFINITY},
|
||
|
{-0., INFINITY},
|
||
|
{+0., INFINITY},
|
||
|
{0.5, INFINITY},
|
||
|
{1, INFINITY},
|
||
|
{2, INFINITY},
|
||
|
{INFINITY, INFINITY}
|
||
|
|
||
|
};
|
||
|
|
||
|
#endif
|
||
|
|
||
|
int main()
|
||
|
{
|
||
|
#if _ARCH_PPC || __aarch64__
|
||
|
const unsigned N = sizeof(x) / sizeof(x[0]);
|
||
|
unsigned i, j;
|
||
|
for (i = 0; i < N; ++i)
|
||
|
{
|
||
|
for (j = 0; j < N; ++j)
|
||
|
{
|
||
|
if (test__multc3(x[i][0], x[i][1], x[j][0], x[j][1]))
|
||
|
return 1;
|
||
|
}
|
||
|
}
|
||
|
#else
|
||
|
printf("skipped\n");
|
||
|
#endif
|
||
|
return 0;
|
||
|
}
|