blob: 99758ffe24587a06526d952ecb97855c4db8dab1 [file] [log] [blame]
Elliott Hughesf9f4a432015-08-24 22:57:08 +00001/*
2 * Copyright (C) 2015 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include <math.h>
18
19#include "fpmath.h"
20
Elliott Hughes591a2a72022-12-05 20:58:15 +000021double fabs(double x) { return __builtin_fabs(x); }
22float fabsf(float x) { return __builtin_fabsf(x); }
Elliott Hughesf9f4a432015-08-24 22:57:08 +000023long double fabsl(long double x) { return __builtin_fabsl(x); }
Elliott Hughes9a1bb702017-11-09 22:40:11 +000024
25#if defined(__aarch64__)
Jake Weinstein1e108e32017-12-11 02:50:04 -050026float ceilf(float x) { return __builtin_ceilf(x); }
27double ceil(double x) { return __builtin_ceil(x); }
Elliott Hughesedf386b2022-12-09 20:54:38 +000028#endif
Jake Weinstein1e108e32017-12-11 02:50:04 -050029
Elliott Hughesedf386b2022-12-09 20:54:38 +000030#if defined(__aarch64__) || defined(__riscv)
Elliott Hughes46f24a12022-10-26 21:55:34 +000031double copysign(double x, double y) { return __builtin_copysign(x, y); }
32float copysignf(float x, float y) { return __builtin_copysignf(x, y); }
Elliott Hughesedf386b2022-12-09 20:54:38 +000033#endif
Elliott Hughes46f24a12022-10-26 21:55:34 +000034
Elliott Hughes47aa5b92023-02-02 02:22:06 +000035#if defined(__arm__) || defined(__aarch64__)
Jake Weinstein1e108e32017-12-11 02:50:04 -050036float floorf(float x) { return __builtin_floorf(x); }
37double floor(double x) { return __builtin_floor(x); }
Elliott Hughes47aa5b92023-02-02 02:22:06 +000038#if defined(__ILP32__)
39__weak_reference(floor, floorl);
40#endif
Elliott Hughesedf386b2022-12-09 20:54:38 +000041#endif
Jake Weinstein1e108e32017-12-11 02:50:04 -050042
Elliott Hughesedf386b2022-12-09 20:54:38 +000043#if defined(__aarch64__) || defined(__riscv)
Elliott Hughes9a1bb702017-11-09 22:40:11 +000044float fmaf(float x, float y, float z) { return __builtin_fmaf(x, y, z); }
45double fma(double x, double y, double z) { return __builtin_fma(x, y, z); }
46
47float fmaxf(float x, float y) { return __builtin_fmaxf(x, y); }
48double fmax(double x, double y) { return __builtin_fmax(x, y); }
49
50float fminf(float x, float y) { return __builtin_fminf(x, y); }
51double fmin(double x, double y) { return __builtin_fmin(x, y); }
52
Elliott Hughes2dcc5ce2023-02-01 02:05:24 +000053long lrint(double x) { return __builtin_lrint(x); }
54long lrintf(float x) { return __builtin_lrintf(x); }
55long long llrint(double x) { return __builtin_llrint(x); }
56long long llrintf(float x) { return __builtin_llrintf(x); }
57
Elliott Hughes0cbb9022022-10-28 00:00:00 +000058long lround(double x) { return __builtin_lround(x); }
59long lroundf(float x) { return __builtin_lroundf(x); }
60long long llround(double x) { return __builtin_llround(x); }
61long long llroundf(float x) { return __builtin_llroundf(x); }
Elliott Hughesedf386b2022-12-09 20:54:38 +000062#endif
Elliott Hughes0cbb9022022-10-28 00:00:00 +000063
Elliott Hughesedf386b2022-12-09 20:54:38 +000064#if defined(__aarch64__)
Jake Weinstein1e108e32017-12-11 02:50:04 -050065float rintf(float x) { return __builtin_rintf(x); }
66double rint(double x) { return __builtin_rint(x); }
67
Elliott Hughes9a1bb702017-11-09 22:40:11 +000068float roundf(float x) { return __builtin_roundf(x); }
69double round(double x) { return __builtin_round(x); }
Elliott Hughes2dcc5ce2023-02-01 02:05:24 +000070#endif
Jake Weinstein1e108e32017-12-11 02:50:04 -050071
Elliott Hughes47aa5b92023-02-02 02:22:06 +000072#if defined(__arm__) || defined(__aarch64__) || defined(__riscv)
Elliott Hughes2dcc5ce2023-02-01 02:05:24 +000073float sqrtf(float x) { return __builtin_sqrtf(x); }
74double sqrt(double x) { return __builtin_sqrt(x); }
Elliott Hughes47aa5b92023-02-02 02:22:06 +000075#if defined(__ILP32__)
76__weak_reference(sqrt, sqrtl);
77#endif
Elliott Hughes2dcc5ce2023-02-01 02:05:24 +000078#endif
79
80#if defined(__aarch64__)
Jake Weinstein1e108e32017-12-11 02:50:04 -050081float truncf(float x) { return __builtin_truncf(x); }
82double trunc(double x) { return __builtin_trunc(x); }
Elliott Hughes9a1bb702017-11-09 22:40:11 +000083#endif