iommu: Add I/O ASID allocator
authorJean-Philippe Brucker <jean-philippe.brucker@arm.com>
Wed, 2 Oct 2019 19:42:41 +0000 (12:42 -0700)
committerJoerg Roedel <jroedel@suse.de>
Tue, 15 Oct 2019 11:34:16 +0000 (13:34 +0200)
commitfa83433c92e340822a056a610a4fa2063a3db304
tree86c9acdf47a699b5dc9546bb02bb58424048ed9d
parent4c7c171f85b261f91270d405b7c7390aa6ddfb60
iommu: Add I/O ASID allocator

Some devices might support multiple DMA address spaces, in particular
those that have the PCI PASID feature. PASID (Process Address Space ID)
allows to share process address spaces with devices (SVA), partition a
device into VM-assignable entities (VFIO mdev) or simply provide
multiple DMA address space to kernel drivers. Add a global PASID
allocator usable by different drivers at the same time. Name it I/O ASID
to avoid confusion with ASIDs allocated by arch code, which are usually
a separate ID space.

The IOASID space is global. Each device can have its own PASID space,
but by convention the IOMMU ended up having a global PASID space, so
that with SVA, each mm_struct is associated to a single PASID.

The allocator is primarily used by IOMMU subsystem but in rare occasions
drivers would like to allocate PASIDs for devices that aren't managed by
an IOMMU, using the same ID space as IOMMU.

Signed-off-by: Jean-Philippe Brucker <jean-philippe.brucker@arm.com>
Signed-off-by: Jacob Pan <jacob.jun.pan@linux.intel.com>
Reviewed-by: Jean-Philippe Brucker <jean-philippe@linaro.org>
Reviewed-by: Eric Auger <eric.auger@redhat.com>
Signed-off-by: Joerg Roedel <jroedel@suse.de>
drivers/iommu/Kconfig
drivers/iommu/Makefile
drivers/iommu/ioasid.c [new file with mode: 0644]
include/linux/ioasid.h [new file with mode: 0644]