blob: c3a43116468cd4cb7a9a8aaf8e6729d5074cc2f5 [file] [log] [blame]
/*
* Copyright (C) 2017 The Android Open Source Project
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
#include <tgmath.h>
#include "header_checks.h"
#define TGMATH(f_) f_(f1); f_(d1); f_(ld1);
#define TGMATHC(f_) f_(f1); f_(d1); f_(ld1); f_(fc1); f_(dc1); f_(ldc1);
#define TGMATHCONLY(f_) f_(fc1); f_(dc1); f_(ldc1);
#define TGMATH2(f_) f_(f1, f2); f_(d1, d2); f_(ld1, ld2);
#define TGMATH2C(f_) f_(f1, f2); f_(d1, d2); f_(ld1, ld2); f_(fc1, fc2); f_(dc1, dc2); f_(ldc1, ldc2);
#define TGMATH3(f_) f_(f1, f2, f3); f_(d1, d2, d3); f_(ld1, ld2, ld3);
static void tgmath_h() {
float f1, f2, f3;
f1 = f2 = f3 = 0;
float complex fc1, fc2, fc3;
fc1 = fc2 = fc3 = 0;
double d1, d2, d3;
d1 = d2 = d3 = 0;
double complex dc1, dc2, dc3;
dc1 = dc2 = dc3 = 0;
long double ld1, ld2, ld3;
ld1 = ld2 = ld3 = 0;
long double complex ldc1, ldc2, ldc3;
ldc1 = ldc2 = ldc3 = 0;
int i = 0;
long l = 0;
TGMATHC(acos);
TGMATHC(asin);
TGMATHC(atan);
TGMATHC(acosh);
TGMATHC(asinh);
TGMATHC(atanh);
TGMATHC(cos);
TGMATHC(sin);
TGMATHC(tan);
TGMATHC(cosh);
TGMATHC(sinh);
TGMATHC(tanh);
TGMATHC(exp);
TGMATHC(log);
TGMATH2C(pow);
TGMATHC(sqrt);
TGMATHC(fabs);
TGMATH2(atan2);
TGMATH(cbrt);
TGMATH(ceil);
TGMATH2(copysign);
TGMATH(erf);
TGMATH(erfc);
TGMATH(exp2);
TGMATH(expm1);
TGMATH2(fdim);
TGMATH(floor);
TGMATH3(fma);
TGMATH2(fmax);
TGMATH2(fmin);
TGMATH2(fmod);
frexp(f1, &i); frexp(d1, &i); frexp(ld1, &i);
TGMATH2(hypot);
TGMATH(ilogb);
ldexp(f1, i); ldexp(d1, i); ldexp(ld1, i);
TGMATH(lgamma);
TGMATH(llrint);
TGMATH(llround);
TGMATH(log10);
TGMATH(log1p);
TGMATH(log2);
TGMATH(logb);
TGMATH(lrint);
TGMATH(lround);
TGMATH(nearbyint);
TGMATH2(nextafter);
TGMATH2(nexttoward);
TGMATH2(remainder);
remquo(f1, f2, &i); remquo(d1, d2, &i); remquo(ld1, ld2, &i);
TGMATH(rint);
TGMATH(round);
scalbln(f1, l); scalbln(d1, l); scalbln(ld1, l);
scalbn(f1, i); scalbn(d1, i); scalbn(ld1, i);
TGMATH(tgamma);
TGMATH(trunc);
TGMATHCONLY(carg);
TGMATHCONLY(cimag);
TGMATHCONLY(conj);
TGMATHCONLY(cproj);
TGMATHCONLY(creal);
}