aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/gpu/drm/ttm/ttm_page_alloc_dma.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c b/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
index 6c06d0b601f9..156ddcd304c3 100644
--- a/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
+++ b/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
@@ -949,7 +949,7 @@ void ttm_dma_unpopulate(struct ttm_dma_tt *ttm_dma, struct device *dev)
949 struct dma_page *d_page, *next; 949 struct dma_page *d_page, *next;
950 enum pool_type type; 950 enum pool_type type;
951 bool is_cached = false; 951 bool is_cached = false;
952 unsigned count = 0, i; 952 unsigned count = 0, i, npages = 0;
953 unsigned long irq_flags; 953 unsigned long irq_flags;
954 954
955 type = ttm_to_type(ttm->page_flags, ttm->caching_state); 955 type = ttm_to_type(ttm->page_flags, ttm->caching_state);
@@ -974,8 +974,13 @@ void ttm_dma_unpopulate(struct ttm_dma_tt *ttm_dma, struct device *dev)
974 } else { 974 } else {
975 pool->npages_free += count; 975 pool->npages_free += count;
976 list_splice(&ttm_dma->pages_list, &pool->free_list); 976 list_splice(&ttm_dma->pages_list, &pool->free_list);
977 npages = count;
977 if (pool->npages_free > _manager->options.max_size) { 978 if (pool->npages_free > _manager->options.max_size) {
978 count = pool->npages_free - _manager->options.max_size; 979 npages = pool->npages_free - _manager->options.max_size;
980 /* free at least NUM_PAGES_TO_ALLOC number of pages
981 * to reduce calls to set_memory_wb */
982 if (npages < NUM_PAGES_TO_ALLOC)
983 npages = NUM_PAGES_TO_ALLOC;
979 } 984 }
980 } 985 }
981 spin_unlock_irqrestore(&pool->lock, irq_flags); 986 spin_unlock_irqrestore(&pool->lock, irq_flags);
@@ -999,9 +1004,9 @@ void ttm_dma_unpopulate(struct ttm_dma_tt *ttm_dma, struct device *dev)
999 ttm_dma->dma_address[i] = 0; 1004 ttm_dma->dma_address[i] = 0;
1000 } 1005 }
1001 1006
1002 /* shrink pool if necessary */ 1007 /* shrink pool if necessary (only on !is_cached pools)*/
1003 if (count) 1008 if (npages)
1004 ttm_dma_page_pool_free(pool, count); 1009 ttm_dma_page_pool_free(pool, npages);
1005 ttm->state = tt_unpopulated; 1010 ttm->state = tt_unpopulated;
1006} 1011}
1007EXPORT_SYMBOL_GPL(ttm_dma_unpopulate); 1012EXPORT_SYMBOL_GPL(ttm_dma_unpopulate);