On Wed, May 14, 2025 at 01:33:39PM -0300, Jason Gunthorpe wrote: > On Wed, May 14, 2025 at 03:02:53PM +0800, Xu Yilun wrote: > > > We have an awkward fit for what CCA people are doing to the various > > > Linux APIs. Looking somewhat maximally across all the arches a "bind" > > > for a CC vPCI device creation operation does: > > > > > > - Setup the CPU page tables for the VM to have access to the MMIO > > > > This is guest side thing, is it? Anything host need to opt-in? > > CPU hypervisor page tables. > > > > - Revoke hypervisor access to the MMIO > > > > VFIO could choose never to mmap MMIO, so in this case nothing to do? > > Yes, if you do it that way. > > > > - Setup the vIOMMU to understand the vPCI device > > > - Take over control of some of the IOVA translation, at least for T=1, > > > and route to the the vIOMMU > > > - Register the vPCI with any attestation functions the VM might use > > > - Do some DOE stuff to manage/validate TDSIP/etc > > > > Intel TDX Connect has a extra requirement for "unbind": > > > > - Revoke KVM page table (S-EPT) for the MMIO only after TDISP > > CONFIG_UNLOCK > > Maybe you could express this as the S-EPT always has the MMIO mapped > into it as long as the vPCI function is installed to the VM?
Yeah. > Is KVM responsible for the S-EPT? Yes. > > > Another thing is, seems your term "bind" includes all steps for > > shared -> private conversion. > > Well, I was talking about vPCI creation. I understand that during the > vPCI lifecycle the VM will do "bind" "unbind" which are more or less > switching the device into a T=1 mode. Though I understood on some I want to introduce some terms about CC vPCI. 1. "Bind", guest requests host do host side CC setup & put device in CONFIG_LOCKED state, waiting for attestation. Any further change which has secuity concern breaks "bind", e.g. reset, touch MMIO, physical MSE, BAR addr... 2. "Attest", after "bind", guest verifies device evidences (cert, measurement...). 3. "Accept", after successful attestation, guest do guest side CC setup & switch the device into T=1 mode (TDISP RUN state) 4. "Unbind", guest requests host put device in CONFIG_UNLOCK state + remove all CC setup. > arches this was mostly invisible to the hypervisor? Attest & Accept can be invisible to hypervisor, or host just help pass data blobs between guest, firmware & device. Bind cannot be host agnostic, host should be aware not to touch device after Bind. > > > But in my mind, "bind" only includes > > putting device in TDISP LOCK state & corresponding host setups required > > by firmware. I.e "bind" means host lockes down the CC setup, waiting for > > guest attestation. > > So we will need to have some other API for this that modifies the vPCI > object. IIUC, in Alexey's patch ioctl(iommufd, IOMMU_VDEVICE_TSM_BIND) does the "Bind" thing in host. > > It might be reasonable to have VFIO reach into iommufd to do that on > an already existing iommufd VDEVICE object. A little weird, but we > could probably make that work. Mm, Are you proposing an uAPI in VFIO, and a kAPI from VFIO -> IOMMUFD like: ioctl(vfio_fd, VFIO_DEVICE_ATTACH_VDEV, vdev_id) -> iommufd_device_attach_vdev() -> tsm_tdi_bind() > > But you have some weird ordering issues here if the S-EPT has to have > the VFIO MMIO then you have to have a close() destruction order that Yeah, by holding kvm reference. > sees VFIO remove the S-EPT and release the KVM, then have iommufd > destroy the VDEVICE object. Regarding VM destroy, TDX Connect has more enforcement, VM could only be destroyed after all assigned CC vPCI devices are destroyed. Nowadays, VFIO already holds KVM reference, so we need close(vfio_fd) -> iommufd_device_detach_vdev() -> tsm_tdi_unbind() -> tdi stop -> callback to VFIO, dmabuf_move_notify(revoke) -> KVM unmap MMIO -> tdi metadata remove -> kvm_put_kvm() -> kvm_destroy_vm() > > > > It doesn't mean that iommufd is suddenly doing PCI stuff, no, that > > > stays in VFIO. > > > > I'm not sure if Alexey's patch [1] illustates your idea. It calls > > tsm_tdi_bind() which directly does device stuff, and impacts MMIO. > > VFIO doesn't know about this. > > > > I have to interpret this as VFIO firstly hand over device CC features > > and MMIO resources to IOMMUFD, so VFIO never cares about them. > > > > [1] https://lore.kernel.org/all/20250218111017.491719-15-...@amd.com/ > > There is also the PCI layer involved here and maybe PCI should be > participating in managing some of this. Like it makes a bit of sense > that PCI would block the FLR on platforms that require this? FLR to a bound device is absolutely fine, just break the CC state. Sometimes it is exactly what host need to stop CC immediately. The problem is in VFIO's pre-FLR handling so we need to patch VFIO, not PCI core. Thanks, Yilun > > Jason