Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
BaseTools/build_rule.template: Set additional Rust module linker flags (
#1098) ## Description This change sets the ImageBase in the PE header for Rust modules to `0` so they do not have a preferred base. This is similar to the EFI images produced by the edk2 build system. The subsystem type is also set to `efi_boot_service_driver` instead of the default target specification value of `EFI_APPLICATION`. Details for changing the subsystem type are here: https://doc.rust-lang.org/nightly/rustc/platform-support/unknown-uefi.html#requirements Ideally, these values would be set as individual `target.<triple>.rustflags` in `.cargo/config.toml`. However, we override the `/MAP` argument using `-C linker-args` in `build_rule.txt` to the build output directory. This must be set dynamically since the output directory and module name are based on per module values. Since the cargo configuration file does not support reading environment variables and setting an environment there in a `[env]` section would be too late to impact the commands that run in `build_rules.txt` (cargo is called from cargo make based on those rules), this is the simplest approach to retain the map file path in addition to the new changes. In the future, this may be moved to a common target specification so the values are available without these changes. - [ ] Impacts functionality? - [ ] Impacts security? - [x] Breaking change? - [ ] Includes tests? - [ ] Includes documentation? ## How This Was Tested - Checked `ImageBase` and `Subsystem` of EFI images in output directory to confirm expected values. ## Integration Instructions This change is marked as breaking in case flows were dependent on the previous behavior. Otherwise, no changes are nedeed. Signed-off-by: Michael Kubacki <[email protected]>
- Loading branch information