mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-23 00:20:52 -05:00
rust: Respect HOSTCC when linking for host
Currently, rustc defaults to invoking `cc`, even if `HOSTCC` is defined, resulting in build failures in hermetic environments where `cc` does not exist. This includes both hostprogs and proc-macros. Since we are setting the linker to `HOSTCC`, we set the linker flavor to `gcc` explicitly. The linker-flavor selects both which linker to search for if the linker is unset, and which kind of linker flags to pass. Without this flag, `rustc` would attempt to determine which flags to pass based on the name of the binary passed as `HOSTCC`. `gcc` is the name of the linker-flavor used by `rustc` for all C compilers, including both `gcc` and `clang`. Signed-off-by: Matthew Maurer <mmaurer@google.com> Reviewed-by: Martin Rodriguez Reboredo <yakoyoku@gmail.com> Tested-by: Alice Ryhl <aliceryhl@google.com> Reviewed-by: Nick Desaulniers <ndesaulniers@google.com> Acked-by: Miguel Ojeda <ojeda@kernel.org> Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
This commit is contained in:
parent
ffa46bbc58
commit
80bac83a73
2 changed files with 4 additions and 0 deletions
|
@ -383,6 +383,8 @@ $(obj)/exports_kernel_generated.h: $(obj)/kernel.o FORCE
|
||||||
quiet_cmd_rustc_procmacro = $(RUSTC_OR_CLIPPY_QUIET) P $@
|
quiet_cmd_rustc_procmacro = $(RUSTC_OR_CLIPPY_QUIET) P $@
|
||||||
cmd_rustc_procmacro = \
|
cmd_rustc_procmacro = \
|
||||||
$(RUSTC_OR_CLIPPY) $(rust_common_flags) \
|
$(RUSTC_OR_CLIPPY) $(rust_common_flags) \
|
||||||
|
-Clinker-flavor=gcc -Clinker=$(HOSTCC) \
|
||||||
|
-Clink-args='$(call escsq,$(KBUILD_HOSTLDFLAGS))' \
|
||||||
--emit=dep-info=$(depfile) --emit=link=$@ --extern proc_macro \
|
--emit=dep-info=$(depfile) --emit=link=$@ --extern proc_macro \
|
||||||
--crate-type proc-macro \
|
--crate-type proc-macro \
|
||||||
--crate-name $(patsubst lib%.so,%,$(notdir $@)) $<
|
--crate-name $(patsubst lib%.so,%,$(notdir $@)) $<
|
||||||
|
|
|
@ -91,6 +91,8 @@ hostcxx_flags = -Wp,-MMD,$(depfile) \
|
||||||
# current working directory, which may be not accessible in the out-of-tree
|
# current working directory, which may be not accessible in the out-of-tree
|
||||||
# modules case.
|
# modules case.
|
||||||
hostrust_flags = --out-dir $(dir $@) --emit=dep-info=$(depfile) \
|
hostrust_flags = --out-dir $(dir $@) --emit=dep-info=$(depfile) \
|
||||||
|
-Clinker-flavor=gcc -Clinker=$(HOSTCC) \
|
||||||
|
-Clink-args='$(call escsq,$(KBUILD_HOSTLDFLAGS))' \
|
||||||
$(KBUILD_HOSTRUSTFLAGS) $(HOST_EXTRARUSTFLAGS) \
|
$(KBUILD_HOSTRUSTFLAGS) $(HOST_EXTRARUSTFLAGS) \
|
||||||
$(HOSTRUSTFLAGS_$(target-stem))
|
$(HOSTRUSTFLAGS_$(target-stem))
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue