erythros/src/openlibm
2025-04-04 18:16:29 -04:00
..
aarch64 Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
amd64 Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
arm Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
bsdsrc Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
docs Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
i387 Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
include Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
ld80 Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
ld128 Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
loongarch64 Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
mips Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
powerpc Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
riscv64 Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
s390 Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
src Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
test Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
wasm32 Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
CMakeLists.txt Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
LICENSE.md Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
Make.inc Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
Makefile Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
openlibm.pc.in Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00
README.md Meta: Add OpenLibm 2025-04-04 18:16:29 -04:00

OpenLibm

codecov

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 language that worked consistently across compilers and operating systems, and in 32-bit and 64-bit environments.

Platform support

OpenLibm builds on Linux, macOS, Windows, FreeBSD, OpenBSD, NetBSD, and DragonFly BSD. It builds with both GCC and clang. Although largely tested and widely used on the x86 and x86-64 architectures, OpenLibm also supports arm, aarch64, ppc64le, mips, wasm32, riscv, s390(x) and loongarch64.

Build instructions

GNU Make

  1. Use GNU Make to build OpenLibm. This is make on most systems, but gmake on BSDs.
  2. Use make USEGCC=1 to build with GCC. This is the default on Linux and Windows.
  3. Use make USECLANG=1 to build with clang. This is the default on OS X, FreeBSD, and OpenBSD.
  4. Use make ARCH=wasm32 to build the wasm32 library with clang.
  5. 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.

Cross Build Take riscv64 as example:

  1. install qemu-riscv64-static, gcc-riscv64-linux-gnu
  2. Cross build:
ARCH=riscv64
TRIPLE=$ARCH-linux-gnu
make ARCH=$ARCH TOOLPREFIX=$TRIPLE-  -j
make -C test ARCH=$ARCH TOOLPREFIX=$TRIPLE-  -j
  1. Run test with qemu:
qemu-$ARCH-static -L . -L /usr/$TRIPLE/  test/test-float
qemu-$ARCH-static -L . -L /usr/$TRIPLE/  test/test-double

CMake

  1. Create build directory with mkdir build and navigate into it with cd build.
  2. Run CMake to configure project and generate native build system with cmake /path/to/openlibm/ or generate project with build system of choice e.g. cmake /path/to/openlib/ -G "MinGW Makefiles".
  3. Build with the build system with cmake --build ..

Default CMake configuration builds a shared library, this can easily be configured using BUILD_SHARED_LIBS configuration option.

Acknowledgements

PowerPC support for openlibm was graciously sponsored by IBM.