mirror of
https://github.com/torvalds/linux.git
synced 2025-04-06 00:16:18 +00:00
rust: pin-init: internal: synchronize with user-space version
Synchronize the internal macros crate with the user-space version that uses the quote crate [1] instead of a custom `quote!` macro. The imports in the different version are achieved using `cfg` on the kernel config value. This cfg is always set in the kernel and never set in the user-space version. Since the quote crate requires the proc_macro2 crate, imports also need to be adjusted and `.into()` calls have to be inserted. Link: https://crates.io/crates/quote [1] Signed-off-by: Benno Lossin <benno.lossin@proton.me> Reviewed-by: Andreas Hindborg <a.hindborg@kernel.org> Tested-by: Andreas Hindborg <a.hindborg@kernel.org> Reviewed-by: Fiona Behrens <me@Kloenk.dev> Link: https://lore.kernel.org/r/20250308110339.2997091-19-benno.lossin@proton.me Signed-off-by: Miguel Ojeda <ojeda@kernel.org>
This commit is contained in:
parent
02c01c089d
commit
7cb5dee4c8
@ -1,5 +1,8 @@
|
||||
// SPDX-License-Identifier: Apache-2.0 OR MIT
|
||||
|
||||
#[cfg(not(kernel))]
|
||||
use proc_macro2 as proc_macro;
|
||||
|
||||
use proc_macro::{TokenStream, TokenTree};
|
||||
|
||||
/// Parsed generics.
|
||||
|
@ -7,6 +7,13 @@
|
||||
//! `pin-init` proc macros.
|
||||
|
||||
#![cfg_attr(not(RUSTC_LINT_REASONS_IS_STABLE), feature(lint_reasons))]
|
||||
// Allow `.into()` to convert
|
||||
// - `proc_macro2::TokenStream` into `proc_macro::TokenStream` in the user-space version.
|
||||
// - `proc_macro::TokenStream` into `proc_macro::TokenStream` in the kernel version.
|
||||
// Clippy warns on this conversion, but it's required by the user-space version.
|
||||
//
|
||||
// Remove once we have `proc_macro2` in the kernel.
|
||||
#![allow(clippy::useless_conversion)]
|
||||
|
||||
use proc_macro::TokenStream;
|
||||
|
||||
@ -14,6 +21,9 @@ use proc_macro::TokenStream;
|
||||
#[path = "../../../macros/quote.rs"]
|
||||
#[macro_use]
|
||||
mod quote;
|
||||
#[cfg(not(kernel))]
|
||||
#[macro_use]
|
||||
extern crate quote;
|
||||
|
||||
mod helpers;
|
||||
mod pin_data;
|
||||
@ -23,17 +33,17 @@ mod zeroable;
|
||||
#[allow(missing_docs)]
|
||||
#[proc_macro_attribute]
|
||||
pub fn pin_data(inner: TokenStream, item: TokenStream) -> TokenStream {
|
||||
pin_data::pin_data(inner, item)
|
||||
pin_data::pin_data(inner.into(), item.into()).into()
|
||||
}
|
||||
|
||||
#[allow(missing_docs)]
|
||||
#[proc_macro_attribute]
|
||||
pub fn pinned_drop(args: TokenStream, input: TokenStream) -> TokenStream {
|
||||
pinned_drop::pinned_drop(args, input)
|
||||
pinned_drop::pinned_drop(args.into(), input.into()).into()
|
||||
}
|
||||
|
||||
#[allow(missing_docs)]
|
||||
#[proc_macro_derive(Zeroable)]
|
||||
pub fn derive_zeroable(input: TokenStream) -> TokenStream {
|
||||
zeroable::derive(input)
|
||||
zeroable::derive(input.into()).into()
|
||||
}
|
||||
|
@ -1,5 +1,8 @@
|
||||
// SPDX-License-Identifier: Apache-2.0 OR MIT
|
||||
|
||||
#[cfg(not(kernel))]
|
||||
use proc_macro2 as proc_macro;
|
||||
|
||||
use crate::helpers::{parse_generics, Generics};
|
||||
use proc_macro::{Group, Punct, Spacing, TokenStream, TokenTree};
|
||||
|
||||
|
@ -1,5 +1,8 @@
|
||||
// SPDX-License-Identifier: Apache-2.0 OR MIT
|
||||
|
||||
#[cfg(not(kernel))]
|
||||
use proc_macro2 as proc_macro;
|
||||
|
||||
use proc_macro::{TokenStream, TokenTree};
|
||||
|
||||
pub(crate) fn pinned_drop(_args: TokenStream, input: TokenStream) -> TokenStream {
|
||||
|
@ -1,5 +1,8 @@
|
||||
// SPDX-License-Identifier: GPL-2.0
|
||||
|
||||
#[cfg(not(kernel))]
|
||||
use proc_macro2 as proc_macro;
|
||||
|
||||
use crate::helpers::{parse_generics, Generics};
|
||||
use proc_macro::{TokenStream, TokenTree};
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user