On Tue, 21 Nov 2017 11:08:01 -0500It depends upon what you mean by two distinct paths. Configuring the
Tony Krowiak <akrowiak@xxxxxxxxxxxxxxxxxx> wrote:
I am not quite sure what you are asking, but I'll attempt to answerOk, so we would have two distinct paths here...
what I think you're asking. A new type of mediated matrix device
will be introduced to configure a virtual matrix for a guest that
provides the interfaces to map a virtual adapter/domain ID to one
or more real adapter/domain IDs. If by virtualization facility,
you are talking about the VFIO AP matrix driver, then yes,
the driver will handle ioctl requests based on the type of the
mediated matrix device through which the request was submitted:
If the request is to configure the KVM guest's matrix:
* If the mediated matrix device type is passthrough:
* Do validation of matrix
* Configure the APM, AQM and ADM in the KVM guest's CRYCB
according to the configuration specified via the mediated
device's sysfs attribute files.
* If the mediated matrix device type is virtual:
* Do validation of matrix
* No need to configure CRYCB since all instructions will be
intercepted
The driver would require additional ioctls to handle
If the request is to execute an intercepted AP instruction:...and two distinct paths for most instructions here as well.
* If the mediated matrix device type is passthrough:
* Forward the instruction to the AP device and return the
result to QEMU.
* If the mediated matrix device type is virtual:
* Retrieve all of the real APQNs mapped to the virtual
adapter and domain IDs configured in the mediated matrix
device's sysfs attribute files
* If there is more than one APQN mapping, then determine
which would be best to use - algorithm TBD
* Forward the instruction to the AP device and return the
result.
That is the plan. Given Pierre's objections, I thought it might help
Of course, these are just preliminary ideas at this time.Yes, let's cross that bridge when we get to it.
I've only prototyped the sysfs configuration interfaces. No
back end prototyping has been undertaken yet. If the ideas do
not pan out, however; I think virtualization can be introduced
as an independent design.