From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from lists.ozlabs.org (lists.ozlabs.org [112.213.38.117]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 304B2ECD994 for ; Thu, 5 Feb 2026 18:05:07 +0000 (UTC) Received: from boromir.ozlabs.org (localhost [127.0.0.1]) by lists.ozlabs.org (Postfix) with ESMTP id 4f6Q9Y378wz30T8; Fri, 06 Feb 2026 05:05:05 +1100 (AEDT) Authentication-Results: lists.ozlabs.org; arc=none smtp.remote-ip="2607:f8b0:4864:20::432" ARC-Seal: i=1; a=rsa-sha256; d=lists.ozlabs.org; s=201707; t=1770314705; cv=none; b=M4BQfDzb3sfygxnHWYLUcpNq9a6Bkfdup3cBvZIOx8NV66R95g+vruvQRq+JwTWoEzXxRhgB0XxJojRfnQz4ja9wfhb7TbY1+Inp1HNkPw5dssjV38dhoqKaxkAQFSRgAb5cfXFCj2I2GW5SbYV44g/9EIAuJUlgkMprJH/udblOQHt7EY0G3hJt9LMgs7isnsMp1n6oGlhLF9FQuEherIloCy7p3eTPTfp4nQRLX4uuh5JC7lvw8B9+aDlOIO+4anmw6+CG+I4VElL09ahkNacbDU/Kh9aoapAazj6hKTPrjSrundOYBEBq5+JpvvVwF22zhTgxK3QYQRYX3PUjvA== ARC-Message-Signature: i=1; a=rsa-sha256; d=lists.ozlabs.org; s=201707; t=1770314705; c=relaxed/relaxed; bh=5JEXFfn5owLVtRFRZ2oa7tX5z5wOjOt9hQA1ZlR21y4=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=eg8BcwYWS4nlu9ZSwwmzsxIltjkbC+dUkS1GsHNVFbdqTXDqHjbg4DY0MIW2A0QjoBBBS6s9aedclXzYgl+WH3XygOlDj+N3+8GLGoFv6rupx9NSJWSNFZZ3MPgLt0cffKSwLYju3toDVAIgM7M9lMkE3zlf7VfpPk3ChZx99qF16VvnCOt3e60LkfkF+W5XSzHgakl094uq7ZZkWdNeIC/cuFZe9ClWDCVjk7le+AIkiW6FwUcG1s9+EsQYc3G1glf8s4FgcMSmjl/3nC0g2sE4uXYPTuFiaIxavHYqvi0LwsRihtISX+q74QFZvH9q5+XtbMWEAxs8Y84eBCr73A== ARC-Authentication-Results: i=1; lists.ozlabs.org; dmarc=pass (p=none dis=none) header.from=gmail.com; dkim=pass (2048-bit key; unprotected) header.d=gmail.com header.i=@gmail.com header.a=rsa-sha256 header.s=20230601 header.b=nk/x3kPZ; dkim-atps=neutral; spf=pass (client-ip=2607:f8b0:4864:20::432; helo=mail-pf1-x432.google.com; envelope-from=mkchauras@gmail.com; receiver=lists.ozlabs.org) smtp.mailfrom=gmail.com Authentication-Results: lists.ozlabs.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: lists.ozlabs.org; dkim=pass (2048-bit key; unprotected) header.d=gmail.com header.i=@gmail.com header.a=rsa-sha256 header.s=20230601 header.b=nk/x3kPZ; dkim-atps=neutral Authentication-Results: lists.ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=gmail.com (client-ip=2607:f8b0:4864:20::432; helo=mail-pf1-x432.google.com; envelope-from=mkchauras@gmail.com; receiver=lists.ozlabs.org) Received: from mail-pf1-x432.google.com (mail-pf1-x432.google.com [IPv6:2607:f8b0:4864:20::432]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange x25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by lists.ozlabs.org (Postfix) with ESMTPS id 4f6Q9X2yYhz2xQC for ; Fri, 06 Feb 2026 05:05:04 +1100 (AEDT) Received: by mail-pf1-x432.google.com with SMTP id d2e1a72fcca58-81ecbdfdcebso784827b3a.1 for ; Thu, 05 Feb 2026 10:05:04 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1770314702; x=1770919502; darn=lists.ozlabs.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=5JEXFfn5owLVtRFRZ2oa7tX5z5wOjOt9hQA1ZlR21y4=; b=nk/x3kPZYrB1gotYVioNt578x8fNloxeVEVJkIdNTBC4dPpgct8RzTEDkNrmzLMy6T UtnVFr2v9V4Yx9baq0bNiPLJtqsIMc5I4OvO7aBeFKKAUNQBgWAvDnhd6FhlZBqIJg3K M/Z/9zsD41ktHXIpTNgqgSN4F6H3/leNeyWmh2NktZJLOgKFyjS2RiQcds5Ulg00fBKB QpggiGy6umrfCo/d+TTl89HgduZsWDBz4ZE6/Xa+5C+jrr2EAkAG+8irg08UdmLzf+rj a5xPub2aML6ZPpa/syubojmFIFWvQvSVEd31Iz01wfuxvsVwAjhh1gRNv28kbqLy5eeV GAZg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1770314702; x=1770919502; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=5JEXFfn5owLVtRFRZ2oa7tX5z5wOjOt9hQA1ZlR21y4=; b=Bxc822qedoLCCS3dPgpbAaLeQ4MmANwA3LeD0BVkoobrpinpNiTNUpZYT/YiUokWVG Cm5uvNOz4Ia0u1O1tV9rpmXKHsF1twNS6KIDa5ipm8TPmCJOWHkX0Bc1gi+5/pclo3r5 EIHHGOpuCQraho8jpNPjgi8XS7NbXdrej3Q6OVSgejYTZW00ZnNwFY5RRMTLfqohUAC8 DytcqTuFicmAuX3llu1VC61w9lpUmv0AODjg+B1lcQJ4VN1nlY+qq3EBiI9kks8BBVCD 7exuvv1GyrcUlgxo//EOR+Hn1G27PhyijDaRF6F+1gqrtBmhW+VlCPbGm+PFSQSSznPF qD3A== X-Forwarded-Encrypted: i=1; AJvYcCUB/YPMYZz+VnFqptz4f5hLjrsa6fxUhgOlFVyxPoilTS0+tzk4JgKsJM1Touh/9R1MdiNxDgzDSnjx+j0=@lists.ozlabs.org X-Gm-Message-State: AOJu0YyHzmMyyAZtIA92yg6kxman2JGFqOtvcYq+WAV6jf+ySaGJx8RM H0qYwRtfn0iOo07f2kVUkJVfywnb8jRaZEY6eEJYGkUavvxrU6sMB32V X-Gm-Gg: AZuq6aLUXPGGklIUeCqDHYZpGz5olx2x6dPjUC+tkONtfFxLjee2skE3A8sL5frNlHs df7dPXM9KJNgvaBEwNvatuaNwgXgmQTbI2wbzpeUbj8S+oMq4dH41jC+w4p6Lt1TkuAKcKAu38r TVfF6IongiCmb3wYGMTJ9pueRfmv/CrMVVqjqTmNbn8ajOeW4rMotvJZQT4A20rbGoljou5udSu 2tiDk6oDg/m6zddxGOUEDUCFzErh1YPklaJiu4EfYKT3eeppNhyJxKTN7w97d+AlWN66+O1Cpfv etr/nw8PmbnHffbosagBegZclLjNgkP7e+jGcKGtoHK0IHUjtgXPv+S6jrVLPwCHCCsTBt9OpU9 KO2Twh5uAj1+bqa9x2B6XIWn0jZWzxbEHqmlDvg/+bUr7fMHnd32CGighQNsEQS/kt9JSiZPaCt Fg2eYD8spz8rRghdA3OkUYqhpYlhZo3MzyoIZ4q+vMZdVceH3C6zmQkn+beqa+tSDP4AziwrEp X-Received: by 2002:a05:6a21:a89:b0:392:e5eb:f0f with SMTP id adf61e73a8af0-393ad3b6c44mr176743637.68.1770314701789; Thu, 05 Feb 2026 10:05:01 -0800 (PST) Received: from li-1a3e774c-28e4-11b2-a85c-acc9f2883e29.ibm.com.com ([106.51.167.8]) by smtp.gmail.com with ESMTPSA id 41be03b00d2f7-c6dcb5436c5sm99812a12.15.2026.02.05.10.04.54 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 05 Feb 2026 10:05:01 -0800 (PST) From: "Mukesh Kumar Chaurasiya (IBM)" To: linkmauve@linkmauve.fr, ojeda@kernel.org, boqun.feng@gmail.com, gary@garyguo.net, bjorn3_gh@protonmail.com, lossin@kernel.org, a.hindborg@kernel.org, aliceryhl@google.com, tmgross@umich.edu, dakr@kernel.org, corbet@lwn.net, maddy@linux.ibm.com, mpe@ellerman.id.au, npiggin@gmail.com, chleroy@kernel.org, peterz@infradead.org, jpoimboe@kernel.org, jbaron@akamai.com, rostedt@goodmis.org, ardb@kernel.org, rust-for-linux@vger.kernel.org, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org Cc: "Mukesh Kumar Chaurasiya (IBM)" Subject: [PATCH V3 2/3] rust: Add PowerPC support Date: Thu, 5 Feb 2026 23:34:28 +0530 Message-ID: <20260205180429.3280657-3-mkchauras@gmail.com> X-Mailer: git-send-email 2.52.0 In-Reply-To: <20260205180429.3280657-1-mkchauras@gmail.com> References: <20260205180429.3280657-1-mkchauras@gmail.com> X-Mailing-List: linuxppc-dev@lists.ozlabs.org List-Id: List-Help: List-Owner: List-Post: List-Archive: , List-Subscribe: , , List-Unsubscribe: Precedence: list MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit From: Link Mauve For now only Big Endian 32-bit PowerPC is supported, as that is the only hardware I have. This has been tested on the Nintendo Wii so far, but I plan on also using it on the GameCube, Wii U and Apple G4. These changes aren’t the only ones required to get the kernel to compile and link on PowerPC, libcore will also have to be changed to not use integer division to format u64, u128 and core::time::Duration, otherwise __udivdi3() and __umoddi3() will have to be added. I have tested this change by replacing the three implementations with unimplemented!() and it linked just fine. Signed-off-by: Link Mauve Signed-off-by: Mukesh Kumar Chaurasiya (IBM) --- Documentation/rust/arch-support.rst | 1 + arch/powerpc/Kconfig | 1 + arch/powerpc/Makefile | 2 ++ rust/Makefile | 4 +++- 4 files changed, 7 insertions(+), 1 deletion(-) diff --git a/Documentation/rust/arch-support.rst b/Documentation/rust/arch-support.rst index 6e6a515d0899..e26a94808e97 100644 --- a/Documentation/rust/arch-support.rst +++ b/Documentation/rust/arch-support.rst @@ -18,6 +18,7 @@ Architecture Level of support Constraints ``arm`` Maintained ARMv7 Little Endian only. ``arm64`` Maintained Little Endian only. ``loongarch`` Maintained \- +``powerpc`` Experimental 32-bit Big Endian only. ``riscv`` Maintained ``riscv64`` and LLVM/Clang only. ``um`` Maintained \- ``x86`` Maintained ``x86_64`` only. diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig index 9537a61ebae0..17db23b82e91 100644 --- a/arch/powerpc/Kconfig +++ b/arch/powerpc/Kconfig @@ -283,6 +283,7 @@ config PPC select HAVE_REGS_AND_STACK_ACCESS_API select HAVE_RELIABLE_STACKTRACE select HAVE_RSEQ + select HAVE_RUST if PPC32 select HAVE_SAMPLE_FTRACE_DIRECT if HAVE_DYNAMIC_FTRACE_WITH_DIRECT_CALLS select HAVE_SAMPLE_FTRACE_DIRECT_MULTI if HAVE_DYNAMIC_FTRACE_WITH_DIRECT_CALLS select HAVE_SETUP_PER_CPU_AREA if PPC64 diff --git a/arch/powerpc/Makefile b/arch/powerpc/Makefile index a58b1029592c..9fd82c75dcbd 100644 --- a/arch/powerpc/Makefile +++ b/arch/powerpc/Makefile @@ -61,6 +61,8 @@ else KBUILD_LDFLAGS_MODULE += $(objtree)/arch/powerpc/lib/crtsavres.o endif +KBUILD_RUSTFLAGS += --target=powerpc-unknown-linux-gnu + ifdef CONFIG_CPU_LITTLE_ENDIAN KBUILD_CPPFLAGS += -mlittle-endian KBUILD_LDFLAGS += -EL diff --git a/rust/Makefile b/rust/Makefile index 4dcc2eff51cb..ae22f2c5f0b3 100644 --- a/rust/Makefile +++ b/rust/Makefile @@ -384,13 +384,15 @@ bindgen_skip_c_flags := -mno-fp-ret-in-387 -mpreferred-stack-boundary=% \ -fstrict-flex-arrays=% -fmin-function-alignment=% \ -fzero-init-padding-bits=% -mno-fdpic \ -fdiagnostics-show-context -fdiagnostics-show-context=% \ - --param=% --param asan-% -fno-isolate-erroneous-paths-dereference + --param=% --param asan-% -fno-isolate-erroneous-paths-dereference \ + -ffixed-r2 -mmultiple -mno-readonly-in-sdata # Derived from `scripts/Makefile.clang`. BINDGEN_TARGET_x86 := x86_64-linux-gnu BINDGEN_TARGET_arm64 := aarch64-linux-gnu BINDGEN_TARGET_arm := arm-linux-gnueabi BINDGEN_TARGET_loongarch := loongarch64-linux-gnusf +BINDGEN_TARGET_powerpc := powerpc-linux-gnu BINDGEN_TARGET_um := $(BINDGEN_TARGET_$(SUBARCH)) BINDGEN_TARGET := $(BINDGEN_TARGET_$(SRCARCH)) -- 2.52.0