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

Mechanism for automatically passing flags used by rustc #1254

Closed
mrkajetanp opened this issue Nov 1, 2024 · 6 comments · Fixed by #1279
Closed

Mechanism for automatically passing flags used by rustc #1254

mrkajetanp opened this issue Nov 1, 2024 · 6 comments · Fixed by #1279

Comments

@mrkajetanp
Copy link
Contributor

When cc-rs is running in a build script, it currently does not check which flags were passed to rustc.

There are some flags which in order to be fully effective need to be passed to both rustc and cc, a good example being AArch64 branch protection - if the Rust code is built with BTI but the C component is not, that will disable BTI for the whole binary.

Would some mechanism for checking which flags were passed to rustc and determining their corresponding cc flags be desirable to have? This could either be in the form of adding them in automatically, a separate function such as inherit_rustc_flags() or even just a warning to the user that some flags that should match don't match.

I'm thinking about implementing something along the lines of what I described above, but I wanted to ask for some thoughts from people who work on this crate. Is this desirable in the first place? If so, roughly what direction should I go in with this?

@NobodyXu
Copy link
Collaborator

NobodyXu commented Nov 1, 2024

Thanks, we definitely want more data to be fetcher from cargoz

Can you provide more details on what rustc/cargo flags it is?

@mrkajetanp
Copy link
Contributor Author

The specific case I'm coming at this with is -Z branch-protection, e.g. -Z branch-protection=pac-ret,bti.
The corresponding cc flag would be -mbranch-protection=pac-ret+bti.
I imagine this would apply to some other flags too and in the end we could just have a rustc => cc flag match statement that could be expanded over time.
We can read the flags through CARGO_ENCODED_RUSTFLAGS and parse those from there.

@NobodyXu
Copy link
Collaborator

NobodyXu commented Nov 1, 2024

Thanks that's a good idea, I would accept a PR for it.

@mrkajetanp
Copy link
Contributor Author

Sounds good, will write up a PR then.
Should this be an opt-in thing with its own builder function? E.g. like

cc::Build::new().file("foo.c").inherit_rustc_flags().compile("foo");

Or should we have this done by default with some opt-out?

@NobodyXu
Copy link
Collaborator

NobodyXu commented Nov 1, 2024

I think opt-out makes more sense, or maybe we don't even need an opt-out mechanism.

AFAIK the current cargo env usage does not have any opt-out mechanism.

@madsmtm
Copy link
Collaborator

madsmtm commented Nov 1, 2024

List of codegen options that could be interesting (I'm going through the list of rustc's -C options, and matching them to Clang's options):

  • -Car: Deprecated
  • -Ccode-model: -mcmodel
  • -Ccollapse-macro-debuginfo: Rust specific
  • -Ccodegen-units: Rust specific
  • -Ccontrol-flow-guard: -mguard
  • -Cdebug-assertions: Should probably be controlled by something like CARGO_CFG_DEBUG_ASSERTIONS instead (except that doesn't currently work).
  • -Cdebuginfo: Read DEBUG instead (needs to be changed to include all values).
  • -Cdefault-linker-libraries: Probably desirable to control this separately between the Rust and C compiler.
  • -Cdlltool: ?
  • -Cembed-bitcode: -fembed-bitcode
  • -Cextra-filename: Rust specific.
  • -Cforce-frame-pointers: -fno-omit-frame-pointer
  • -Cforce-unwind-tables: ? Maybe some sort of -fexception flag?
  • -Cincremental: Rust specific.
  • -Cinline-threshold: Deprecated.
  • -Cinstrument-coverage: -fprofile-generate?
  • -Clink-arg / -Clink-args: Need to ignore, since though we could pass these using the -Xlinker flag, these flags are intended for the final executable, and cc is only producing an intermediary.
  • -Clink-dead-code: -dead_strip/--gc-sections
  • -Clink-self-contained: May be Rust specific?
  • -Clinker / -Clinker-flavor: We could possibly query the linker, and use it if it's a C compiler, but that'd probably be unexpected.
  • -Clinker-plugin-lto: ?
  • -Cllvm-args: Maybe forward these directly to Clang? Or maybe inside -mllvm?
  • -Clto: -flto, though cross-language LTO is hard.
  • -Cmetadata: Rust specific.
  • -Cno-prepopulate-passes: Rust specific.
  • -Cno-redzone: -mred-zone
  • -Cno-stack-check: Deprecated.
  • -Cno-vectorize-loops: -fno-vectorize
  • -Cno-vectorize-slp: -fno-slp-vectorize
  • -Copt-level: Read OPT_LEVEL instead.
  • -Coverflow-checks: -ftrapv/-fwrapv?
  • -Cpanic: -fexceptions
  • -Cpasses: ?
  • -Cprefer-dynamic: Rust specific.
  • -Cprofile-generate: -fprofile-generate
  • -Cprofile-use: -fprofile-use
  • -Crelocation-model: -mdynamic-no-pic
  • -Crelro-level: -Wl,-z,relro?
  • -Cremark: -R?
  • -Crpath: ?
  • -Csave-temps: -save-temps, but might need more to integrate with Cargo?
  • -Csoft-float: -msoft-float
  • -Csplit-debuginfo: Maybe -gsplit-dwarf?
  • -Cstrip: Rust specific (invokes an external tool after compilation).
  • -Csymbol-mangling-version: Rust specific.
  • -Ctarget-cpu: -march (because -Ctarget-cpu forces that CPU, so -mcpu is too weak (?)).
  • -Ctarget-feature: Use CARGO_CFG_TARGET_FEATURE instead.
  • -Ctune-cpu: -mtune (or perhaps -mcpu?)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants