diff options
-rw-r--r-- | drivers/gpu/drm/etnaviv/etnaviv_mmu.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_mmu.c b/drivers/gpu/drm/etnaviv/etnaviv_mmu.c index 169ac96e8f08..fe0e85b41310 100644 --- a/drivers/gpu/drm/etnaviv/etnaviv_mmu.c +++ b/drivers/gpu/drm/etnaviv/etnaviv_mmu.c | |||
@@ -116,9 +116,14 @@ static int etnaviv_iommu_find_iova(struct etnaviv_iommu *mmu, | |||
116 | struct list_head list; | 116 | struct list_head list; |
117 | bool found; | 117 | bool found; |
118 | 118 | ||
119 | /* | ||
120 | * XXX: The DRM_MM_SEARCH_BELOW is really a hack to trick | ||
121 | * drm_mm into giving out a low IOVA after address space | ||
122 | * rollover. This needs a proper fix. | ||
123 | */ | ||
119 | ret = drm_mm_insert_node_in_range(&mmu->mm, node, | 124 | ret = drm_mm_insert_node_in_range(&mmu->mm, node, |
120 | size, 0, mmu->last_iova, ~0UL, | 125 | size, 0, mmu->last_iova, ~0UL, |
121 | DRM_MM_SEARCH_DEFAULT); | 126 | mmu->last_iova ? DRM_MM_SEARCH_DEFAULT : DRM_MM_SEARCH_BELOW); |
122 | 127 | ||
123 | if (ret != -ENOSPC) | 128 | if (ret != -ENOSPC) |
124 | break; | 129 | break; |