forked from torvalds/linux
-
Notifications
You must be signed in to change notification settings - Fork 436
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
Third-party crates support: proc-macro2
, quote
, syn
, serde
and serde_derive
#1007
Open
ojeda
wants to merge
16
commits into
Rust-for-Linux:rust-next
Choose a base branch
from
ojeda:third-party
base: rust-next
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
+78,232
−25
Open
Changes from all commits
Commits
Show all changes
16 commits
Select commit
Hold shift + click to select a range
4d28d13
rust: proc-macro2: import crate
ojeda ff8917c
rust: proc-macro2: add SPDX License Identifiers
ojeda bb40745
rust: proc-macro2: remove `unicode_ident` dependency
ojeda 90523af
rust: quote: import crate
ojeda d7f4b0d
rust: quote: add SPDX License Identifiers
ojeda 313e6c9
rust: syn: import crate
ojeda f9bcfd0
rust: syn: add SPDX License Identifiers
ojeda 3916aa6
rust: syn: remove `unicode-ident` dependency
ojeda 2e4b1b4
rust: serde: import crate
ojeda 7fcbf51
rust: serde: add `no_fp_fmt_parse` support
ojeda 22605b8
rust: serde: enable the `core_c_str` feature
ojeda b56a317
rust: serde: add SPDX License Identifiers
ojeda 6f37f9b
rust: serde_derive: import crate
ojeda 16bebcf
rust: serde_derive: add SPDX License Identifiers
ojeda 9121b11
rust: Kbuild: enable `proc-macro2`, `quote`, `syn`, `serde` and `serd…
ojeda 7d2ea51
rust: test `serde` support
ojeda File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,6 @@ | ||
# SPDX-License-Identifier: GPL-2.0 | ||
|
||
*.rlib | ||
bindings_generated.rs | ||
bindings_helpers_generated.rs | ||
uapi_generated.rs | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -8,11 +8,12 @@ always-$(CONFIG_RUST) += exports_core_generated.h | |
obj-$(CONFIG_RUST) += helpers.o | ||
CFLAGS_REMOVE_helpers.o = -Wmissing-prototypes -Wmissing-declarations | ||
|
||
always-$(CONFIG_RUST) += libmacros.so | ||
no-clean-files += libmacros.so | ||
always-$(CONFIG_RUST) += libproc_macro2.rlib libquote.rlib libsyn.rlib | ||
always-$(CONFIG_RUST) += libserde_derive.so libmacros.so | ||
no-clean-files += libserde_derive.so libmacros.so | ||
|
||
always-$(CONFIG_RUST) += bindings/bindings_generated.rs bindings/bindings_helpers_generated.rs | ||
obj-$(CONFIG_RUST) += alloc.o bindings.o kernel.o | ||
obj-$(CONFIG_RUST) += alloc.o bindings.o serde.o kernel.o | ||
always-$(CONFIG_RUST) += exports_alloc_generated.h exports_bindings_generated.h \ | ||
exports_kernel_generated.h | ||
|
||
|
@@ -60,11 +61,73 @@ alloc-cfgs = \ | |
--cfg no_sync \ | ||
--cfg no_thin | ||
|
||
proc_macro2-skip_flags := \ | ||
--edition=2021 \ | ||
-Drust_2018_idioms \ | ||
-Dunreachable_pub \ | ||
-Dunsafe_op_in_unsafe_fn | ||
|
||
proc_macro2-flags := \ | ||
--edition=2018 \ | ||
-Amissing_docs \ | ||
--cfg 'feature="proc-macro"' \ | ||
--cfg use_proc_macro \ | ||
--cfg wrap_proc_macro | ||
|
||
quote-skip_flags := \ | ||
--edition=2021 \ | ||
-Drust_2018_idioms | ||
|
||
quote-flags := \ | ||
--edition=2018 \ | ||
-Amissing_docs \ | ||
--extern proc_macro2 \ | ||
--cfg 'feature="proc-macro"' | ||
|
||
syn-skip_flags := \ | ||
--edition=2021 \ | ||
-Drust_2018_idioms \ | ||
-Dunreachable_pub \ | ||
-Dunsafe_op_in_unsafe_fn | ||
|
||
syn-flags := \ | ||
--edition=2018 \ | ||
-Amissing_docs \ | ||
--cfg 'feature="clone-impls"' \ | ||
--cfg 'feature="derive"' \ | ||
--cfg 'feature="extra-traits"' \ | ||
--cfg 'feature="fold"' \ | ||
--cfg 'feature="full"' \ | ||
--cfg 'feature="parsing"' \ | ||
--cfg 'feature="printing"' \ | ||
--cfg 'feature="proc-macro"' \ | ||
--cfg 'feature="quote"' \ | ||
--cfg 'feature="visit"' \ | ||
--cfg 'feature="visit-mut"' | ||
|
||
serde_derive-skip_flags := \ | ||
--edition=2021 \ | ||
-Drust_2018_idioms \ | ||
-Dunreachable_pub | ||
|
||
serde_derive-flags := \ | ||
-Amissing_docs | ||
|
||
serde-skip_flags := \ | ||
--edition=2021 \ | ||
-Drust_2018_idioms \ | ||
-Dunreachable_pub | ||
|
||
serde-flags := \ | ||
-Amissing_docs \ | ||
--cfg no_fp_fmt_parse | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. If you pass |
||
|
||
quiet_cmd_rustdoc = RUSTDOC $(if $(rustdoc_host),H, ) $< | ||
cmd_rustdoc = \ | ||
OBJTREE=$(abspath $(objtree)) \ | ||
$(RUSTDOC) $(if $(rustdoc_host),$(rust_common_flags),$(rust_flags)) \ | ||
$(RUSTDOC) $(filter-out $(skip_flags),$(if $(rustdoc_host),$(rust_common_flags),$(rust_flags))) \ | ||
$(rustc_target_flags) -L$(objtree)/$(obj) \ | ||
--extern quote --extern syn \ | ||
--output $(objtree)/$(obj)/doc \ | ||
--crate-name $(subst rustdoc-,,$@) \ | ||
@$(objtree)/include/generated/rustc_cfg $< | ||
|
@@ -81,7 +144,7 @@ quiet_cmd_rustdoc = RUSTDOC $(if $(rustdoc_host),H, ) $< | |
# command-like flags to solve the issue. Meanwhile, we use the non-custom case | ||
# and then retouch the generated files. | ||
rustdoc: rustdoc-core rustdoc-macros rustdoc-compiler_builtins \ | ||
rustdoc-alloc rustdoc-kernel | ||
rustdoc-alloc rustdoc-kernel rustdoc-serde rustdoc-serde_derive | ||
$(Q)cp $(srctree)/Documentation/images/logo.svg $(objtree)/$(obj)/doc | ||
$(Q)cp $(srctree)/Documentation/images/COPYING-logo $(objtree)/$(obj)/doc | ||
$(Q)find $(objtree)/$(obj)/doc -name '*.html' -type f -print0 | xargs -0 sed -Ei \ | ||
|
@@ -116,17 +179,31 @@ rustdoc-alloc: $(src)/alloc/lib.rs rustdoc-core rustdoc-compiler_builtins FORCE | |
|
||
rustdoc-kernel: private rustc_target_flags = --extern alloc \ | ||
--extern build_error --extern macros=$(objtree)/$(obj)/libmacros.so \ | ||
--extern bindings --extern uapi | ||
--extern bindings --extern uapi --extern serde --extern serde_derive | ||
rustdoc-kernel: $(src)/kernel/lib.rs rustdoc-core rustdoc-macros \ | ||
rustdoc-compiler_builtins rustdoc-alloc $(obj)/libmacros.so \ | ||
$(obj)/bindings.o FORCE | ||
rustdoc-compiler_builtins rustdoc-alloc rustdoc-serde $(obj)/libmacros.so \ | ||
$(obj)/bindings.o $(obj)/libserde_derive.so FORCE | ||
$(call if_changed,rustdoc) | ||
|
||
rustdoc-serde_derive: private rustdoc_host = yes | ||
rustdoc-serde_derive: private skip_flags = $(serde_derive-skip_flags) | ||
rustdoc-serde_derive: private rustc_target_flags = --crate-type proc-macro \ | ||
--extern proc_macro -Amissing_docs | ||
rustdoc-serde_derive: $(src)/serde_derive/lib.rs FORCE | ||
$(call if_changed,rustdoc) | ||
|
||
rustdoc-serde: private skip_flags = $(serde-skip_flags) | ||
rustdoc-serde: private rustc_target_flags = --extern alloc --extern serde \ | ||
-Arustdoc::broken_intra_doc_links | ||
rustdoc-serde: $(src)/serde/lib.rs rustdoc-core FORCE | ||
$(call if_changed,rustdoc) | ||
|
||
quiet_cmd_rustc_test_library = RUSTC TL $< | ||
cmd_rustc_test_library = \ | ||
OBJTREE=$(abspath $(objtree)) \ | ||
$(RUSTC) $(rust_common_flags) \ | ||
@$(objtree)/include/generated/rustc_cfg $(rustc_target_flags) \ | ||
$(RUSTC) \ | ||
$(filter-out $(skip_flags),$(rust_common_flags) $(rustc_target_flags)) \ | ||
@$(objtree)/include/generated/rustc_cfg \ | ||
--crate-type $(if $(rustc_test_library_proc),proc-macro,rlib) \ | ||
--out-dir $(objtree)/$(obj)/test --cfg testlib \ | ||
--sysroot $(objtree)/$(obj)/test/sysroot \ | ||
|
@@ -136,9 +213,25 @@ quiet_cmd_rustc_test_library = RUSTC TL $< | |
rusttestlib-build_error: $(src)/build_error.rs rusttest-prepare FORCE | ||
$(call if_changed,rustc_test_library) | ||
|
||
rusttestlib-macros: private rustc_target_flags = --extern proc_macro | ||
rusttestlib-proc_macro2: private skip_flags = $(proc_macro2-skip_flags) | ||
rusttestlib-proc_macro2: private rustc_target_flags = $(proc_macro2-flags) | ||
rusttestlib-proc_macro2: $(src)/proc-macro2/lib.rs rusttest-prepare FORCE | ||
$(call if_changed,rustc_test_library) | ||
|
||
rusttestlib-quote: private skip_flags = $(quote-skip_flags) | ||
rusttestlib-quote: private rustc_target_flags = $(quote-flags) | ||
rusttestlib-quote: $(src)/quote/lib.rs rusttestlib-proc_macro2 FORCE | ||
$(call if_changed,rustc_test_library) | ||
|
||
rusttestlib-syn: private skip_flags = $(syn-skip_flags) | ||
rusttestlib-syn: private rustc_target_flags = $(syn-flags) | ||
rusttestlib-syn: $(src)/syn/lib.rs rusttestlib-quote FORCE | ||
$(call if_changed,rustc_test_library) | ||
|
||
rusttestlib-macros: private rustc_target_flags = --extern proc_macro \ | ||
--extern quote --extern syn | ||
rusttestlib-macros: private rustc_test_library_proc = yes | ||
rusttestlib-macros: $(src)/macros/lib.rs rusttest-prepare FORCE | ||
rusttestlib-macros: $(src)/macros/lib.rs rusttestlib-syn FORCE | ||
$(call if_changed,rustc_test_library) | ||
|
||
rusttestlib-bindings: $(src)/bindings/lib.rs rusttest-prepare FORCE | ||
|
@@ -147,6 +240,18 @@ rusttestlib-bindings: $(src)/bindings/lib.rs rusttest-prepare FORCE | |
rusttestlib-uapi: $(src)/uapi/lib.rs rusttest-prepare FORCE | ||
$(call if_changed,rustc_test_library) | ||
|
||
rusttestlib-serde_derive: private skip_flags = $(serde_derive-skip_flags) | ||
rusttestlib-serde_derive: private rustc_target_flags = --extern proc_macro \ | ||
--extern quote --extern syn $(serde_derive-flags) | ||
rusttestlib-serde_derive: private rustc_test_library_proc = yes | ||
rusttestlib-serde_derive: $(src)/serde_derive/lib.rs rusttestlib-syn FORCE | ||
$(call if_changed,rustc_test_library) | ||
|
||
rusttestlib-serde: private skip_flags = $(serde-skip_flags) | ||
rusttestlib-serde: private rustc_target_flags = $(serde-flags) | ||
rusttestlib-serde: $(src)/serde/lib.rs rusttest-prepare FORCE | ||
$(call if_changed,rustc_test_library) | ||
|
||
quiet_cmd_rustdoc_test = RUSTDOC T $< | ||
cmd_rustdoc_test = \ | ||
OBJTREE=$(abspath $(objtree)) \ | ||
|
@@ -222,17 +327,19 @@ quiet_cmd_rustsysroot = RUSTSYSROOT | |
rusttest-prepare: FORCE | ||
$(call if_changed,rustsysroot) | ||
|
||
rusttest-macros: private rustc_target_flags = --extern proc_macro | ||
rusttest-macros: private rustc_target_flags = --extern proc_macro \ | ||
--extern quote --extern syn | ||
rusttest-macros: private rustdoc_test_target_flags = --crate-type proc-macro | ||
rusttest-macros: $(src)/macros/lib.rs rusttest-prepare FORCE | ||
rusttest-macros: $(src)/macros/lib.rs rusttestlib-syn FORCE | ||
$(call if_changed,rustc_test) | ||
$(call if_changed,rustdoc_test) | ||
|
||
rusttest-kernel: private rustc_target_flags = --extern alloc \ | ||
--extern build_error --extern macros --extern bindings --extern uapi | ||
--extern build_error --extern macros --extern bindings --extern uapi \ | ||
--extern serde --extern serde_derive | ||
rusttest-kernel: $(src)/kernel/lib.rs rusttest-prepare \ | ||
rusttestlib-build_error rusttestlib-macros rusttestlib-bindings \ | ||
rusttestlib-uapi FORCE | ||
rusttestlib-uapi rusttestlib-serde rusttestlib-serde_derive FORCE | ||
$(call if_changed,rustc_test) | ||
$(call if_changed,rustc_test_library) | ||
|
||
|
@@ -348,17 +455,52 @@ $(obj)/exports_bindings_generated.h: $(obj)/bindings.o FORCE | |
$(obj)/exports_kernel_generated.h: $(obj)/kernel.o FORCE | ||
$(call if_changed,exports) | ||
|
||
quiet_cmd_rustc_hostlibrary = $(RUSTC_OR_CLIPPY_QUIET) H $@ | ||
cmd_rustc_hostlibrary = \ | ||
$(if $(skip_clippy),$(RUSTC),$(RUSTC_OR_CLIPPY)) \ | ||
$(filter-out $(skip_flags),$(rust_common_flags) $(rustc_target_flags)) \ | ||
--emit=dep-info,link --crate-type rlib -O \ | ||
--out-dir $(objtree)/$(obj) -L$(objtree)/$(obj) \ | ||
--crate-name $(patsubst lib%.rlib,%,$(notdir $@)) $<; \ | ||
mv $(objtree)/$(obj)/$(patsubst lib%.rlib,%,$(notdir $@)).d $(depfile); \ | ||
sed -i '/^\#/d' $(depfile) | ||
|
||
$(obj)/libproc_macro2.rlib: private skip_clippy = 1 | ||
$(obj)/libproc_macro2.rlib: private skip_flags = $(proc_macro2-skip_flags) | ||
$(obj)/libproc_macro2.rlib: private rustc_target_flags = $(proc_macro2-flags) | ||
$(obj)/libproc_macro2.rlib: $(src)/proc-macro2/lib.rs FORCE | ||
$(call if_changed_dep,rustc_hostlibrary) | ||
|
||
$(obj)/libquote.rlib: private skip_clippy = 1 | ||
$(obj)/libquote.rlib: private skip_flags = $(quote-skip_flags) | ||
$(obj)/libquote.rlib: private rustc_target_flags = $(quote-flags) | ||
$(obj)/libquote.rlib: $(src)/quote/lib.rs $(obj)/libproc_macro2.rlib FORCE | ||
$(call if_changed_dep,rustc_hostlibrary) | ||
|
||
$(obj)/libsyn.rlib: private skip_clippy = 1 | ||
$(obj)/libsyn.rlib: private skip_flags = $(syn-skip_flags) | ||
$(obj)/libsyn.rlib: private rustc_target_flags = $(syn-flags) | ||
$(obj)/libsyn.rlib: $(src)/syn/lib.rs $(obj)/libquote.rlib FORCE | ||
$(call if_changed_dep,rustc_hostlibrary) | ||
|
||
quiet_cmd_rustc_procmacro = $(RUSTC_OR_CLIPPY_QUIET) P $@ | ||
cmd_rustc_procmacro = \ | ||
$(RUSTC_OR_CLIPPY) $(rust_common_flags) \ | ||
$(if $(skip_clippy),$(RUSTC),$(RUSTC_OR_CLIPPY)) \ | ||
$(filter-out $(skip_flags),$(rust_common_flags) $(rustc_target_flags)) \ | ||
--emit=dep-info=$(depfile) --emit=link=$@ --extern proc_macro \ | ||
--crate-type proc-macro \ | ||
--crate-name $(patsubst lib%.so,%,$(notdir $@)) $< | ||
--extern quote --extern syn --crate-type proc-macro \ | ||
-L$(objtree)/$(obj) --crate-name $(patsubst lib%.so,%,$(notdir $@)) $< | ||
|
||
# Procedural macros can only be used with the `rustc` that compiled it. | ||
# Therefore, to get `libmacros.so` automatically recompiled when the compiler | ||
# version changes, we add `core.o` as a dependency (even if it is not needed). | ||
$(obj)/libmacros.so: $(src)/macros/lib.rs $(obj)/core.o FORCE | ||
$(obj)/libserde_derive.so: private skip_clippy = 1 | ||
$(obj)/libserde_derive.so: private skip_flags = $(serde_derive-skip_flags) | ||
$(obj)/libserde_derive.so: private rustc_target_flags = $(serde_derive-flags) | ||
$(obj)/libserde_derive.so: $(src)/serde_derive/lib.rs $(obj)/libsyn.rlib $(obj)/core.o FORCE | ||
$(call if_changed_dep,rustc_procmacro) | ||
|
||
$(obj)/libmacros.so: $(src)/macros/lib.rs $(obj)/libsyn.rlib $(obj)/core.o FORCE | ||
$(call if_changed_dep,rustc_procmacro) | ||
|
||
quiet_cmd_rustc_library = $(if $(skip_clippy),RUSTC,$(RUSTC_OR_CLIPPY_QUIET)) L $@ | ||
|
@@ -420,10 +562,18 @@ $(obj)/uapi.o: $(src)/uapi/lib.rs \ | |
$(obj)/uapi/uapi_generated.rs FORCE | ||
$(call if_changed_dep,rustc_library) | ||
|
||
$(obj)/serde.o: private skip_clippy = 1 | ||
$(obj)/serde.o: private skip_flags = $(serde-skip_flags) | ||
$(obj)/serde.o: private rustc_target_flags = $(serde-flags) | ||
$(obj)/serde.o: $(src)/serde/lib.rs $(obj)/compiler_builtins.o FORCE | ||
$(call if_changed_dep,rustc_library) | ||
|
||
$(obj)/kernel.o: private rustc_target_flags = --extern alloc \ | ||
--extern build_error --extern macros --extern bindings --extern uapi | ||
--extern build_error --extern macros --extern bindings --extern uapi \ | ||
--extern serde --extern serde_derive | ||
$(obj)/kernel.o: $(src)/kernel/lib.rs $(obj)/alloc.o $(obj)/build_error.o \ | ||
$(obj)/libmacros.so $(obj)/bindings.o $(obj)/uapi.o FORCE | ||
$(obj)/libmacros.so $(obj)/bindings.o $(obj)/uapi.o \ | ||
$(obj)/serde.o $(obj)/libserde_derive.so FORCE | ||
$(call if_changed_dep,rustc_library) | ||
|
||
endif # CONFIG_RUST |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
// SPDX-License-Identifier: Apache-2.0 OR MIT | ||
|
||
//! Test `serde`. | ||
//! | ||
//! It contains a data format used by the `rust_serde` sample, as well | ||
//! as a quick check that `serde_derive` works in the `kernel` crate too. | ||
|
||
#![allow(missing_docs)] | ||
|
||
mod de; | ||
mod error; | ||
mod ser; | ||
|
||
pub use de::{from_bytes, Deserializer}; | ||
pub use error::{Error, Result}; | ||
pub use ser::{to_vec, Serializer}; | ||
|
||
use serde_derive::{Deserialize, Serialize}; | ||
|
||
#[derive(Serialize, Deserialize, Debug)] | ||
pub struct S { | ||
a: (), | ||
b: bool, | ||
c: bool, | ||
d: (), | ||
} |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe do
--cap-lints allow
for all third-party crates? This overrides any-D
arguments. It is also what cargo passes for all non-local crates.