From: Link Mauve <linkmauve@linkmauve.fr>
To: Mukesh Kumar Chaurasiya <mkchauras@gmail.com>
Cc: Link Mauve <linkmauve@linkmauve.fr>,
maddy@linux.ibm.com, mpe@ellerman.id.au, npiggin@gmail.com,
chleroy@kernel.org, peterz@infradead.org, jpoimboe@kernel.org,
jbaron@akamai.com, aliceryhl@google.com, rostedt@goodmis.org,
ardb@kernel.org, ojeda@kernel.org, boqun@kernel.org,
gary@garyguo.net, bjorn3_gh@protonmail.com, lossin@kernel.org,
a.hindborg@kernel.org, tmgross@umich.edu, dakr@kernel.org,
nathan@kernel.org, nick.desaulniers+lkml@gmail.com,
morbo@google.com, justinstitt@google.com,
linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org,
rust-for-linux@vger.kernel.org, llvm@lists.linux.dev
Subject: Re: [PATCH V11 1/4] rust: Fix "multiple candidates for rmeta dependency core" error
Date: Tue, 21 Apr 2026 12:26:51 +0200 [thread overview]
Message-ID: <aedQ629D0x-5KuKw@luna> (raw)
In-Reply-To: <aedJGuF9P2V1lOCZ@li-1a3e774c-28e4-11b2-a85c-acc9f2883e29.ibm.com>
[-- Attachment #1: Type: text/plain, Size: 4468 bytes --]
On Tue, Apr 21, 2026 at 03:25:22PM +0530, Mukesh Kumar Chaurasiya wrote:
> On Tue, Apr 21, 2026 at 11:38:08AM +0200, Link Mauve wrote:
> > Hi Mukesh,
> >
> > This patch doesn’t apply on top of mainline, which tree did you base it
> > off?
> >
> It was on mainline v7.0 tag.
Great thanks, they do apply there!
I needed three more patches for the kernel to build on PPC32, I’ve
attached them but they are absolutely not patches which could go into
the kernel (except for the second, enabling asm_experimental_arch).
What do you think we should do about them?
> On latest there is a confilict. I'll send out a rebased version.
>
> > On Fri, Apr 17, 2026 at 08:52:50PM +0530, Mukesh Kumar Chaurasiya (IBM) wrote:
> > > When building Rust code for powerpc64le with LLVM=1 and -j1, rustc
> > > encounters an error: "multiple candidates for `rmeta` dependency `core`
> > > found", with two candidates:
> > > 1. The host's standard library from the rustup toolchain
> > > 2. The kernel's custom libcore.rmeta in the rust/ directory
> > >
> > > This occurs because the build system uses `-L$(objtree)/rust` for host
> > > library builds (proc_macro2, quote, syn), which causes rustc to search
> > > the rust/ directory. During this search, rustc finds both the kernel's
> > > custom libcore.rmeta and gains access to the host's standard library,
> > > creating a conflict.
> > >
> > > The solution is to separate host libraries into a dedicated rust/host/
> > > subdirectory and use `-L$(objtree)/rust/host` for host builds instead
> > > of `-L$(objtree)/rust`. This ensures that:
> > >
> > > 1. Host library builds (proc_macro2, quote, syn) only search rust/host/
> > > and never encounter the kernel's libcore.rmeta
> > > 2. Proc macro builds use `-L$(objtree)/rust/host` to find their
> > > dependencies
> > >
> > > Special handling is added for rustdoc-pin_init, which is a host build
> > > (to access the alloc crate) but depends on proc macros from the main
> > > rust/ directory. It uses explicit `--extern` paths to reference the
> > > proc macros without adding `-L$(objtree)/rust`, which would reintroduce
> > > the conflict.
> > >
> > > The rust/host/ directory is added to clean-files to ensure it's removed
> > > during `make clean`.
> > >
> > > Link: https://github.com/Rust-for-Linux/linux/issues/105
> > > Link: https://github.com/linuxppc/issues/issues/451
> > > Signed-off-by: Mukesh Kumar Chaurasiya (IBM) <mkchauras@gmail.com>
> > > ---
> > > rust/Makefile | 38 +++++++++++++++++++++-----------------
> > > 1 file changed, 21 insertions(+), 17 deletions(-)
> > >
> > > diff --git a/rust/Makefile b/rust/Makefile
> > > index 9801af2e1e02..e234b8a39358 100644
> > > --- a/rust/Makefile
> > > +++ b/rust/Makefile
> > > @@ -3,6 +3,9 @@
> > > # Where to place rustdoc generated documentation
> > > rustdoc_output := $(objtree)/Documentation/output/rust/rustdoc
> > >
> > > +# Clean generated host directory
> > > +clean-files := host/
> > > +
> > > obj-$(CONFIG_RUST) += core.o compiler_builtins.o ffi.o
> > > always-$(CONFIG_RUST) += exports_core_generated.h
> > >
> > > @@ -27,7 +30,7 @@ endif
> > >
> > > obj-$(CONFIG_RUST) += exports.o
> > >
> > > -always-$(CONFIG_RUST) += libproc_macro2.rlib libquote.rlib libsyn.rlib
> > > +always-$(CONFIG_RUST) += host/libproc_macro2.rlib host/libquote.rlib host/libsyn.rlib
> > >
> > > always-$(CONFIG_RUST_KERNEL_DOCTESTS) += doctests_kernel_generated.rs
> > > always-$(CONFIG_RUST_KERNEL_DOCTESTS) += doctests_kernel_generated_kunit.c
> > > @@ -150,7 +153,7 @@ quiet_cmd_rustdoc = RUSTDOC $(if $(rustdoc_host),H, ) $<
> > > OBJTREE=$(abspath $(objtree)) \
> > > $(RUSTDOC) $(filter-out $(skip_flags) --remap-path-prefix=% --remap-path-scope=%, \
> > > $(if $(rustdoc_host),$(rust_common_flags),$(rust_flags))) \
> >
> > The issue is here ↑, --remap-path-prefix=% got removed and the two
> > previous lines got merged into one.
> >
> Yeah will fix this.
> > > - $(rustc_target_flags) -L$(objtree)/$(obj) \
> > > + $(rustc_target_flags) -L$(objtree)/$(obj)$(if $(rustdoc_host),/host) \
> > > -Zunstable-options --generate-link-to-definition \
> > > --output $(rustdoc_output) \
> > > --crate-name $(subst rustdoc-,,$@) \
> > […]
> >
> > Thanks anyway for iterating on this series! I’ve started writing a DRM
> > driver based off a previous version. :)
> >
> That's cool. Thanks.
>
> Regards,
> Mukesh
> > --
> > Link Mauve
> >
--
Link Mauve
[-- Attachment #2: 0001-XXX-Workaround-sstep.c.patch --]
[-- Type: text/plain, Size: 1400 bytes --]
From 79b614dd7be16a1108e1f0176a7bc235fa163a4e Mon Sep 17 00:00:00 2001
From: Link Mauve <linkmauve@linkmauve.fr>
Date: Wed, 8 Apr 2026 14:16:04 +0200
Subject: [PATCH 1/3] XXX: Workaround sstep.c
These variables are used only on CONFIG_PPC64, which causes compilation
to fail on PPC32.
---
arch/powerpc/lib/sstep.c | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/arch/powerpc/lib/sstep.c b/arch/powerpc/lib/sstep.c
index ac3ee19531d8..dc129f0cb6a0 100644
--- a/arch/powerpc/lib/sstep.c
+++ b/arch/powerpc/lib/sstep.c
@@ -1354,15 +1354,15 @@ int analyse_instr(struct instruction_op *op, const struct pt_regs *regs,
#ifdef CONFIG_PPC64
unsigned int suffixopcode, prefixtype, prefix_r;
#endif
- unsigned int opcode, ra, rb, rc, rd, spr, u;
+ unsigned int opcode, ra, rb/*, rc*/, rd, spr, u;
unsigned long int imm;
unsigned long int val, val2;
unsigned int mb, me, sh;
- unsigned int word, suffix;
+ unsigned int word/*, suffix*/;
long ival;
word = ppc_inst_val(instr);
- suffix = ppc_inst_suffix(instr);
+ //suffix = ppc_inst_suffix(instr);
op->type = COMPUTE;
@@ -1480,7 +1480,7 @@ int analyse_instr(struct instruction_op *op, const struct pt_regs *regs,
rd = (word >> 21) & 0x1f;
ra = (word >> 16) & 0x1f;
rb = (word >> 11) & 0x1f;
- rc = (word >> 6) & 0x1f;
+ //rc = (word >> 6) & 0x1f;
switch (opcode) {
#ifdef __powerpc64__
--
2.54.0
[-- Attachment #3: 0002-XXX-Enable-asm_experimental_arch-for-PowerPC-asm.patch --]
[-- Type: text/plain, Size: 2350 bytes --]
From d4e72fad43175bde99287b8efdece900e5b53444 Mon Sep 17 00:00:00 2001
From: Link Mauve <linkmauve@linkmauve.fr>
Date: Fri, 10 Apr 2026 13:05:24 +0200
Subject: [PATCH 2/3] XXX: Enable asm_experimental_arch for PowerPC asm!()
This is needed to compile the kernel crate, otherwise this error
happens:
error[E0658]: inline assembly is not stable yet on this architecture
--> ../rust/kernel/sync/barrier.rs:19:14
|
19 | unsafe { core::arch::asm!("") };
| ^^^^^^^^^^^^^^^^^^^^
|
= note: see issue #93335 <https://github.com/rust-lang/rust/issues/93335> for more information
= help: add `#![feature(asm_experimental_arch)]` to the crate attributes to enable
= note: this compiler was built on 2026-03-25; consider upgrading it if it is out of date
error: aborting due to 1 previous error
For more information about this error, try `rustc --explain E0658`.
---
rust/kernel/lib.rs | 3 +++
scripts/Makefile.build | 2 +-
2 files changed, 4 insertions(+), 1 deletion(-)
diff --git a/rust/kernel/lib.rs b/rust/kernel/lib.rs
index d93292d47420..92ccd47dc3ee 100644
--- a/rust/kernel/lib.rs
+++ b/rust/kernel/lib.rs
@@ -47,6 +47,9 @@
// To be determined.
#![feature(used_with_arg)]
//
+// Needed for PowerPC inline assembly.
+#![feature(asm_experimental_arch)]
+//
// `feature(derive_coerce_pointee)` is expected to become stable. Before Rust
// 1.84.0, it did not exist, so enable the predecessor features.
#![cfg_attr(CONFIG_RUSTC_HAS_COERCE_POINTEE, feature(derive_coerce_pointee))]
diff --git a/scripts/Makefile.build b/scripts/Makefile.build
index 3652b85be545..c7cc21994c5a 100644
--- a/scripts/Makefile.build
+++ b/scripts/Makefile.build
@@ -321,7 +321,7 @@ $(obj)/%.lst: $(obj)/%.c FORCE
#
# Please see https://github.com/Rust-for-Linux/linux/issues/2 for details on
# the unstable features in use.
-rust_allowed_features := asm_const,asm_goto,arbitrary_self_types,lint_reasons,offset_of_nested,raw_ref_op,slice_ptr_len,strict_provenance,used_with_arg
+rust_allowed_features := asm_const,asm_goto,asm_experimental_arch,arbitrary_self_types,lint_reasons,offset_of_nested,raw_ref_op,slice_ptr_len,strict_provenance,used_with_arg
# `--out-dir` is required to avoid temporaries being created by `rustc` in the
# current working directory, which may be not accessible in the out-of-tree
--
2.54.0
[-- Attachment #4: 0003-XXX-Workaround-for-__udivdi3-and-__umoddi3.patch --]
[-- Type: text/plain, Size: 1336 bytes --]
From 2c0a3ec3da6fa1f0151225c05159f7a812317d32 Mon Sep 17 00:00:00 2001
From: Link Mauve <linkmauve@linkmauve.fr>
Date: Fri, 10 Apr 2026 13:51:24 +0200
Subject: [PATCH 3/3] XXX: Workaround for __udivdi3() and __umoddi3()
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
The core crate currently depends on these two functions for i64/u64/
i128/u128/core::time::Duration formatting, but we shouldn’t use that in
the kernel so let’s panic if they are ever called.
---
rust/exports.c | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/rust/exports.c b/rust/exports.c
index 587f0e776aba..5f1cdf13882e 100644
--- a/rust/exports.c
+++ b/rust/exports.c
@@ -12,6 +12,7 @@
*/
#include <linux/export.h>
+#include <linux/panic.h>
#define EXPORT_SYMBOL_RUST_GPL(sym) extern int sym; EXPORT_SYMBOL_GPL(sym)
@@ -20,6 +21,14 @@
#include "exports_bindings_generated.h"
#include "exports_kernel_generated.h"
+void __udivdi3(void) {
+ panic("__udivdi3() called but shouldn’t be made available on this architecture!\n");
+}
+
+void __umoddi3(void) {
+ panic("__umoddi3() called but shouldn’t be made available on this architecture!\n");
+}
+
// For modules using `rust/build_error.rs`.
#ifdef CONFIG_RUST_BUILD_ASSERT_ALLOW
EXPORT_SYMBOL_RUST_GPL(rust_build_error);
--
2.54.0
next prev parent reply other threads:[~2026-04-21 10:26 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-04-17 15:22 [PATCH V11 0/4] Rust support for powerpc Mukesh Kumar Chaurasiya (IBM)
2026-04-17 15:22 ` [PATCH V11 1/4] rust: Fix "multiple candidates for rmeta dependency core" error Mukesh Kumar Chaurasiya (IBM)
2026-04-21 9:38 ` Link Mauve
2026-04-21 9:55 ` Mukesh Kumar Chaurasiya
2026-04-21 10:26 ` Link Mauve [this message]
2026-04-21 12:19 ` Mukesh Kumar Chaurasiya
2026-04-21 12:26 ` Link Mauve
2026-04-21 15:53 ` Mukesh Kumar Chaurasiya
2026-04-21 15:57 ` Gary Guo
2026-04-21 17:47 ` Mukesh Kumar Chaurasiya
2026-04-21 18:10 ` Gary Guo
2026-04-21 18:16 ` Miguel Ojeda
2026-04-21 16:00 ` Miguel Ojeda
2026-04-21 17:28 ` Mukesh Kumar Chaurasiya
2026-04-21 15:59 ` Gary Guo
2026-04-21 16:36 ` Link Mauve
2026-04-21 16:51 ` Gary Guo
2026-04-21 17:10 ` Link Mauve
2026-04-21 17:17 ` Link Mauve
2026-04-17 15:22 ` [PATCH V11 2/4] powerpc/jump_label: adjust inline asm to be consistent Mukesh Kumar Chaurasiya (IBM)
2026-04-17 15:22 ` [PATCH V11 3/4] rust: Add PowerPC support Mukesh Kumar Chaurasiya (IBM)
2026-04-21 15:59 ` Gary Guo
2026-04-17 15:22 ` [PATCH V11 4/4] powerpc: Enable Rust for ppc64le Mukesh Kumar Chaurasiya (IBM)
2026-04-21 15:59 ` Gary Guo
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=aedQ629D0x-5KuKw@luna \
--to=linkmauve@linkmauve.fr \
--cc=a.hindborg@kernel.org \
--cc=aliceryhl@google.com \
--cc=ardb@kernel.org \
--cc=bjorn3_gh@protonmail.com \
--cc=boqun@kernel.org \
--cc=chleroy@kernel.org \
--cc=dakr@kernel.org \
--cc=gary@garyguo.net \
--cc=jbaron@akamai.com \
--cc=jpoimboe@kernel.org \
--cc=justinstitt@google.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linuxppc-dev@lists.ozlabs.org \
--cc=llvm@lists.linux.dev \
--cc=lossin@kernel.org \
--cc=maddy@linux.ibm.com \
--cc=mkchauras@gmail.com \
--cc=morbo@google.com \
--cc=mpe@ellerman.id.au \
--cc=nathan@kernel.org \
--cc=nick.desaulniers+lkml@gmail.com \
--cc=npiggin@gmail.com \
--cc=ojeda@kernel.org \
--cc=peterz@infradead.org \
--cc=rostedt@goodmis.org \
--cc=rust-for-linux@vger.kernel.org \
--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