From: Anup Patel <apatel@ventanamicro.com>
To: "Michael Turquette" <mturquette@baylibre.com>,
"Stephen Boyd" <sboyd@kernel.org>,
"Rob Herring" <robh@kernel.org>,
"Krzysztof Kozlowski" <krzk+dt@kernel.org>,
"Conor Dooley" <conor+dt@kernel.org>,
"Jassi Brar" <jassisinghbrar@gmail.com>,
"Thomas Gleixner" <tglx@linutronix.de>,
"Rafael J . Wysocki" <rafael@kernel.org>,
"Mika Westerberg" <mika.westerberg@linux.intel.com>,
"Andy Shevchenko" <andriy.shevchenko@linux.intel.com>,
"Linus Walleij" <linus.walleij@linaro.org>,
"Bartosz Golaszewski" <brgl@bgdev.pl>,
"Uwe Kleine-König" <ukleinek@kernel.org>
Cc: Anup Patel <apatel@ventanamicro.com>,
devicetree@vger.kernel.org,
Andrew Jones <ajones@ventanamicro.com>,
Alexandre Ghiti <alex@ghiti.fr>,
Atish Patra <atish.patra@linux.dev>,
Leyfoon Tan <leyfoon.tan@starfivetech.com>,
Anup Patel <anup@brainfault.org>,
linux-kernel@vger.kernel.org,
Samuel Holland <samuel.holland@sifive.com>,
linux-acpi@vger.kernel.org, Palmer Dabbelt <palmer@dabbelt.com>,
Paul Walmsley <paul.walmsley@sifive.com>,
linux-riscv@lists.infradead.org, Len Brown <lenb@kernel.org>,
linux-clk@vger.kernel.org,
Rahul Pathak <rpathak@ventanamicro.com>
Subject: [PATCH v9 00/24] Linux SBI MPXY and RPMI drivers
Date: Mon, 28 Jul 2025 15:10:08 +0530 [thread overview]
Message-ID: <20250728094032.63545-1-apatel@ventanamicro.com> (raw)
The SBI v3.0 (MPXY extension) [1] and RPMI v1.0 [2] specifications
are ratified by the RISC-V International.
Currently, most of the RPMI and MPXY drivers are in OpenSBI whereas
Linux only has SBI MPXY mailbox controller driver, RPMI clock driver
and RPMI system MSI driver This series also includes ACPI support
for SBI MPXY mailbox controller and RPMI system MSI drivers.
These patches can be found in the riscv_sbi_mpxy_mailbox_v9 branch
at: https://github.com/avpatel/linux.git
To test these patches, boot Linux on "virt,rpmi=on,aia=aplic-imsic"
machine with OpenSBI and QEMU from the dev-upstream branch at:
https://github.com/ventanamicro/opensbi.git
https://github.com/ventanamicro/qemu.git
[1] https://github.com/riscv-non-isa/riscv-sbi-doc/releases
[2] https://github.com/riscv-non-isa/riscv-rpmi/releases
Changes since v8:
- Added Jassi's Acked-by in mailbox related patches
- Renamed "clock-controller" DT node to "clock-service" DT node
in PATCH8 as suggested by Stephen Boyd
Changes since v7:
- Addressed enum related nits in PATCH3
(Refer, https://lore.kernel.org/all/CAK9=C2VxhC6soxHtmacedbeCU=rFi84Br1RvN2uPcBKoLhRaJw@mail.gmail.com/)
- Addressed comments in PATCH7 as follows:
- Added minmax.h to includes
- Removed "rc" variable from mpxy_mbox_send_rpmi_data()
- Removed alignment and other checks from mpxy_mbox_peek_rpmi_data()
- Created separate function to restrict scope of channel_ids used in mpxy_mbox_probe()
(Refer, https://lore.kernel.org/all/CAK9=C2Ume2CmBYHYob7HSJHu=ZdfdWM+4JYPgFJ9Hir5Oi8cOg@mail.gmail.com/)
- Improved comments for struct rpmi_clk_rates in PATCH10
(Refer, https://lore.kernel.org/all/CAK9=C2VfvsbFTjecQm0OSsssXbff7wC4fqWf3CTmnpWSiaLcBw@mail.gmail.com/)
- Improved refactoring of acpi_fwnode_get_reference_args() in PATCH14
(Refer, https://lore.kernel.org/all/20250702051345.1460497-15-apatel@ventanamicro.com/)
- Improve nargs_count parsing in acpi_fwnode_get_reference_args() for PATCH15
(Refer, https://lore.kernel.org/all/20250702051345.1460497-16-apatel@ventanamicro.com/)
- Added more comments describing why need to explicitly set device MSI domain in PATCH21
(Refer, https://lore.kernel.org/all/aGaUmpw1pVWNAmpb@smile.fi.intel.com/)
Changes since v6:
- Rebased the series on Linux-6.16-rc4
- Added Stephen's Reviewed-by in appropriate patches
- Addressed Andy's comments on PATCH5, PATCH6, PATCH9, and PATCH14
- New PATCH6 in this series which is factored-out from PATCH7
Changes since v5:
- Rebased the series on Linux-6.16-rc2
- Added Conor's Reviewed-by in all DT binding patches
- Addressed Andy's comments on PATCH5
- Addressed Tglx's comments on PATCH12 and PATCH21
Changes since v4:
- Rebased the series on Linux-6.16-rc1
- Dropped PATCH1 since a similar change is already merged
https://lore.kernel.org/linux-riscv/20250523101932.1594077-4-cleger@rivosinc.com/
- Addressed Andy's comments on PATCH4, PATCH5, PATCH6, PATCH7,
PATCH13, and PATCH17
- Addressed Atish's comments on PATCH11 and PATCH12
- Addressed Conor's comments on PATCH9
Changes since v3:
- Rebased the series on Linux-6.15-rc7
- Updated PATCH2 DT bindings as-per Rob's suggestion
- Improved request_threaded_irq() usage in PATCH7
- Updated PATCH10 clk-rpmi driver as-per commments from Andy
- Updated PATCH13 irq-riscv-rpmi-sysmsi driver as-per comments
from Andy and Tglx
- Addressed ACPI related comments in PATCH14, PATCH15, PATCH18,
PATCH20 and PATCH21
Changes since v2:
- Dropped the "RFC" tag from series since the SBI v3.0 and
RPMI v1.0 specifications are now frozen
- Rebased the series on Linux-6.15-rc5
- Split PATCH8 of v2 into two patches adding separate DT
bindings for "riscv,rpmi-mpxy-clock" and "riscv,rpmi-clock"
- Split PATCH10 of v2 into two patches adding separate DT
bindings for "riscv,rpmi-mpxy-system-msi" and
"riscv,rpmi-system-msi"
- Addressed comments from TGLX on PATCH11 of v2 adding irqchip
driver for RPMI system MSI
- Addressed ACPI related comments in PATCH15 and PATCH16 of v2
- New PATCH17 and PATCH18 in this series
Changes since v1:
- Addressed DT bindings related comments in PATCH2, PATCH3, and
PATCH7 of v1 series
- Addressed comments in PATCH6 and PATCH8 of v1 series
- New PATCH6 in v2 series to allow fwnode based mailbox channel
request
- New PATCH10 and PATCH11 to add RPMI system MSI based interrupt
controller driver
- New PATCH12 to PATCH16 which adds ACPI support in SBI MPXY
mailbox driver and RPMI system MSI driver
- New PATCH17 to enable required kconfig option to allow graceful
shutdown on QEMU virt machine
Anup Patel (14):
dt-bindings: mailbox: Add bindings for RPMI shared memory transport
dt-bindings: mailbox: Add bindings for RISC-V SBI MPXY extension
RISC-V: Add defines for the SBI message proxy extension
mailbox: Add common header for RPMI messages sent via mailbox
mailbox: Allow controller specific mapping using fwnode
byteorder: Add memcpy_to_le32() and memcpy_from_le32()
mailbox: Add RISC-V SBI message proxy (MPXY) based mailbox driver
dt-bindings: clock: Add RPMI clock service message proxy bindings
dt-bindings: clock: Add RPMI clock service controller bindings
dt-bindings: Add RPMI system MSI message proxy bindings
dt-bindings: Add RPMI system MSI interrupt controller bindings
irqchip: Add driver for the RPMI system MSI service group
RISC-V: Enable GPIO keyboard and event device in RV64 defconfig
MAINTAINERS: Add entry for RISC-V RPMI and MPXY drivers
Rahul Pathak (1):
clk: Add clock driver for the RISC-V RPMI clock service group
Sunil V L (9):
ACPI: property: Refactor acpi_fwnode_get_reference_args() to support
nargs_prop
ACPI: Add support for nargs_prop in acpi_fwnode_get_reference_args()
ACPI: scan: Update honor list for RPMI System MSI
ACPI: RISC-V: Create interrupt controller list in sorted order
ACPI: RISC-V: Add support to update gsi range
ACPI: RISC-V: Add RPMI System MSI to GSI mapping
irqchip/irq-riscv-imsic-early: Export imsic_acpi_get_fwnode()
mailbox/riscv-sbi-mpxy: Add ACPI support
irqchip/riscv-rpmi-sysmsi: Add ACPI support
.../bindings/clock/riscv,rpmi-clock.yaml | 64 ++
.../bindings/clock/riscv,rpmi-mpxy-clock.yaml | 64 ++
.../riscv,rpmi-mpxy-system-msi.yaml | 67 ++
.../riscv,rpmi-system-msi.yaml | 74 ++
.../mailbox/riscv,rpmi-shmem-mbox.yaml | 124 ++
.../bindings/mailbox/riscv,sbi-mpxy-mbox.yaml | 51 +
MAINTAINERS | 15 +
arch/riscv/configs/defconfig | 2 +
arch/riscv/include/asm/irq.h | 6 +
arch/riscv/include/asm/sbi.h | 63 +
drivers/acpi/property.c | 128 ++-
drivers/acpi/riscv/irq.c | 75 +-
drivers/acpi/scan.c | 2 +
drivers/base/property.c | 2 +-
drivers/clk/Kconfig | 8 +
drivers/clk/Makefile | 1 +
drivers/clk/clk-rpmi.c | 616 ++++++++++
drivers/irqchip/Kconfig | 7 +
drivers/irqchip/Makefile | 1 +
drivers/irqchip/irq-riscv-imsic-early.c | 2 +
drivers/irqchip/irq-riscv-rpmi-sysmsi.c | 328 ++++++
drivers/mailbox/Kconfig | 11 +
drivers/mailbox/Makefile | 2 +
drivers/mailbox/mailbox.c | 65 +-
drivers/mailbox/riscv-sbi-mpxy-mbox.c | 1017 +++++++++++++++++
include/linux/byteorder/generic.h | 16 +
include/linux/mailbox/riscv-rpmi-message.h | 243 ++++
include/linux/mailbox_controller.h | 3 +
include/linux/wordpart.h | 16 +
29 files changed, 2990 insertions(+), 83 deletions(-)
create mode 100644 Documentation/devicetree/bindings/clock/riscv,rpmi-clock.yaml
create mode 100644 Documentation/devicetree/bindings/clock/riscv,rpmi-mpxy-clock.yaml
create mode 100644 Documentation/devicetree/bindings/interrupt-controller/riscv,rpmi-mpxy-system-msi.yaml
create mode 100644 Documentation/devicetree/bindings/interrupt-controller/riscv,rpmi-system-msi.yaml
create mode 100644 Documentation/devicetree/bindings/mailbox/riscv,rpmi-shmem-mbox.yaml
create mode 100644 Documentation/devicetree/bindings/mailbox/riscv,sbi-mpxy-mbox.yaml
create mode 100644 drivers/clk/clk-rpmi.c
create mode 100644 drivers/irqchip/irq-riscv-rpmi-sysmsi.c
create mode 100644 drivers/mailbox/riscv-sbi-mpxy-mbox.c
create mode 100644 include/linux/mailbox/riscv-rpmi-message.h
--
2.43.0
_______________________________________________
linux-riscv mailing list
linux-riscv@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-riscv
next reply other threads:[~2025-07-28 9:41 UTC|newest]
Thread overview: 28+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-07-28 9:40 Anup Patel [this message]
2025-07-28 9:40 ` [PATCH v9 01/24] dt-bindings: mailbox: Add bindings for RPMI shared memory transport Anup Patel
2025-07-28 9:40 ` [PATCH v9 02/24] dt-bindings: mailbox: Add bindings for RISC-V SBI MPXY extension Anup Patel
2025-08-02 4:12 ` Samuel Holland
2025-08-03 14:07 ` Anup Patel
2025-07-28 9:40 ` [PATCH v9 03/24] RISC-V: Add defines for the SBI message proxy extension Anup Patel
2025-07-28 9:40 ` [PATCH v9 04/24] mailbox: Add common header for RPMI messages sent via mailbox Anup Patel
2025-07-28 9:40 ` [PATCH v9 05/24] mailbox: Allow controller specific mapping using fwnode Anup Patel
2025-07-28 9:40 ` [PATCH v9 06/24] byteorder: Add memcpy_to_le32() and memcpy_from_le32() Anup Patel
2025-07-28 9:40 ` [PATCH v9 07/24] mailbox: Add RISC-V SBI message proxy (MPXY) based mailbox driver Anup Patel
2025-07-28 9:40 ` [PATCH v9 08/24] dt-bindings: clock: Add RPMI clock service message proxy bindings Anup Patel
2025-07-28 9:40 ` [PATCH v9 09/24] dt-bindings: clock: Add RPMI clock service controller bindings Anup Patel
2025-07-28 9:40 ` [PATCH v9 10/24] clk: Add clock driver for the RISC-V RPMI clock service group Anup Patel
2025-07-28 9:40 ` [PATCH v9 11/24] dt-bindings: Add RPMI system MSI message proxy bindings Anup Patel
2025-07-28 9:40 ` [PATCH v9 12/24] dt-bindings: Add RPMI system MSI interrupt controller bindings Anup Patel
2025-07-28 9:40 ` [PATCH v9 13/24] irqchip: Add driver for the RPMI system MSI service group Anup Patel
2025-07-28 9:40 ` [PATCH v9 14/24] ACPI: property: Refactor acpi_fwnode_get_reference_args() to support nargs_prop Anup Patel
2025-07-28 9:40 ` [PATCH v9 15/24] ACPI: Add support for nargs_prop in acpi_fwnode_get_reference_args() Anup Patel
2025-07-28 9:40 ` [PATCH v9 16/24] ACPI: scan: Update honor list for RPMI System MSI Anup Patel
2025-07-28 9:40 ` [PATCH v9 17/24] ACPI: RISC-V: Create interrupt controller list in sorted order Anup Patel
2025-07-28 9:40 ` [PATCH v9 18/24] ACPI: RISC-V: Add support to update gsi range Anup Patel
2025-07-28 9:40 ` [PATCH v9 19/24] ACPI: RISC-V: Add RPMI System MSI to GSI mapping Anup Patel
2025-07-28 9:40 ` [PATCH v9 20/24] irqchip/irq-riscv-imsic-early: Export imsic_acpi_get_fwnode() Anup Patel
2025-07-28 9:40 ` [PATCH v9 21/24] mailbox/riscv-sbi-mpxy: Add ACPI support Anup Patel
2025-07-28 9:40 ` [PATCH v9 22/24] irqchip/riscv-rpmi-sysmsi: " Anup Patel
2025-07-28 9:40 ` [PATCH v9 23/24] RISC-V: Enable GPIO keyboard and event device in RV64 defconfig Anup Patel
2025-07-28 9:40 ` [PATCH v9 24/24] MAINTAINERS: Add entry for RISC-V RPMI and MPXY drivers Anup Patel
2025-08-07 16:50 ` [PATCH v9 00/24] Linux SBI MPXY and RPMI drivers patchwork-bot+linux-riscv
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=20250728094032.63545-1-apatel@ventanamicro.com \
--to=apatel@ventanamicro.com \
--cc=ajones@ventanamicro.com \
--cc=alex@ghiti.fr \
--cc=andriy.shevchenko@linux.intel.com \
--cc=anup@brainfault.org \
--cc=atish.patra@linux.dev \
--cc=brgl@bgdev.pl \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=jassisinghbrar@gmail.com \
--cc=krzk+dt@kernel.org \
--cc=lenb@kernel.org \
--cc=leyfoon.tan@starfivetech.com \
--cc=linus.walleij@linaro.org \
--cc=linux-acpi@vger.kernel.org \
--cc=linux-clk@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-riscv@lists.infradead.org \
--cc=mika.westerberg@linux.intel.com \
--cc=mturquette@baylibre.com \
--cc=palmer@dabbelt.com \
--cc=paul.walmsley@sifive.com \
--cc=rafael@kernel.org \
--cc=robh@kernel.org \
--cc=rpathak@ventanamicro.com \
--cc=samuel.holland@sifive.com \
--cc=sboyd@kernel.org \
--cc=tglx@linutronix.de \
--cc=ukleinek@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