[PATCH v3 3/8] iommu/riscv: Add HPM support for performance monitoring
Andrew Jones
andrew.jones at oss.qualcomm.com
Wed Feb 4 10:39:41 PST 2026
How does this relate to
https://lore.kernel.org/all/20250115030306.29735-1-zong.li@sifive.com/
>From a quick skim it looks like there's plenty of overlap.
Thanks,
drew
On Wed, Feb 04, 2026 at 05:09:01PM +0800, Lv Zheng wrote:
> From: Jingyu Li <joey.li at spacemit.com>
>
> Introduces perf-based HPM driver for RISC-V IOMMU, enabling performance
> monitoring capabilities.
>
> Note that the RISC-V IOMMU HPM module uses COUNTER_MAX-1 as a static
> counter index of HPMCYCLES, and 0~COUNTER_MAX-2 as the dynamic counter
> indexes of other HPMEVENTS in order to correctly index into IOHPMEVT and
> IOHPMCTR registers that have already been defined in the iommu-bits.h.
> However the users treat 0 as the index of HPMCYCLES and 1~COUNTER_MAX-1 as
> the indexes of other HPMEVENTS, thus care should be taken in dealing with
> counter indexes between userspace and kernel space.
>
> Signed-off-by: Jingyu Li <joey.li at spacemit.com>
> Signed-off-by: Lv Zheng <lv.zheng at linux.spacemit.com>
> Link: https://github.com/riscv-non-isa/riscv-iommu
> ---
> drivers/iommu/riscv/Kconfig | 9 +
> drivers/iommu/riscv/Makefile | 1 +
> drivers/iommu/riscv/iommu-bits.h | 6 +
> drivers/iommu/riscv/iommu-hpm.c | 843 +++++++++++++++++++++++++++
> drivers/iommu/riscv/iommu-pci.c | 13 +-
> drivers/iommu/riscv/iommu-platform.c | 8 +-
> drivers/iommu/riscv/iommu.h | 42 ++
> 7 files changed, 919 insertions(+), 3 deletions(-)
> create mode 100644 drivers/iommu/riscv/iommu-hpm.c
>
More information about the linux-riscv
mailing list