mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	iommu/amd: Add missing domain type checks
Drivers are supposed to list the domain types they support in their
domain_alloc() ops so when we add new domain types, like BLOCKING or SVA,
they don't start breaking.
This ended up providing an empty UNMANAGED domain when the core code asked
for a BLOCKING domain, which happens to be the fallback for drivers that
don't support it, but this is completely wrong for SVA.
Check for the DMA types AMD supports and reject every other kind.
Fixes: 136467962e ("iommu: Add IOMMU SVA domain support")
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
Reviewed-by: Vasant Hegde <vasant.hegde@amd.com>
Reviewed-by: Kevin Tian <kevin.tian@intel.com>
Link: https://lore.kernel.org/r/0-v1-2ac37b893728+da-amd_check_types_jgg@nvidia.com
Signed-off-by: Joerg Roedel <jroedel@suse.de>
			
			
This commit is contained in:
		
							parent
							
								
									8ec4e2befe
								
							
						
					
					
						commit
						29f54745f2
					
				| @ -2074,7 +2074,7 @@ static struct protection_domain *protection_domain_alloc(unsigned int type) | ||||
| { | ||||
| 	struct io_pgtable_ops *pgtbl_ops; | ||||
| 	struct protection_domain *domain; | ||||
| 	int pgtable = amd_iommu_pgtable; | ||||
| 	int pgtable; | ||||
| 	int mode = DEFAULT_PGTABLE_LEVEL; | ||||
| 	int ret; | ||||
| 
 | ||||
| @ -2091,6 +2091,10 @@ static struct protection_domain *protection_domain_alloc(unsigned int type) | ||||
| 		mode = PAGE_MODE_NONE; | ||||
| 	} else if (type == IOMMU_DOMAIN_UNMANAGED) { | ||||
| 		pgtable = AMD_IOMMU_V1; | ||||
| 	} else if (type == IOMMU_DOMAIN_DMA || type == IOMMU_DOMAIN_DMA_FQ) { | ||||
| 		pgtable = amd_iommu_pgtable; | ||||
| 	} else { | ||||
| 		return NULL; | ||||
| 	} | ||||
| 
 | ||||
| 	switch (pgtable) { | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Jason Gunthorpe
						Jason Gunthorpe