1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
* vim: set ts=8 sts=2 et sw=2 tw=80:
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef jsmath_h
#define jsmath_h
#include <stdint.h>
#include "NamespaceImports.h"
namespace js {
using UnaryMathFunctionType = double (*)(double);
// Used for inlining calls to double => double Math functions from JIT code.
// Note that this list does not include all unary Math functions: abs and sqrt
// for example are missing because the JITs optimize them without a C++ call.
enum class UnaryMathFunction : uint8_t {
Log,
Sin,
Cos,
Exp,
Tan,
ACos,
ASin,
ATan,
Log10,
Log2,
Log1P,
ExpM1,
CosH,
SinH,
TanH,
ACosH,
ASinH,
ATanH,
Trunc,
Cbrt,
Floor,
Ceil,
Round,
};
extern UnaryMathFunctionType GetUnaryMathFunctionPtr(UnaryMathFunction fun);
extern const char* GetUnaryMathFunctionName(UnaryMathFunction fun);
/*
* JS math functions.
*/
extern const JSClass MathClass;
extern uint64_t GenerateRandomSeed();
// Fill |seed[0]| and |seed[1]| with random bits, suitable for
// seeding a XorShift128+ random number generator.
extern void GenerateXorShift128PlusSeed(mozilla::Array<uint64_t, 2>& seed);
extern double math_random_impl(JSContext* cx);
extern double math_abs_impl(double x);
extern bool math_abs(JSContext* cx, unsigned argc, js::Value* vp);
extern double math_max_impl(double x, double y);
extern bool math_max(JSContext* cx, unsigned argc, js::Value* vp);
extern double math_min_impl(double x, double y);
extern bool math_min(JSContext* cx, unsigned argc, js::Value* vp);
extern double math_sqrt_impl(double x);
extern bool math_imul_handle(JSContext* cx, HandleValue lhs, HandleValue rhs,
MutableHandleValue res);
extern bool RoundFloat32(JSContext* cx, HandleValue v, float* out);
extern bool RoundFloat32(JSContext* cx, HandleValue arg,
MutableHandleValue res);
extern double RoundFloat32(double d);
extern double math_log_impl(double x);
extern bool math_use_fdlibm_for_sin_cos_tan();
extern double math_sin_fdlibm_impl(double x);
extern double math_sin_native_impl(double x);
extern double math_sin_impl(double x);
extern double math_cos_fdlibm_impl(double x);
extern double math_cos_native_impl(double x);
extern double math_cos_impl(double x);
extern double math_exp_impl(double x);
extern double math_tan_fdlibm_impl(double x);
extern double math_tan_native_impl(double x);
extern double math_tan_impl(double x);
extern double ecmaHypot(double x, double y);
extern double hypot3(double x, double y, double z);
extern double hypot4(double x, double y, double z, double w);
extern bool math_hypot_handle(JSContext* cx, HandleValueArray args,
MutableHandleValue res);
extern bool math_trunc(JSContext* cx, unsigned argc, Value* vp);
extern double ecmaAtan2(double x, double y);
extern double math_atan_impl(double x);
extern double math_asin_impl(double x);
extern double math_acos_impl(double x);
extern double math_ceil_impl(double x);
extern bool math_floor(JSContext* cx, unsigned argc, Value* vp);
extern double math_floor_impl(double x);
template <typename T>
extern T GetBiggestNumberLessThan(T x);
extern double math_round_impl(double x);
extern float math_roundf_impl(float x);
extern double powi(double x, int32_t y);
extern double ecmaPow(double x, double y);
extern double math_log10_impl(double x);
extern double math_log2_impl(double x);
extern double math_log1p_impl(double x);
extern double math_expm1_impl(double x);
extern double math_cosh_impl(double x);
extern double math_sinh_impl(double x);
extern double math_tanh_impl(double x);
extern double math_acosh_impl(double x);
extern double math_asinh_impl(double x);
extern double math_atanh_impl(double x);
extern double math_trunc_impl(double x);
extern float math_truncf_impl(float x);
extern double math_sign_impl(double x);
extern double math_cbrt_impl(double x);
} /* namespace js */
#endif /* jsmath_h */
|