summaryrefslogtreecommitdiff
path: root/device/include/math.h
diff options
context:
space:
mode:
authorXavier ASUS <xavi92psx@gmail.com>2019-10-18 00:31:54 +0200
committerXavier ASUS <xavi92psx@gmail.com>2019-10-18 00:31:54 +0200
commit268a53de823a6750d6256ee1fb1e7707b4b45740 (patch)
tree42c1799a9a82b2f7d9790ee9fe181d72a7274751 /device/include/math.h
downloadsdcc-gas-268a53de823a6750d6256ee1fb1e7707b4b45740.tar.gz
sdcc-3.9.0 fork implementing GNU assembler syntax
This fork aims to provide better support for stm8-binutils
Diffstat (limited to 'device/include/math.h')
-rw-r--r--device/include/math.h108
1 files changed, 108 insertions, 0 deletions
diff --git a/device/include/math.h b/device/include/math.h
new file mode 100644
index 0000000..75620fa
--- /dev/null
+++ b/device/include/math.h
@@ -0,0 +1,108 @@
+/*-------------------------------------------------------------------------
+ math.h: Floating point math function declarations
+
+ Copyright (C) 2001, Jesus Calvino-Fraga, jesusc@ieee.org
+
+ This library is free software; you can redistribute it and/or modify it
+ under the terms of the GNU General Public License as published by the
+ Free Software Foundation; either version 2, or (at your option) any
+ later version.
+
+ This library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this library; see the file COPYING. If not, write to the
+ Free Software Foundation, 51 Franklin Street, Fifth Floor, Boston,
+ MA 02110-1301, USA.
+
+ As a special exception, if you link this library with other files,
+ some of which are compiled with SDCC, to produce an executable,
+ this library does not by itself cause the resulting executable to
+ be covered by the GNU General Public License. This exception does
+ not however invalidate any other reasons why the executable file
+ might be covered by the GNU General Public License.
+-------------------------------------------------------------------------*/
+
+/* Version 1.0 - Initial release */
+
+#ifndef _INC_MATH
+#define _INC_MATH
+
+#define HUGE_VALF 3.402823466e+38
+
+#define PI 3.1415926536
+#define TWO_PI 6.2831853071
+#define HALF_PI 1.5707963268
+#define QUART_PI 0.7853981634
+#define iPI 0.3183098862
+#define iTWO_PI 0.1591549431
+#define TWO_O_PI 0.6366197724
+
+/* EPS=B**(-t/2), where B is the radix of the floating-point representation
+ and there are t base-B digits in the significand. Therefore, for floats
+ EPS=2**(-12). Also define EPS2=EPS*EPS. */
+#define EPS 244.14062E-6
+#define EPS2 59.6046E-9
+
+union float_long
+{
+ float f;
+ long l;
+};
+
+#if defined(__SDCC_MATH_LIB) && defined(__SDCC_mcs51) && !defined(__SDCC_USE_XSTACK) && !defined(__SDCC_STACK_AUTO) && !defined(_SDCC_NO_ASM_LIB_FUNCS)
+/* Compile the mcs51 assembly version only when all these
+ conditions are met. Since not all the functions are
+ reentrant, do not compile with --stack-auto is used. */
+#define MATH_ASM_MCS51
+#endif
+
+
+/* Functions on the z80 & gbz80 are always reentrant and so the "reentrant" */
+/* keyword is not defined. */
+#if defined(__SDCC_z80) || defined(__SDCC_z180) || defined(__SDCC_r2k) || defined(__SDCC_r3ka) || defined(__SDCC_tlcs90) || defined(__SDCC_gbz80) || defined(__SDCC_ez80_z80) || defined(__SDCC_stm8)
+#define _FLOAT_FUNC_REENTRANT
+#else
+#define _FLOAT_FUNC_REENTRANT __reentrant
+#endif
+
+/**********************************************
+ * Prototypes for float ANSI C math functions *
+ **********************************************/
+
+/* Trigonometric functions */
+float sinf(float x) _FLOAT_FUNC_REENTRANT;
+float cosf(float x) _FLOAT_FUNC_REENTRANT;
+float tanf(float x) _FLOAT_FUNC_REENTRANT;
+float cotf(float x) _FLOAT_FUNC_REENTRANT;
+float asinf(float x) _FLOAT_FUNC_REENTRANT;
+float acosf(float x) _FLOAT_FUNC_REENTRANT;
+float atanf(float x) _FLOAT_FUNC_REENTRANT;
+float atan2f(float x, float y);
+
+/* Hyperbolic functions */
+float sinhf(float x) _FLOAT_FUNC_REENTRANT;
+float coshf(float x) _FLOAT_FUNC_REENTRANT;
+float tanhf(float x) _FLOAT_FUNC_REENTRANT;
+
+/* Exponential, logarithmic and power functions */
+float expf(float x) _FLOAT_FUNC_REENTRANT;
+float logf(float x) _FLOAT_FUNC_REENTRANT;
+float log10f(float x) _FLOAT_FUNC_REENTRANT;
+float powf(float x, float y);
+float sqrtf(float a) _FLOAT_FUNC_REENTRANT;
+
+/* Nearest integer, absolute value, and remainder functions */
+float fabsf(float x) _FLOAT_FUNC_REENTRANT;
+float frexpf(float x, int *pw2);
+float ldexpf(float x, int pw2);
+float ceilf(float x) _FLOAT_FUNC_REENTRANT;
+float floorf(float x) _FLOAT_FUNC_REENTRANT;
+float modff(float x, float * y);
+
+int isnan(float f);
+int isinf(float f);
+#endif /* _INC_MATH */