mirror of
https://git.planet-casio.com/Lephenixnoir/OpenLibm.git
synced 2024-12-28 20:43:41 +01:00
Fork of the OpenLibm math library with fx-9860G and fx-CG 50 support.
787652b054
As a component of atan2(y, x), the case of x == 1.0 is farmed out to
atan(y). The current implementation of this comparison is vulnerable
to signed integer underflow (that is, undefined behavior), and it's
performed in a somewhat more complicated way than it need be. Change
it to not be quite so cute, rather directly comparing the high/low
bits of x to the specific IEEE-754 bit pattern that encodes 1.0.
Note that while there are three different e_atan* files in the
relevant directory, only this one needs fixing. e_atan2f.c already
compares against the full bit pattern encoding 1.0f, while
e_atan2l.cuses bitwise-ands/ors/nots and so doesn't require a change.
Incorporated from FreeBSD source tree. See:
|
||
---|---|---|
aarch64 | ||
amd64 | ||
arm | ||
bsdsrc | ||
i387 | ||
include | ||
ld80 | ||
ld128 | ||
powerpc | ||
src | ||
test | ||
.gitignore | ||
.mailmap | ||
.travis.yml | ||
LICENSE.md | ||
Make.inc | ||
Makefile | ||
openlibm.pc.in | ||
README.md |
OpenLibm
OpenLibm is an effort to have a high quality, portable, standalone
C mathematical library (libm
).
It can be used standalone in applications and programming language
implementations.
The project was born out of a need to have a good libm
for the
Julia programming langage that worked
consistently across compilers and operating systems, and in 32-bit and
64-bit environments.
Platform support
OpenLibm builds on Linux, Mac OS X, Windows, FreeBSD, OpenBSD, and DragonFly BSD. It builds with both GCC and clang. Although largely tested and widely used on x86 architectures, OpenLibm also supports ARM and PowerPC.
Build instructions
- Use GNU Make to build OpenLibm. This is
make
on most systems, butgmake
on BSDs. - Use
make USEGCC=1
to build with GCC. This is the default on Linux and Windows. - Use
make USECLANG=1
to build with clang. This is the default on OS X, FreeBSD, and OpenBSD. - Architectures are auto-detected. Use
make ARCH=i386
to force a build for i386. Other supported architectures are i486, i586, and i686. GCC 4.8 is the minimum requirement for correct codegen on older 32-bit architectures.
Acknowledgements
PowerPC support for openlibm was graciously sponsored by IBM.