From: Danilo Krummrich <dakr@kernel.org>
To: Alice Ryhl <aliceryhl@google.com>
Cc: Greg KH <gregkh@linuxfoundation.org>,
rafael@kernel.org, bhelgaas@google.com, ojeda@kernel.org,
alex.gaynor@gmail.com, boqun.feng@gmail.com, gary@garyguo.net,
bjorn3_gh@protonmail.com, benno.lossin@proton.me,
tmgross@umich.edu, a.hindborg@samsung.com, airlied@gmail.com,
fujita.tomonori@gmail.com, lina@asahilina.net,
pstanner@redhat.com, ajanulgu@redhat.com, lyude@redhat.com,
robh@kernel.org, daniel.almeida@collabora.com,
saravanak@google.com, dirk.behme@de.bosch.com, j@jannau.net,
fabien.parent@linaro.org, chrisi.schrefl@gmail.com,
rust-for-linux@vger.kernel.org, linux-kernel@vger.kernel.org,
linux-pci@vger.kernel.org, devicetree@vger.kernel.org
Subject: Re: [PATCH v5 01/16] rust: pass module name to `Module::init`
Date: Wed, 11 Dec 2024 15:52:06 +0100 [thread overview]
Message-ID: <Z1mnFoap_AnPPNfu@cassiopeiae> (raw)
In-Reply-To: <CAH5fLgjg82x5EiWa1BTC7DpbhteBm5Or8XtpLAL0hQz+huXMCw@mail.gmail.com>
On Wed, Dec 11, 2024 at 03:45:53PM +0100, Alice Ryhl wrote:
> On Wed, Dec 11, 2024 at 3:29 PM Danilo Krummrich <dakr@kernel.org> wrote:
> >
> > On Wed, Dec 11, 2024 at 02:34:54PM +0100, Alice Ryhl wrote:
> > > On Wed, Dec 11, 2024 at 2:31 PM Danilo Krummrich <dakr@kernel.org> wrote:
> > > >
> > > > On Wed, Dec 11, 2024 at 02:14:37PM +0100, Greg KH wrote:
> > > > > On Wed, Dec 11, 2024 at 01:34:31PM +0100, Danilo Krummrich wrote:
> > > > > > On Wed, Dec 11, 2024 at 01:22:33PM +0100, Danilo Krummrich wrote:
> > > > > > > On Wed, Dec 11, 2024 at 12:05:10PM +0100, Greg KH wrote:
> > > > > > > > On Wed, Dec 11, 2024 at 11:59:54AM +0100, Greg KH wrote:
> > > > > > > > > On Wed, Dec 11, 2024 at 11:48:23AM +0100, Greg KH wrote:
> > > > > > > > > > On Wed, Dec 11, 2024 at 11:45:20AM +0100, Greg KH wrote:
> > > > > > > > > > > On Tue, Dec 10, 2024 at 11:46:28PM +0100, Danilo Krummrich wrote:
> > > > > > > > > > > > In a subsequent patch we introduce the `Registration` abstraction used
> > > > > > > > > > > > to register driver structures. Some subsystems require the module name on
> > > > > > > > > > > > driver registration (e.g. PCI in __pci_register_driver()), hence pass
> > > > > > > > > > > > the module name to `Module::init`.
> > > > > > > > > > >
> > > > > > > > > > > Nit, we don't need the NAME of the PCI driver (well, we do like it, but
> > > > > > > > > > > that's not the real thing), we want the pointer to the module structure
> > > > > > > > > > > in the register_driver call.
> > > > > > > > > > >
> > > > > > > > > > > Does this provide for that? I'm thinking it does, but it's not the
> > > > > > > > > > > "name" that is the issue here.
> > > > > > > > > >
> > > > > > > > > > Wait, no, you really do want the name, don't you. You refer to
> > > > > > > > > > "module.0" to get the module structure pointer (if I'm reading the code
> > > > > > > > > > right), but as you have that pointer already, why can't you just use
> > > > > > > > > > module->name there as well as you have a pointer to a valid module
> > > > > > > > > > structure that has the name already embedded in it.
> > > > > > > > >
> > > > > > > > > In digging further, it's used by the pci code to call into lower layers,
> > > > > > > > > but why it's using a different string other than the module name string
> > > > > > > > > is beyond me. Looks like this goes way back before git was around, and
> > > > > > > > > odds are it's my fault for something I wrote a long time ago.
> > > > > > > > >
> > > > > > > > > I'll see if I can just change the driver core to not need a name at all,
> > > > > > > > > and pull it from the module which would make all of this go away in the
> > > > > > > > > end. Odds are something will break but who knows...
> > > > > > > >
> > > > > > > > Nope, things break, the "name" is there to handle built-in modules (as
> > > > > > > > the module pointer will be NULL.)
> > > > > > > >
> > > > > > > > So what you really want is not the module->name (as I don't think that
> > > > > > > > will be set), but you want KBUILD_MODNAME which the build system sets.
> > > > > > >
> > > > > > > That's correct, and the reason why I pass through this name argument.
> > > > > > >
> > > > > > > Sorry I wasn't able to reply earlier to save you some time.
> > > > > > >
> > > > > > > > You shouldn't need to pass the name through all of the subsystems here,
> > > > > > > > just rely on the build system instead.
> > > > > > > >
> > > > > > > > Or does the Rust side not have KBUILD_MODNAME?
> > > > > > >
> > > > > > > AFAIK, it doesn't (or didn't have at the time I wrote the patch).
> > > > > > >
> > > > > > > @Miguel: Can we access KBUILD_MODNAME conveniently?
> > > > > >
> > > > > > Actually, I now remember there was another reason why I pass it through in
> > > > > > `Module::init`.
> > > > > >
> > > > > > Even if we had env!(KBUILD_MODNAME) already, I'd want to use it from the bus
> > > > > > abstraction code, e.g. rust/kernel/pci.rs. But since this is generic code, it
> > > > > > won't get the KBUILD_MODNAME from the module that is using the bus abstraction.
> > > > >
> > > > > Rust can't do that in a macro somehow that all pci rust drivers can pull
> > > > > from?
> > > >
> > > > The problem is that register / unregister is encapsulated within methods of the
> > > > abstraction types. So the C macro trick (while generally possible) isn't
> > > > applicable.
> > > >
> > > > I think we could avoid having an additional `name` parameter in `Module::init`,
> > > > but it would still need to be the driver resolving `env!(KBUILD_MODNAME)`
> > > > passing it into the bus abstraction.
> > > >
> > > > However, similar to what Alice suggested in another thread, we could include
> > > > this step in the `module_*_driver!` macros.
> > > >
> > > > Modules that don't use this convenience macro would need to do it by hand
> > > > though. But that's probably not that big a deal.
> > >
> > > I think we can do it in the core `module!` macro that everyone has to use.
> >
> > How? The `module!` macro does not know about the registration instances within
> > the module structure.
>
> You could have the module! macro emit something along these lines:
>
> impl ModuleName for {type_} {
> const NAME: &'static CStr = c_str!(env!("KBUILD_MODNAME"));
> }
>
> Then you can do `<Self as ModuleName>::NAME` to obtain the name elsewhere.
Where {type_} would need to be the driver's `Driver` structure?
We'd then need to define the bus adapter as:
`pub struct Adapter<T: Driver + ModuleName>(T)`
But the question stands I guess, how would the module macro know {type_}?
>
> Alice
next prev parent reply other threads:[~2024-12-11 14:52 UTC|newest]
Thread overview: 46+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-12-10 22:46 [PATCH v5 00/16] Device / Driver PCI / Platform Rust abstractions Danilo Krummrich
2024-12-10 22:46 ` [PATCH v5 01/16] rust: pass module name to `Module::init` Danilo Krummrich
2024-12-11 10:45 ` Greg KH
2024-12-11 10:48 ` Greg KH
2024-12-11 10:59 ` Greg KH
2024-12-11 11:05 ` Greg KH
2024-12-11 11:41 ` Miguel Ojeda
2024-12-11 12:43 ` Alice Ryhl
2024-12-11 12:22 ` Danilo Krummrich
2024-12-11 12:34 ` Danilo Krummrich
2024-12-11 13:14 ` Greg KH
2024-12-11 13:31 ` Danilo Krummrich
2024-12-11 13:34 ` Alice Ryhl
2024-12-11 14:29 ` Danilo Krummrich
2024-12-11 14:45 ` Alice Ryhl
2024-12-11 14:52 ` Danilo Krummrich [this message]
2024-12-11 14:55 ` Alice Ryhl
2024-12-11 15:03 ` Danilo Krummrich
2024-12-11 15:15 ` Alice Ryhl
2024-12-11 15:36 ` Danilo Krummrich
2024-12-11 15:53 ` Danilo Krummrich
2024-12-11 13:45 ` Greg KH
2024-12-11 14:21 ` Danilo Krummrich
2024-12-11 14:30 ` Greg KH
2024-12-10 22:46 ` [PATCH v5 02/16] rust: implement generic driver registration Danilo Krummrich
2024-12-10 22:46 ` [PATCH v5 03/16] rust: implement `IdArray`, `IdTable` and `RawDeviceId` Danilo Krummrich
2024-12-10 22:46 ` [PATCH v5 04/16] rust: add rcu abstraction Danilo Krummrich
2024-12-11 18:47 ` Boqun Feng
2024-12-10 22:46 ` [PATCH v5 05/16] rust: types: add `Opaque::pin_init` Danilo Krummrich
2024-12-11 9:18 ` Alice Ryhl
2024-12-10 22:46 ` [PATCH v5 06/16] rust: add `Revocable` type Danilo Krummrich
2024-12-11 10:47 ` Benoît du Garreau
2024-12-11 10:57 ` Alice Ryhl
2024-12-10 22:46 ` [PATCH v5 07/16] rust: add `io::{Io, IoRaw}` base types Danilo Krummrich
2024-12-10 22:46 ` [PATCH v5 08/16] rust: add devres abstraction Danilo Krummrich
2024-12-10 22:46 ` [PATCH v5 09/16] rust: pci: add basic PCI device / driver abstractions Danilo Krummrich
2024-12-10 22:46 ` [PATCH v5 10/16] rust: pci: implement I/O mappable `pci::Bar` Danilo Krummrich
2024-12-10 22:46 ` [PATCH v5 11/16] samples: rust: add Rust PCI sample driver Danilo Krummrich
2024-12-10 22:46 ` [PATCH v5 12/16] rust: of: add `of::DeviceId` abstraction Danilo Krummrich
2024-12-10 22:46 ` [PATCH v5 13/16] rust: driver: implement `Adapter` Danilo Krummrich
2024-12-12 2:10 ` Fabien Parent
2024-12-10 22:46 ` [PATCH v5 14/16] rust: platform: add basic platform device / driver abstractions Danilo Krummrich
2024-12-11 15:27 ` Rob Herring
2024-12-10 22:46 ` [PATCH v5 15/16] samples: rust: add Rust platform sample driver Danilo Krummrich
2024-12-11 15:29 ` Rob Herring
2024-12-10 22:46 ` [PATCH v5 16/16] MAINTAINERS: add Danilo to DRIVER CORE Danilo Krummrich
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=Z1mnFoap_AnPPNfu@cassiopeiae \
--to=dakr@kernel.org \
--cc=a.hindborg@samsung.com \
--cc=airlied@gmail.com \
--cc=ajanulgu@redhat.com \
--cc=alex.gaynor@gmail.com \
--cc=aliceryhl@google.com \
--cc=benno.lossin@proton.me \
--cc=bhelgaas@google.com \
--cc=bjorn3_gh@protonmail.com \
--cc=boqun.feng@gmail.com \
--cc=chrisi.schrefl@gmail.com \
--cc=daniel.almeida@collabora.com \
--cc=devicetree@vger.kernel.org \
--cc=dirk.behme@de.bosch.com \
--cc=fabien.parent@linaro.org \
--cc=fujita.tomonori@gmail.com \
--cc=gary@garyguo.net \
--cc=gregkh@linuxfoundation.org \
--cc=j@jannau.net \
--cc=lina@asahilina.net \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pci@vger.kernel.org \
--cc=lyude@redhat.com \
--cc=ojeda@kernel.org \
--cc=pstanner@redhat.com \
--cc=rafael@kernel.org \
--cc=robh@kernel.org \
--cc=rust-for-linux@vger.kernel.org \
--cc=saravanak@google.com \
--cc=tmgross@umich.edu \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).