Re: [PATCH 3/4] iommu: Introduce IOMMU call-back for processing struct KVM assigned to VFIO
From: Robin Murphy
Date: Tue Jan 17 2023 - 07:52:21 EST
On 2023-01-17 04:20, Suthikulpanit, Suravee wrote:
Hi Robin,
On 1/10/2023 10:11 PM, Robin Murphy wrote:
On 2023-01-10 14:31, Suravee Suthikulpanit wrote:
Currently, VFIO provide an kvm_vfio_file_set_kvm() interface for
assigning
a KVM structure to a VFIO group. The information in struct KVM is also
useful for IOMMU drivers when setting up VFIO domain.
Introduce struct iommu_domain_ops.set_kvm call-back function to allow
IOMMU drivers to provide call-back to process the struct KVM assigned.
Hmm, it sounds like this has quite some overlap of intent with the
existing "enable_nesting" op, and my gut feeling is that it's not
great to have two completely different "this is a VFIO domain"
mechanisms... :/
Robin.
Actually, the intention is to communicate KVM information, which is
already available to the VFIO down to the AMD IOMMU driver layer. I am
not sure if the enable_nesting() has enough information or the same
intention since that only communicates VFIO domain information.
Sure, but from the high level view, we have on the one hand an API for
"I want to use this domain in a VM (with nested paging)" and on other an
API for "I want to use nested paging in this domain (for a VM)", so
clearly it would be most sensible to converge on a single API for what
is ultimately one single overarching use-case.
I'm not claiming that the existing enable_nesting op is anywhere near
the right design either; in fact I'm pretty sure it isn't, if the Arm
SMMU drivers ever want to contemplate sharing stage 2 pagetables with
KVM also.
Cheers,
Robin.