Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

build: remove openlibm #56875

Draft
wants to merge 13 commits into
base: master
Choose a base branch
from

Conversation

inkydragon
Copy link
Member

@inkydragon inkydragon commented Dec 20, 2024

This pr replaced #42299

On Windows, we use libmingwex to provide math functions which are not implemented by msvcrt (Old Microsoft Libm).
From libmingwex: ldexp, log2l, exp2l, powi

Note: We are using a special toolchain i686-12.2.0-release-posix-sjlj from niXman/mingw-builds-binaries for i686-windows.

@inkydragon inkydragon added the DO NOT MERGE Do not merge this PR! label Dec 20, 2024
@inkydragon

This comment was marked as outdated.

@inkydragon

This comment was marked as outdated.

Make.inc Outdated Show resolved Hide resolved
@inkydragon
Copy link
Member Author

With newer msvcrt from gcc14, we can build julia-x64 without openblibm
https://buildkite.com/julialang/julia-master/builds/43184#0193e4ca-544e-43fd-b419-b3c2d245ba39

@inkydragon inkydragon force-pushed the cyhan/remove-openlibm branch from 5a78588 to fde32eb Compare December 21, 2024 08:27
@inkydragon
Copy link
Member Author

@giordano
Copy link
Contributor

With newer msvcrt from gcc14, we can build julia-x64 without openblibm

Does this mean that on Windows we'd need to require a very recent compiler?

@inkydragon
Copy link
Member Author

Does this mean that on Windows we'd need to require a very recent compiler?

MSYS2 only keeps the latest version of the package, so GCC 14 is used here.

Maybe a newer version of gcc isn't necessary, but I haven't tested it yet.
I guess just using the mingw toolchain and linking to mingw32, mingwex, msvcrt would be an alternative to openlibm.

@oscardssmith
Copy link
Member

As an alternative to this, could we just use LLVM libm? It's not complete, but IIRC the only thing that we actually depend on is the conversions which are implemented https://libc.llvm.org/headers/math/index.html#implementation-status

@inkydragon
Copy link
Member Author

As an alternative to this

After this PR, we use system libm.
Then, you can switch to LLVM libm, if you like.
Or, we can provide the configuration for switching libm in the build system.

@inkydragon inkydragon force-pushed the cyhan/remove-openlibm branch from 6f2a2d6 to 26b7ffb Compare January 18, 2025 07:38
@inkydragon inkydragon force-pushed the cyhan/remove-openlibm branch from 8c70304 to c43095f Compare January 18, 2025 07:57
@inkydragon inkydragon added external dependencies Involves LLVM, OpenBLAS, or other linked libraries excision Removal of code from Base or the repository labels Jan 19, 2025
@inkydragon inkydragon removed the DO NOT MERGE Do not merge this PR! label Jan 19, 2025
Comment on lines +131 to +133
-cp -a /mingw64/lib/libmsvcrt.a $(build_private_libdir)/
-cp -a /mingw64/lib/libmingw32.a $(build_private_libdir)/
-cp -a /mingw64/lib/libmingwex.a $(build_private_libdir)/
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe we want to add libmingw32, libmingwex to CSL too.

And if I use libmsvcrt.a from CSL, it failed to build.
Seems there is some version mismatch.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
excision Removal of code from Base or the repository external dependencies Involves LLVM, OpenBLAS, or other linked libraries
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants