]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
RISC-V: KVM: Add separate source for forwarded SBI extensions
authorAnup Patel <apatel@ventanamicro.com>
Fri, 17 Oct 2025 15:59:23 +0000 (21:29 +0530)
committerAnup Patel <anup@brainfault.org>
Mon, 24 Nov 2025 04:25:36 +0000 (09:55 +0530)
Add a separate source vcpu_sbi_forward.c for SBI extensions
which are entirely forwarded to KVM user-space.

Signed-off-by: Anup Patel <apatel@ventanamicro.com>
Reviewed-by: Andrew Jones <ajones@ventanamicro.com>
Link: https://lore.kernel.org/r/20251017155925.361560-3-apatel@ventanamicro.com
Signed-off-by: Anup Patel <anup@brainfault.org>
arch/riscv/kvm/Makefile
arch/riscv/kvm/vcpu_sbi_base.c
arch/riscv/kvm/vcpu_sbi_forward.c [new file with mode: 0644]
arch/riscv/kvm/vcpu_sbi_replace.c

index 07197395750e38b2f2dc72e788bf2f2d300fb67a..3b8afb038b35c22784ca8e7da0381a29b999f1a2 100644 (file)
@@ -27,6 +27,7 @@ kvm-y += vcpu_onereg.o
 kvm-$(CONFIG_RISCV_PMU_SBI) += vcpu_pmu.o
 kvm-y += vcpu_sbi.o
 kvm-y += vcpu_sbi_base.o
+kvm-y += vcpu_sbi_forward.o
 kvm-y += vcpu_sbi_fwft.o
 kvm-y += vcpu_sbi_hsm.o
 kvm-$(CONFIG_RISCV_PMU_SBI) += vcpu_sbi_pmu.o
index ca489f2dfbdf641febe5bb19b3939513184d0206..06fdd5f6936498de1fe58ffebaa096362f969861 100644 (file)
@@ -70,15 +70,3 @@ const struct kvm_vcpu_sbi_extension vcpu_sbi_ext_base = {
        .extid_end = SBI_EXT_BASE,
        .handler = kvm_sbi_ext_base_handler,
 };
-
-const struct kvm_vcpu_sbi_extension vcpu_sbi_ext_experimental = {
-       .extid_start = SBI_EXT_EXPERIMENTAL_START,
-       .extid_end = SBI_EXT_EXPERIMENTAL_END,
-       .handler = kvm_riscv_vcpu_sbi_forward_handler,
-};
-
-const struct kvm_vcpu_sbi_extension vcpu_sbi_ext_vendor = {
-       .extid_start = SBI_EXT_VENDOR_START,
-       .extid_end = SBI_EXT_VENDOR_END,
-       .handler = kvm_riscv_vcpu_sbi_forward_handler,
-};
diff --git a/arch/riscv/kvm/vcpu_sbi_forward.c b/arch/riscv/kvm/vcpu_sbi_forward.c
new file mode 100644 (file)
index 0000000..dbfa70c
--- /dev/null
@@ -0,0 +1,27 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Copyright (c) 2025 Ventana Micro Systems Inc.
+ */
+
+#include <linux/kvm_host.h>
+#include <asm/kvm_vcpu_sbi.h>
+#include <asm/sbi.h>
+
+const struct kvm_vcpu_sbi_extension vcpu_sbi_ext_experimental = {
+       .extid_start = SBI_EXT_EXPERIMENTAL_START,
+       .extid_end = SBI_EXT_EXPERIMENTAL_END,
+       .handler = kvm_riscv_vcpu_sbi_forward_handler,
+};
+
+const struct kvm_vcpu_sbi_extension vcpu_sbi_ext_vendor = {
+       .extid_start = SBI_EXT_VENDOR_START,
+       .extid_end = SBI_EXT_VENDOR_END,
+       .handler = kvm_riscv_vcpu_sbi_forward_handler,
+};
+
+const struct kvm_vcpu_sbi_extension vcpu_sbi_ext_dbcn = {
+       .extid_start = SBI_EXT_DBCN,
+       .extid_end = SBI_EXT_DBCN,
+       .default_disabled = true,
+       .handler = kvm_riscv_vcpu_sbi_forward_handler,
+};
index 2c456e26f6ca764709f625928f2f85046d7df2e8..506a510b6bff3b5e1e5dee502a52eb733b3feeb3 100644 (file)
@@ -185,10 +185,3 @@ const struct kvm_vcpu_sbi_extension vcpu_sbi_ext_srst = {
        .extid_end = SBI_EXT_SRST,
        .handler = kvm_sbi_ext_srst_handler,
 };
-
-const struct kvm_vcpu_sbi_extension vcpu_sbi_ext_dbcn = {
-       .extid_start = SBI_EXT_DBCN,
-       .extid_end = SBI_EXT_DBCN,
-       .default_disabled = true,
-       .handler = kvm_riscv_vcpu_sbi_forward_handler,
-};