Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp13876878rwd; Sat, 24 Jun 2023 07:59:47 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ6o25yKq9VyuK0xhYg6mMej0YUv2C3y88S55HXORHKQaU17otlCObdYXLn8IWiTOxuLIQyW X-Received: by 2002:a05:6a00:3a0c:b0:666:8cbb:6e0f with SMTP id fj12-20020a056a003a0c00b006668cbb6e0fmr19692895pfb.3.1687618787129; Sat, 24 Jun 2023 07:59:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1687618787; cv=none; d=google.com; s=arc-20160816; b=TL4a/Yqdrt5e5GDesFfxP6Z4WH3JCa3Z7EyNRRTWp9HWj15o9EtWN2XE/pdR9CeEF4 2HmKqMT8Y6X7XXIkPxPqqM0tq0rUv7phRBKu78bNFVIWTyosbq6+3wNpBx7s2QF/sADf 4e+e2TyILpMpH2Xm7Xn0lLoExFKj1gkDGfCU8gHbFWISMVM7iTzkVMsSFs0vX+oAA6vz q6Q8K5rG3StHYYvTVXnbqWNvejLjFHE9du8h97xalRsvyDlxp7nxetwtCG0LekgT/kWw 8p0enj0Ypq0JCwKm/aNxugpJ/T+TFCvMiLs/b+lEckEydrWJgKge0zrt9b2AjGhV08ss huQA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :feedback-id:references:in-reply-to:message-id:subject:cc:from:to :dkim-signature:date; bh=YV5/XlO7DY5i9iDZ5ZmMmTj4xvcJ6rJdDPORDOCsGYI=; fh=G5JJZHPpWxnD6ZFNcd5f5J3pAM1l8A+sr+uFjGq+s0E=; b=Z8Yy8HEm3yrRFoiNIZXOJCyqQdpoIUG33+++RZwLpEMh4rqpdb5rV6rNs52KClQLTW z2eziHfu0zj4UWVi64eIcZDd1gtMZX98uoFaXUgEKoLY00xhm4uXiRpNcr9DMuiMI04U Gy7j+7pqjl+2spU5s9fA6Qp/zTrU/lUeiVVJX3BlZZL43VcF48jZUuWBo7N2UfyrZ1dC Xt8s75cOc+LtgRdyO6iww59Ziuv/sBSCvMF8fEW8uPh12S/VF/og1u4bPsoGQrrnhdrL PUMIRvg3a2UIVvhJXFeMgENk9GmKqtp2bn4OS+Ike5TrLvNZz5s98DBdc4TxFdfkrOWl dNYA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@protonmail.com header.s=protonmail3 header.b=fXB8WBmt; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=protonmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id cm6-20020a056a00338600b00660278b8422si1324970pfb.158.2023.06.24.07.59.35; Sat, 24 Jun 2023 07:59:47 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@protonmail.com header.s=protonmail3 header.b=fXB8WBmt; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=protonmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233071AbjFXOzX (ORCPT + 99 others); Sat, 24 Jun 2023 10:55:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43332 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229445AbjFXOzX (ORCPT ); Sat, 24 Jun 2023 10:55:23 -0400 Received: from mail-4318.protonmail.ch (mail-4318.protonmail.ch [185.70.43.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4D99AE7D; Sat, 24 Jun 2023 07:55:21 -0700 (PDT) Date: Sat, 24 Jun 2023 14:55:03 +0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=protonmail.com; s=protonmail3; t=1687618519; x=1687877719; bh=YV5/XlO7DY5i9iDZ5ZmMmTj4xvcJ6rJdDPORDOCsGYI=; h=Date:To:From:Cc:Subject:Message-ID:In-Reply-To:References: Feedback-ID:From:To:Cc:Date:Subject:Reply-To:Feedback-ID: Message-ID:BIMI-Selector; b=fXB8WBmtq1Lk+tnc5sME0w+8jCgQvFVvXDv5UDr8/Z1mvV0iZ0VUstye85cMmqTlO WY7u7vQ+VhRzTYIMfCgFbps4OBvwN5zZID0QplZhrVIiNIx70bJXzRIVJYMDuC+9Eo P0gRZw+WR+xnWC2lqk4jnYbnPs/0tQMqgSt7xdu8jSdUBP4HQ7yzHOiPhFvU/W6f7t jN4Fnof4uCKdplTknTpIFcdHNy11u//TmVyn6E1qCkak/48Es8ukMOGiWG94w5P2gF gy2zuD9qDpZ5HIMp3dCup/XF/RAuBH36dQF1fBE9fRTDefRx5cDBVxxtbrVDfoee73 C0xp0FrZ8VClg== To: Benno Lossin From: =?utf-8?Q?Bj=C3=B6rn_Roy_Baron?= Cc: Miguel Ojeda , Wedson Almeida Filho , Alex Gaynor , Boqun Feng , Gary Guo , Alice Ryhl , Andreas Hindborg , rust-for-linux@vger.kernel.org, linux-kernel@vger.kernel.org, patches@lists.linux.dev, Asahi Lina Subject: Re: [PATCH 2/7] rust: add derive macro for `Zeroable` Message-ID: In-Reply-To: <20230624092330.157338-2-benno.lossin@proton.me> References: <20230624092330.157338-1-benno.lossin@proton.me> <20230624092330.157338-2-benno.lossin@proton.me> Feedback-ID: 27884398:user:proton MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM,RCVD_IN_MSPIKE_H5, RCVD_IN_MSPIKE_WL,SPF_HELO_PASS,SPF_PASS,T_SCC_BODY_TEXT_LINE, URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Saturday, June 24th, 2023 at 11:25, Benno Lossin wrote: > Add a derive proc-macro for the `Zeroable` trait. The macro supports > structs where every field implements the `Zeroable` trait. This way > `unsafe` implementations can be avoided. >=20 > The macro is split into two parts: > - a proc-macro to parse generics into impl and ty generics, > - a declarative macro that expands to the impl block. >=20 > Suggested-by: Asahi Lina > Signed-off-by: Benno Lossin Reviewed-by: Bj=C3=B6rn Roy Baron > --- > rust/kernel/init/macros.rs | 28 ++++++++++++++++++++++++++++ > rust/kernel/prelude.rs | 2 +- > rust/macros/lib.rs | 20 ++++++++++++++++++++ > rust/macros/quote.rs | 6 ++++++ > rust/macros/zeroable.rs | 25 +++++++++++++++++++++++++ > 5 files changed, 80 insertions(+), 1 deletion(-) > create mode 100644 rust/macros/zeroable.rs >=20 > diff --git a/rust/kernel/init/macros.rs b/rust/kernel/init/macros.rs > index fbaebd34f218..e8165ff53a94 100644 > --- a/rust/kernel/init/macros.rs > +++ b/rust/kernel/init/macros.rs > @@ -1213,3 +1213,31 @@ macro_rules! __init_internal { > ); > }; > } > + > +#[doc(hidden)] > +#[macro_export] > +macro_rules! __derive_zeroable { > + (parse_input: > + @sig( > + $(#[$($struct_attr:tt)*])* > + $vis:vis struct $name:ident > + $(where $($whr:tt)*)? > + ), > + @impl_generics($($impl_generics:tt)*), > + @ty_generics($($ty_generics:tt)*), > + @body({ > + $( > + $(#[$($field_attr:tt)*])* > + $field:ident : $field_ty:ty > + ),* $(,)? > + }), > + ) =3D> { > + // SAFETY: every field type implements `Zeroable` and padding by= tes may be zero. > + #[automatically_derived] > + unsafe impl<$($impl_generics)*> $crate::Zeroable for $name<$($ty= _generics)*> > + where > + $($field_ty: $crate::Zeroable,)* > + $($($whr)*)? > + {} > + }; > +} > diff --git a/rust/kernel/prelude.rs b/rust/kernel/prelude.rs > index c28587d68ebc..ae21600970b3 100644 > --- a/rust/kernel/prelude.rs > +++ b/rust/kernel/prelude.rs > @@ -18,7 +18,7 @@ > pub use alloc::{boxed::Box, vec::Vec}; >=20 > #[doc(no_inline)] > -pub use macros::{module, pin_data, pinned_drop, vtable}; > +pub use macros::{module, pin_data, pinned_drop, vtable, Zeroable}; >=20 > pub use super::build_assert; >=20 > diff --git a/rust/macros/lib.rs b/rust/macros/lib.rs > index 3fc74cb4ea19..9f056a5c780a 100644 > --- a/rust/macros/lib.rs > +++ b/rust/macros/lib.rs > @@ -10,6 +10,7 @@ > mod pin_data; > mod pinned_drop; > mod vtable; > +mod zeroable; >=20 > use proc_macro::TokenStream; >=20 > @@ -246,3 +247,22 @@ pub fn pin_data(inner: TokenStream, item: TokenStrea= m) -> TokenStream { > pub fn pinned_drop(args: TokenStream, input: TokenStream) -> TokenStream= { > pinned_drop::pinned_drop(args, input) > } > + > +/// Derives the [`Zeroable`] trait for the given struct. > +/// > +/// This can only be used for structs where every field implements the [= `Zeroable`] trait. > +/// > +/// # Examples > +/// > +/// ```rust > +/// #[derive(Zeroable)] > +/// pub struct DriverData { > +/// id: i64, > +/// buf_ptr: *mut u8, > +/// len: usize, > +/// } > +/// ``` > +#[proc_macro_derive(Zeroable)] > +pub fn derive_zeroable(input: TokenStream) -> TokenStream { > + zeroable::derive(input) > +} > diff --git a/rust/macros/quote.rs b/rust/macros/quote.rs > index dddbb4e6f4cb..b76c198a4ed5 100644 > --- a/rust/macros/quote.rs > +++ b/rust/macros/quote.rs > @@ -124,6 +124,12 @@ macro_rules! quote_spanned { > )); > quote_spanned!(@proc $v $span $($tt)*); > }; > + (@proc $v:ident $span:ident ; $($tt:tt)*) =3D> { > + $v.push(::proc_macro::TokenTree::Punct( > + ::proc_macro::Punct::new(';', ::proc_macro::Spacing::Alo= ne) > + )); > + quote_spanned!(@proc $v $span $($tt)*); > + }; > (@proc $v:ident $span:ident $id:ident $($tt:tt)*) =3D> { > $v.push(::proc_macro::TokenTree::Ident(::proc_macro::Ident::new(= stringify!($id), $span))); > quote_spanned!(@proc $v $span $($tt)*); > diff --git a/rust/macros/zeroable.rs b/rust/macros/zeroable.rs > new file mode 100644 > index 000000000000..cddb866c44ef > --- /dev/null > +++ b/rust/macros/zeroable.rs > @@ -0,0 +1,25 @@ > +// SPDX-License-Identifier: GPL-2.0 > + > +use crate::helpers::{parse_generics, Generics}; > +use proc_macro::TokenStream; > + > +pub(crate) fn derive(input: TokenStream) -> TokenStream { > + let ( > + Generics { > + impl_generics, > + ty_generics, > + }, > + mut rest, > + ) =3D parse_generics(input); > + // This should be the body of the struct `{...}`. > + let last =3D rest.pop(); > + quote! { > + ::kernel::__derive_zeroable!( > + parse_input: > + @sig(#(#rest)*), > + @impl_generics(#(#impl_generics)*), > + @ty_generics(#(#ty_generics)*), > + @body(#last), > + ); > + } > +} > -- > 2.41.0