mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	drm/msm: Only enable A6xx LLCC code on A6xx
Using this code on A5xx (and probably older too) causes a
smmu bug.
Fixes: 474dadb8b0 ("drm/msm/a6xx: Add support for using system cache(LLC)")
Signed-off-by: Konrad Dybcio <konrad.dybcio@somainline.org>
Tested-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@somainline.org>
Reviewed-by: Jordan Crouse <jcrouse@codeaurora.org>
Reviewed-by: Sai Prakash Ranjan <saiprakash.ranjan@codeaurora.org>
Signed-off-by: Rob Clark <robdclark@chromium.org>
			
			
This commit is contained in:
		
							parent
							
								
									3f7759e7b7
								
							
						
					
					
						commit
						00fd44a1a4
					
				| @ -191,8 +191,6 @@ adreno_iommu_create_address_space(struct msm_gpu *gpu, | |||||||
| 		struct platform_device *pdev) | 		struct platform_device *pdev) | ||||||
| { | { | ||||||
| 	struct adreno_gpu *adreno_gpu = to_adreno_gpu(gpu); | 	struct adreno_gpu *adreno_gpu = to_adreno_gpu(gpu); | ||||||
| 	struct a6xx_gpu *a6xx_gpu = to_a6xx_gpu(adreno_gpu); |  | ||||||
| 	struct io_pgtable_domain_attr pgtbl_cfg; |  | ||||||
| 	struct iommu_domain *iommu; | 	struct iommu_domain *iommu; | ||||||
| 	struct msm_mmu *mmu; | 	struct msm_mmu *mmu; | ||||||
| 	struct msm_gem_address_space *aspace; | 	struct msm_gem_address_space *aspace; | ||||||
| @ -202,13 +200,18 @@ adreno_iommu_create_address_space(struct msm_gpu *gpu, | |||||||
| 	if (!iommu) | 	if (!iommu) | ||||||
| 		return NULL; | 		return NULL; | ||||||
| 
 | 
 | ||||||
| 	/*
 | 
 | ||||||
| 	 * This allows GPU to set the bus attributes required to use system | 	if (adreno_is_a6xx(adreno_gpu)) { | ||||||
| 	 * cache on behalf of the iommu page table walker. | 		struct a6xx_gpu *a6xx_gpu = to_a6xx_gpu(adreno_gpu); | ||||||
| 	 */ | 		struct io_pgtable_domain_attr pgtbl_cfg; | ||||||
| 	if (!IS_ERR(a6xx_gpu->htw_llc_slice)) { | 		/*
 | ||||||
| 		pgtbl_cfg.quirks = IO_PGTABLE_QUIRK_ARM_OUTER_WBWA; | 		* This allows GPU to set the bus attributes required to use system | ||||||
| 		iommu_domain_set_attr(iommu, DOMAIN_ATTR_IO_PGTABLE_CFG, &pgtbl_cfg); | 		* cache on behalf of the iommu page table walker. | ||||||
|  | 		*/ | ||||||
|  | 		if (!IS_ERR(a6xx_gpu->htw_llc_slice)) { | ||||||
|  | 			pgtbl_cfg.quirks = IO_PGTABLE_QUIRK_ARM_OUTER_WBWA; | ||||||
|  | 			iommu_domain_set_attr(iommu, DOMAIN_ATTR_IO_PGTABLE_CFG, &pgtbl_cfg); | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	mmu = msm_iommu_new(&pdev->dev, iommu); | 	mmu = msm_iommu_new(&pdev->dev, iommu); | ||||||
|  | |||||||
| @ -212,6 +212,11 @@ static inline int adreno_is_a540(struct adreno_gpu *gpu) | |||||||
| 	return gpu->revn == 540; | 	return gpu->revn == 540; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static inline bool adreno_is_a6xx(struct adreno_gpu *gpu) | ||||||
|  | { | ||||||
|  | 	return ((gpu->revn < 700 && gpu->revn > 599)); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| static inline int adreno_is_a618(struct adreno_gpu *gpu) | static inline int adreno_is_a618(struct adreno_gpu *gpu) | ||||||
| { | { | ||||||
|        return gpu->revn == 618; |        return gpu->revn == 618; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Konrad Dybcio
						Konrad Dybcio