On 29/1/26 17:08, Peter Maydell wrote:
From: Shameer Kolothum <[email protected]>

Set up dedicated PCIIOMMUOps for the accel SMMUv3, since it will need
different callback handling in upcoming patches. This also adds a
CONFIG_ARM_SMMUV3_ACCEL build option so the feature can be disabled
at compile time. Because we now include CONFIG_DEVICES in the header to
check for ARM_SMMUV3_ACCEL, the meson file entry for smmuv3.c needs to
be changed to arm_ss.add.

The “accel” property isn’t user visible yet and it will be introduced in
a later patch once all the supporting pieces are ready.

Signed-off-by: Shameer Kolothum <[email protected]>
Reviewed-by: Nicolin Chen <[email protected]>
Reviewed-by: Jonathan Cameron <[email protected]>
Reviewed-by: Eric Auger <[email protected]>
Tested-by: Zhangfei Gao <[email protected]>
Tested-by: Eric Auger <[email protected]>
Signed-off-by: Shameer Kolothum <[email protected]>
Message-id: [email protected]
Signed-off-by: Peter Maydell <[email protected]>
---
  hw/arm/Kconfig          |  5 ++++
  hw/arm/meson.build      |  3 ++-
  hw/arm/smmuv3-accel.c   | 59 +++++++++++++++++++++++++++++++++++++++++
  hw/arm/smmuv3-accel.h   | 27 +++++++++++++++++++
  hw/arm/smmuv3.c         |  5 ++++
  include/hw/arm/smmuv3.h |  3 +++
  6 files changed, 101 insertions(+), 1 deletion(-)
  create mode 100644 hw/arm/smmuv3-accel.c
  create mode 100644 hw/arm/smmuv3-accel.h


diff --git a/hw/arm/smmuv3-accel.h b/hw/arm/smmuv3-accel.h
new file mode 100644
index 0000000000..0dc6b00d35
--- /dev/null
+++ b/hw/arm/smmuv3-accel.h
@@ -0,0 +1,27 @@
+/*
+ * Copyright (c) 2025 Huawei Technologies R & D (UK) Ltd
+ * Copyright (C) 2025 NVIDIA
+ * Written by Nicolin Chen, Shameer Kolothum
+ *
+ * SPDX-License-Identifier: GPL-2.0-or-later
+ */
+
+#ifndef HW_ARM_SMMUV3_ACCEL_H
+#define HW_ARM_SMMUV3_ACCEL_H
+
+#include "hw/arm/smmu-common.h"
+#include CONFIG_DEVICES

We shouldn't use CONFIG_DEVICES in a header as the files including
it become target-specific. I suppose this comes from a copy/paste
pattern of intel_iommu_accel.h :(

$ git grep -w CONFIG_DEVICES
hw/arm/smmuv3-accel.h:17:#include CONFIG_DEVICES
hw/i386/intel_iommu_accel.h:13:#include CONFIG_DEVICES
include/hw/s390x/s390-pci-vfio.h:16:#include CONFIG_DEVICES
target/i386/kvm/tdx.h:7:#include CONFIG_DEVICES /* CONFIG_TDX */
target/i386/sev.h:20:#include CONFIG_DEVICES /* CONFIG_SEV */

+
+typedef struct SMMUv3AccelDevice {
+    SMMUDevice sdev;
+} SMMUv3AccelDevice;
+
+#ifdef CONFIG_ARM_SMMUV3_ACCEL
+void smmuv3_accel_init(SMMUv3State *s);
+#else
+static inline void smmuv3_accel_init(SMMUv3State *s)
+{
+}
+#endif
+
+#endif /* HW_ARM_SMMUV3_ACCEL_H */


Reply via email to