From: Miguel Ojeda <ojeda@kernel.org>
To: Nathan Chancellor <nathan@kernel.org>,
Nicolas Schier <nsc@kernel.org>,
Nick Desaulniers <nick.desaulniers+lkml@gmail.com>,
Bill Wendling <morbo@google.com>,
Justin Stitt <justinstitt@google.com>,
David Gow <david@davidgow.net>,
Russell King <linux@armlinux.org.uk>,
Richard Weinberger <richard@nod.at>,
Anton Ivanov <anton.ivanov@cambridgegreys.com>,
Johannes Berg <johannes@sipsolutions.net>,
aliceryhl@google.com
Cc: linux-um@lists.infradead.org, llvm@lists.linux.dev,
linux-arm-kernel@lists.infradead.org,
linux-kbuild@vger.kernel.org, a.hindborg@kernel.org,
acourbot@nvidia.com, akpm@linux-foundation.org,
bjorn3_gh@protonmail.com, boqun.feng@gmail.com, dakr@kernel.org,
gary@garyguo.net, linux-kernel@vger.kernel.org,
linux-mm@kvack.org, lossin@kernel.org, mark.rutland@arm.com,
mmaurer@google.com, nicolas.schier@linux.dev, ojeda@kernel.org,
peterz@infradead.org, rust-for-linux@vger.kernel.org,
tmgross@umich.edu, urezki@gmail.com, will@kernel.org
Subject: Re: [PATCH v2 0/3] Inline helpers into Rust without full LTO
Date: Sun, 22 Mar 2026 20:21:59 +0100 [thread overview]
Message-ID: <20260322192159.88138-1-ojeda@kernel.org> (raw)
In-Reply-To: <20260203-inline-helpers-v2-0-beb8547a03c9@google.com>
On Tue, 03 Feb 2026 11:34:07 +0000 Alice Ryhl <aliceryhl@google.com> wrote:
>
> To get rid of these helper symbols, provide functionality to inline
> helpers into Rust using llvm-link. This option complements full LTO, by
> being much cheaper and avoiding incompatibility with BTF.
I have been testing this. I think we can go ahead with it, with a few
notes.
I will reply to a couple other bindings in separate emails to avoid
spamming people too much.
- I will mark the Kconfig option as "(EXPERIMENTAL)", since that is
what the commit message says and it allows us to be a bit
conservative.
- Clang passes `-Werror=unused-command-line-argument`, which means
under arm (i.e. 32-bit) we get:
clang: error: argument unused during compilation: '-U arm' [-Werror,-Wunused-command-line-argument]
And under UML I see:
clang: error: argument unused during compilation: '-I ./arch/um/include/shared' [-Werror,-Wunused-command-line-argument]
clang: error: argument unused during compilation: '-I ./arch/x86/um/shared' [-Werror,-Wunused-command-line-argument]
clang: error: argument unused during compilation: '-I ./arch/um/include/shared/skas' [-Werror,-Wunused-command-line-argument]
So we would need e.g. `-Wno-unused-command-line-argument` there
close to the `-Wno-override-module` one, unless Kbuild or
ClangBuiltLinux thinks it is important to keep it for this case.
On the other hand, regardless of whether we fix this (and another
issue in a separate email found thanks to the UML build), we could
instead add `depends on` listing explicitly the architectures where
this is going to be actually tested. That way maintainers can decide
whether they want to support it when they are ready. Thoughts?
Cc'ing Nathan, Nicolas, Nick, Bill, Justin, David, UML, ARM.
- If we use the `.bc` extension, we need to add a `.gitignore` for
`.bc` files, and an exception for `kernel/time/timeconst.bc`.
I guess we will not have too many `bc` scripts in the future for
that to be a problem. On the other hand, we have the chance to use
another extension (either for LLVM bitcode or for `bc` scripts).
But please let me know on e.g. the Kbuild side if someone has
concerns...
- Do we want to have the `cmd_ld_single` step even if the new mode is
not enabled? i.e. we are gating the other steps, so we could gate
that one too easily, no?
- $(cmd_ld_single) \
+ $(if $(link_helper),$(cmd_ld_single)) \
- $(cmd_ld_single) \
+ $(if $(CONFIG_RUST_INLINE_HELPERS),$(cmd_ld_single)) \
I mean, it only affects `CONFIG_LTO_CLANG` configs, which are on
their own experimental as far as I can see, so it is probably fine
as it is, but still, while making things unconditional on the caller
is good, it is also a behaviour change for configs outside the thing
introduced here, so I am asking.
(We could use something like a `is-rust-object` to do it on the
definition side, but I would leave that for later.)
Thanks!
Cheers,
Miguel
next prev parent reply other threads:[~2026-03-22 19:22 UTC|newest]
Thread overview: 50+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-02-03 11:34 [PATCH v2 0/3] Inline helpers into Rust without full LTO Alice Ryhl
2026-02-03 11:34 ` [PATCH v2 1/3] kbuild: rust: add `CONFIG_RUSTC_CLANG_LLVM_COMPATIBLE` Alice Ryhl
2026-02-03 11:49 ` Will Deacon
2026-02-03 12:02 ` Alice Ryhl
2026-03-05 10:12 ` Nicolas Schier
2026-03-05 10:51 ` Alice Ryhl
2026-03-14 0:26 ` Nathan Chancellor
2026-02-03 11:34 ` [PATCH v2 2/3] rust: helpers: #define __rust_helper Alice Ryhl
2026-03-14 0:28 ` Nathan Chancellor
2026-02-03 11:34 ` [PATCH v2 3/3] build: rust: provide an option to inline C helpers into Rust Alice Ryhl
2026-03-06 17:32 ` Alice Ryhl
2026-03-14 0:40 ` Nathan Chancellor
2026-03-14 11:22 ` Alice Ryhl
2026-03-16 21:34 ` Nathan Chancellor
2026-03-17 8:02 ` Miguel Ojeda
2026-03-14 0:34 ` Nathan Chancellor
2026-03-17 8:25 ` [PATCH v2 0/3] Inline helpers into Rust without full LTO Andreas Hindborg
2026-03-22 19:21 ` Miguel Ojeda [this message]
2026-03-22 19:38 ` Miguel Ojeda
2026-03-23 13:54 ` Mark Brown
2026-03-23 14:53 ` Miguel Ojeda
2026-03-22 19:46 ` Miguel Ojeda
2026-03-23 8:49 ` Marek Szyprowski
2026-03-25 1:58 ` Miguel Ojeda
2026-03-26 21:12 ` Arnd Bergmann
2026-03-27 8:02 ` Miguel Ojeda
2026-03-27 8:16 ` Marek Szyprowski
2026-03-23 0:03 ` Miguel Ojeda
2026-03-23 3:04 ` Andrew Lunn
2026-03-23 3:24 ` Miguel Ojeda
2026-03-23 12:54 ` Andrew Lunn
2026-03-23 13:13 ` Gary Guo
2026-03-23 13:28 ` Andrew Lunn
2026-03-23 13:34 ` Miguel Ojeda
2026-03-23 14:39 ` Alice Ryhl
2026-03-23 13:14 ` Miguel Ojeda
2026-03-23 10:03 ` Russell King (Oracle)
2026-03-23 13:26 ` Miguel Ojeda
2026-03-26 10:10 ` Alice Ryhl
2026-03-26 13:47 ` Miguel Ojeda
2026-03-26 14:31 ` Christian Schrefl
2026-03-26 15:18 ` Russell King (Oracle)
2026-03-26 17:30 ` Miguel Ojeda
2026-03-26 21:33 ` Arnd Bergmann
2026-03-27 7:56 ` Geert Uytterhoeven
2026-03-27 9:02 ` Arnd Bergmann
2026-03-26 17:31 ` Miguel Ojeda
2026-03-26 2:42 ` Nathan Chancellor
2026-03-26 17:13 ` Miguel Ojeda
2026-03-26 5:34 ` David Gow
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=20260322192159.88138-1-ojeda@kernel.org \
--to=ojeda@kernel.org \
--cc=a.hindborg@kernel.org \
--cc=acourbot@nvidia.com \
--cc=akpm@linux-foundation.org \
--cc=aliceryhl@google.com \
--cc=anton.ivanov@cambridgegreys.com \
--cc=bjorn3_gh@protonmail.com \
--cc=boqun.feng@gmail.com \
--cc=dakr@kernel.org \
--cc=david@davidgow.net \
--cc=gary@garyguo.net \
--cc=johannes@sipsolutions.net \
--cc=justinstitt@google.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kbuild@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=linux-um@lists.infradead.org \
--cc=linux@armlinux.org.uk \
--cc=llvm@lists.linux.dev \
--cc=lossin@kernel.org \
--cc=mark.rutland@arm.com \
--cc=mmaurer@google.com \
--cc=morbo@google.com \
--cc=nathan@kernel.org \
--cc=nick.desaulniers+lkml@gmail.com \
--cc=nicolas.schier@linux.dev \
--cc=nsc@kernel.org \
--cc=peterz@infradead.org \
--cc=richard@nod.at \
--cc=rust-for-linux@vger.kernel.org \
--cc=tmgross@umich.edu \
--cc=urezki@gmail.com \
--cc=will@kernel.org \
/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