Skip to content

Commit d7659ac

Browse files
committed
rust: add pin-init crate build infrastructure
Add infrastructure for moving the initialization API to its own crate. Covers all make targets such as `rust-analyzer` and `rustdoc`. The tests of pin-init are not added to `rusttest`, as they are already tested in the user-space repository [1]. Link: https://github.com/Rust-for-Linux/pin-init [1] Co-developed-by: Benno Lossin <[email protected]> Signed-off-by: Benno Lossin <[email protected]> Tested-by: Andreas Hindborg <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Miguel Ojeda <[email protected]>
1 parent b321b93 commit d7659ac

File tree

6 files changed

+86
-20
lines changed

6 files changed

+86
-20
lines changed

rust/Makefile

Lines changed: 57 additions & 18 deletions
Original file line numberDiff line numberDiff line change
@@ -12,7 +12,7 @@ obj-$(CONFIG_RUST) += helpers/helpers.o
1212
CFLAGS_REMOVE_helpers/helpers.o = -Wmissing-prototypes -Wmissing-declarations
1313

1414
always-$(CONFIG_RUST) += bindings/bindings_generated.rs bindings/bindings_helpers_generated.rs
15-
obj-$(CONFIG_RUST) += bindings.o kernel.o
15+
obj-$(CONFIG_RUST) += bindings.o pin_init.o kernel.o
1616
always-$(CONFIG_RUST) += exports_helpers_generated.h \
1717
exports_bindings_generated.h exports_kernel_generated.h
1818

@@ -41,7 +41,10 @@ ifdef CONFIG_RUST
4141
libmacros_name := $(shell MAKEFLAGS= $(RUSTC) --print file-names --crate-name macros --crate-type proc-macro - </dev/null)
4242
libmacros_extension := $(patsubst libmacros.%,%,$(libmacros_name))
4343

44-
always-$(CONFIG_RUST) += $(libmacros_name)
44+
libpin_init_internal_name := $(shell MAKEFLAGS= $(RUSTC) --print file-names --crate-name pin_init_internal --crate-type proc-macro - </dev/null)
45+
libpin_init_internal_extension := $(patsubst libpin_init_internal.%,%,$(libpin_init_internal_name))
46+
47+
always-$(CONFIG_RUST) += $(libmacros_name) $(libpin_init_internal_name)
4548

4649
# `$(rust_flags)` is passed in case the user added `--sysroot`.
4750
rustc_sysroot := $(shell MAKEFLAGS= $(RUSTC) $(rust_flags) --print sysroot)
@@ -80,7 +83,7 @@ quiet_cmd_rustdoc = RUSTDOC $(if $(rustdoc_host),H, ) $<
8083
# command-like flags to solve the issue. Meanwhile, we use the non-custom case
8184
# and then retouch the generated files.
8285
rustdoc: rustdoc-core rustdoc-macros rustdoc-compiler_builtins \
83-
rustdoc-kernel
86+
rustdoc-kernel rustdoc-pin_init
8487
$(Q)cp $(srctree)/Documentation/images/logo.svg $(rustdoc_output)/static.files/
8588
$(Q)cp $(srctree)/Documentation/images/COPYING-logo $(rustdoc_output)/static.files/
8689
$(Q)find $(rustdoc_output) -name '*.html' -type f -print0 | xargs -0 sed -Ei \
@@ -110,11 +113,24 @@ rustdoc-compiler_builtins: $(src)/compiler_builtins.rs rustdoc-core FORCE
110113
rustdoc-ffi: $(src)/ffi.rs rustdoc-core FORCE
111114
+$(call if_changed,rustdoc)
112115

113-
rustdoc-kernel: private rustc_target_flags = --extern ffi \
116+
rustdoc-pin_init_internal: private rustdoc_host = yes
117+
rustdoc-pin_init_internal: private rustc_target_flags = --cfg kernel \
118+
--extern proc_macro --crate-type proc-macro
119+
rustdoc-pin_init_internal: $(src)/pin-init/internal/src/_lib.rs FORCE
120+
+$(call if_changed,rustdoc)
121+
122+
rustdoc-pin_init: private rustdoc_host = yes
123+
rustdoc-pin_init: private rustc_target_flags = --extern pin_init_internal \
124+
--extern macros --extern alloc --cfg kernel --cfg feature=\"alloc\"
125+
rustdoc-pin_init: $(src)/pin-init/src/_lib.rs rustdoc-pin_init_internal \
126+
rustdoc-macros FORCE
127+
+$(call if_changed,rustdoc)
128+
129+
rustdoc-kernel: private rustc_target_flags = --extern ffi --extern pin_init \
114130
--extern build_error --extern macros \
115131
--extern bindings --extern uapi
116132
rustdoc-kernel: $(src)/kernel/lib.rs rustdoc-core rustdoc-ffi rustdoc-macros \
117-
rustdoc-compiler_builtins $(obj)/$(libmacros_name) \
133+
rustdoc-pin_init rustdoc-compiler_builtins $(obj)/$(libmacros_name) \
118134
$(obj)/bindings.o FORCE
119135
+$(call if_changed,rustdoc)
120136

@@ -139,12 +155,24 @@ rusttestlib-macros: private rustc_test_library_proc = yes
139155
rusttestlib-macros: $(src)/macros/lib.rs FORCE
140156
+$(call if_changed,rustc_test_library)
141157

158+
rusttestlib-pin_init_internal: private rustc_target_flags = --cfg kernel \
159+
--extern proc_macro
160+
rusttestlib-pin_init_internal: private rustc_test_library_proc = yes
161+
rusttestlib-pin_init_internal: $(src)/pin-init/internal/src/_lib.rs FORCE
162+
+$(call if_changed,rustc_test_library)
163+
164+
rusttestlib-pin_init: private rustc_target_flags = --extern pin_init_internal \
165+
--extern macros --cfg kernel
166+
rusttestlib-pin_init: $(src)/pin-init/src/_lib.rs rusttestlib-macros \
167+
rusttestlib-pin_init_internal $(obj)/$(libpin_init_internal_name) FORCE
168+
+$(call if_changed,rustc_test_library)
169+
142170
rusttestlib-kernel: private rustc_target_flags = --extern ffi \
143-
--extern build_error --extern macros \
171+
--extern build_error --extern macros --extern pin_init \
144172
--extern bindings --extern uapi
145-
rusttestlib-kernel: $(src)/kernel/lib.rs \
146-
rusttestlib-bindings rusttestlib-uapi rusttestlib-build_error \
147-
$(obj)/$(libmacros_name) $(obj)/bindings.o FORCE
173+
rusttestlib-kernel: $(src)/kernel/lib.rs rusttestlib-bindings rusttestlib-uapi \
174+
rusttestlib-build_error rusttestlib-pin_init $(obj)/$(libmacros_name) \
175+
$(obj)/bindings.o FORCE
148176
+$(call if_changed,rustc_test_library)
149177

150178
rusttestlib-bindings: private rustc_target_flags = --extern ffi
@@ -172,8 +200,8 @@ quiet_cmd_rustdoc_test_kernel = RUSTDOC TK $<
172200
mkdir -p $(objtree)/$(obj)/test/doctests/kernel; \
173201
OBJTREE=$(abspath $(objtree)) \
174202
$(RUSTDOC) --test $(rust_flags) \
175-
-L$(objtree)/$(obj) --extern ffi --extern kernel \
176-
--extern build_error --extern macros \
203+
-L$(objtree)/$(obj) --extern ffi --extern pin_init \
204+
--extern kernel --extern build_error --extern macros \
177205
--extern bindings --extern uapi \
178206
--no-run --crate-name kernel -Zunstable-options \
179207
--sysroot=/dev/null \
@@ -203,18 +231,18 @@ quiet_cmd_rustc_test = $(RUSTC_OR_CLIPPY_QUIET) T $<
203231
rusttest: rusttest-macros rusttest-kernel
204232

205233
rusttest-macros: private rustc_target_flags = --extern proc_macro \
206-
--extern macros --extern kernel
234+
--extern macros --extern kernel --extern pin_init
207235
rusttest-macros: private rustdoc_test_target_flags = --crate-type proc-macro
208236
rusttest-macros: $(src)/macros/lib.rs \
209-
rusttestlib-macros rusttestlib-kernel FORCE
237+
rusttestlib-macros rusttestlib-kernel rusttestlib-pin_init FORCE
210238
+$(call if_changed,rustc_test)
211239
+$(call if_changed,rustdoc_test)
212240

213-
rusttest-kernel: private rustc_target_flags = --extern ffi \
241+
rusttest-kernel: private rustc_target_flags = --extern ffi --extern pin_init \
214242
--extern build_error --extern macros --extern bindings --extern uapi
215243
rusttest-kernel: $(src)/kernel/lib.rs rusttestlib-ffi rusttestlib-kernel \
216244
rusttestlib-build_error rusttestlib-macros rusttestlib-bindings \
217-
rusttestlib-uapi FORCE
245+
rusttestlib-uapi rusttestlib-pin_init FORCE
218246
+$(call if_changed,rustc_test)
219247

220248
ifdef CONFIG_CC_IS_CLANG
@@ -361,7 +389,7 @@ $(obj)/exports_kernel_generated.h: $(obj)/kernel.o FORCE
361389

362390
quiet_cmd_rustc_procmacro = $(RUSTC_OR_CLIPPY_QUIET) P $@
363391
cmd_rustc_procmacro = \
364-
$(RUSTC_OR_CLIPPY) $(rust_common_flags) \
392+
$(RUSTC_OR_CLIPPY) $(rust_common_flags) $(rustc_target_flags) \
365393
-Clinker-flavor=gcc -Clinker=$(HOSTCC) \
366394
-Clink-args='$(call escsq,$(KBUILD_PROCMACROLDFLAGS))' \
367395
--emit=dep-info=$(depfile) --emit=link=$@ --extern proc_macro \
@@ -372,6 +400,10 @@ quiet_cmd_rustc_procmacro = $(RUSTC_OR_CLIPPY_QUIET) P $@
372400
$(obj)/$(libmacros_name): $(src)/macros/lib.rs FORCE
373401
+$(call if_changed_dep,rustc_procmacro)
374402

403+
$(obj)/$(libpin_init_internal_name): private rustc_target_flags = --cfg kernel
404+
$(obj)/$(libpin_init_internal_name): $(src)/pin-init/internal/src/_lib.rs FORCE
405+
+$(call if_changed_dep,rustc_procmacro)
406+
375407
quiet_cmd_rustc_library = $(if $(skip_clippy),RUSTC,$(RUSTC_OR_CLIPPY_QUIET)) L $@
376408
cmd_rustc_library = \
377409
OBJTREE=$(abspath $(objtree)) \
@@ -451,6 +483,13 @@ $(obj)/compiler_builtins.o: private rustc_objcopy = -w -W '__*'
451483
$(obj)/compiler_builtins.o: $(src)/compiler_builtins.rs $(obj)/core.o FORCE
452484
+$(call if_changed_rule,rustc_library)
453485

486+
$(obj)/pin_init.o: private skip_gendwarfksyms = 1
487+
$(obj)/pin_init.o: private rustc_target_flags = --extern pin_init_internal \
488+
--extern macros --cfg kernel
489+
$(obj)/pin_init.o: $(src)/pin-init/src/_lib.rs $(obj)/compiler_builtins.o \
490+
$(obj)/$(libpin_init_internal_name) $(obj)/$(libmacros_name) FORCE
491+
+$(call if_changed_rule,rustc_library)
492+
454493
$(obj)/build_error.o: private skip_gendwarfksyms = 1
455494
$(obj)/build_error.o: $(src)/build_error.rs $(obj)/compiler_builtins.o FORCE
456495
+$(call if_changed_rule,rustc_library)
@@ -473,9 +512,9 @@ $(obj)/uapi.o: $(src)/uapi/lib.rs \
473512
$(obj)/uapi/uapi_generated.rs FORCE
474513
+$(call if_changed_rule,rustc_library)
475514

476-
$(obj)/kernel.o: private rustc_target_flags = --extern ffi \
515+
$(obj)/kernel.o: private rustc_target_flags = --extern ffi --extern pin_init \
477516
--extern build_error --extern macros --extern bindings --extern uapi
478-
$(obj)/kernel.o: $(src)/kernel/lib.rs $(obj)/build_error.o \
517+
$(obj)/kernel.o: $(src)/kernel/lib.rs $(obj)/build_error.o $(obj)/pin_init.o \
479518
$(obj)/$(libmacros_name) $(obj)/bindings.o $(obj)/uapi.o FORCE
480519
+$(call if_changed_rule,rustc_library)
481520

rust/pin-init/internal/src/_lib.rs

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
// SPDX-License-Identifier: Apache-2.0 OR MIT
2+
3+
//! Will be removed in a future commit, only exists to prevent compilation errors.

rust/pin-init/internal/src/lib.rs

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,9 @@
11
// SPDX-License-Identifier: Apache-2.0 OR MIT
22

3+
// When fixdep scans this, it will find this string `CONFIG_RUSTC_VERSION_TEXT`
4+
// and thus add a dependency on `include/config/RUSTC_VERSION_TEXT`, which is
5+
// touched by Kconfig when the version string from the compiler changes.
6+
37
#[allow(missing_docs)]
48
#[proc_macro_attribute]
59
pub fn pin_data(inner: TokenStream, item: TokenStream) -> TokenStream {

rust/pin-init/src/_lib.rs

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
// SPDX-License-Identifier: Apache-2.0 OR MIT
2+
3+
//! Will be removed in a future commit, only exists to prevent compilation errors.
4+
5+
#![no_std]

scripts/Makefile.build

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -237,7 +237,7 @@ rust_common_cmd = \
237237
-Zallow-features=$(rust_allowed_features) \
238238
-Zcrate-attr=no_std \
239239
-Zcrate-attr='feature($(rust_allowed_features))' \
240-
-Zunstable-options --extern kernel \
240+
-Zunstable-options --extern pin_init --extern kernel \
241241
--crate-type rlib -L $(objtree)/rust/ \
242242
--crate-name $(basename $(notdir $@)) \
243243
--sysroot=/dev/null \

scripts/generate_rust_analyzer.py

Lines changed: 16 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -93,10 +93,25 @@ def append_crate(display_name, root_module, deps, cfg=[], is_workspace_member=Tr
9393
)
9494
crates[-1]["env"]["OBJTREE"] = str(objtree.resolve(True))
9595

96+
append_crate(
97+
"pin_init_internal",
98+
srctree / "rust" / "pin-init" / "internal" / "src" / "_lib.rs",
99+
[],
100+
cfg=["kernel"],
101+
is_proc_macro=True,
102+
)
103+
104+
append_crate(
105+
"pin_init",
106+
srctree / "rust" / "pin-init" / "src" / "_lib.rs",
107+
["core", "pin_init_internal", "macros"],
108+
cfg=["kernel"],
109+
)
110+
96111
append_crate(
97112
"kernel",
98113
srctree / "rust" / "kernel" / "lib.rs",
99-
["core", "macros", "build_error", "bindings"],
114+
["core", "macros", "build_error", "bindings", "pin_init"],
100115
cfg=cfg,
101116
)
102117
crates[-1]["source"] = {

0 commit comments

Comments
 (0)