On Wed, Jun 02, 2010 at 11:09:17AM -0700, Tom Lyon wrote: > On Wednesday 02 June 2010 10:46:15 am Chris Wright wrote: > > This is not any hot path, so saving an ioctl shouldn't be a consideration. > > Only important consideration is a good API. I may have lost context here, > > but the SHARE API is limited to the vfio fd. The BIND API expects a new > > iommu object. Are there other uses for this object? Tom's current vfio > > driver exposes a dma mapping interface, would the iommu object expose > > one as well? Current interface is device specific DMA interface for > > host device drivers typically mapping in-flight dma buffers, and IOMMU > > specific interface for assigned devices typically mapping entire virtual > > address space. > > Actually, it a domain object - which may be usable among iommus (Joerg?). Yes, this 'iommu' thing is would be a domain object. But sharing among iommus is not necessary because the fact that there are multiple iommus in the system is hidden by the iommu drivers. This fact is not even exposed by the iommu-api. This makes protection domains system global. > However, you can't really do the dma mapping with just the domain because > every device supports a different size address space as a master, i.e., > the dma_mask. The dma_mask has to be handled by the device driver. With the iommu-mapping interface the driver can specify the target io-address and has to consider the dma_mask for that too. > And I don't know how kvm would deal with devices with varying dma mask support, > or why they'd be in the same domain. KVM does not care about these masks. This is the business of the guest device drivers. Joerg -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html