-
Notifications
You must be signed in to change notification settings - Fork 718
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
Conflicting C(XX)FLAGS
when cross-compiling to aarch64-pc-windows-msvc
#2215
Comments
In `ring` we need to check if the compiler is `clang-cl` to prevent overwriting it with `clang` (see all details in briansmith/ring#2215), but `cc-rs` does not currently expose this despite already tracking it. By adding this getter we can steer that logic to not overwrite the compiler when it is `clang-cl`. Perhaps, since `ToolFamily` is `pub` (but not yet reexported from `lib.rs`), could we have a public `Tool::family()` getter to not have to extend these `is_xxx()` getters whenever a downstream crate wants to know something new?
@briansmith these are the errors that show up when compiling with
The first ones in ring/crypto/fipsmodule/bn/internal.h Lines 186 to 195 in 0223acb
A fix for this is described here: The second Lines 47 to 54 in 0223acb
|
First of all thanks for landing #1339 in some crates.io release! Would be great if this repository had
git
tags to follow along where commits are reachable 😅Setup
When cross-compiling (currently from a Linux setup) to Windows, it's common to use https://jake-shadle.github.io/xwin/ / https://github.com/Jake-Shadle/xwin to set up headers and libraries.
When running this in my home directory (
/home/marijn
):$ xwin --arch x86_64,aarch64 --sdk-version 10.0.22621 splat
I add the following to my
~/.cargo/config.toml
to support cross-compiling C(++) sources in our Rust tree, and ultimately linking a binary:Problem statement
Unfortunately the Windows ARM64 support PR (#1339) overwrites the compiler with
clang
:ring/build.rs
Lines 549 to 556 in d2e401f
This code doesn't modify the flags, and leaves what my environment has in
CFLAGS_aarch64-pc-windows-msvc
in place. Without using theclang-cl
driver,clang
doesn't understand the above commands and compilingring
errors out with a bunch of errors like:Proposed solution
As mentioned at #1339 (comment)
clang-cl
works, albeit currently (on LLVM18.1.8
) with lots of warnings of the form:I'd be happy to PR a change to not overwrite the compiler when it is
clang-cl
like, next to the existing... && !compiler.is_clang_like()
.cc-rs
already tracks if it'sclang_cl
but doesn't currently expose that publicly, so we'll have to add that first.Thanks!
The text was updated successfully, but these errors were encountered: