diff options
Diffstat (limited to 'drivers/gpu/drm/drm_mm.c')
| -rw-r--r-- | drivers/gpu/drm/drm_mm.c | 21 | 
1 files changed, 18 insertions, 3 deletions
| diff --git a/drivers/gpu/drm/drm_mm.c b/drivers/gpu/drm/drm_mm.c index 186c4e90cc1c..89eef1bb4ddc 100644 --- a/drivers/gpu/drm/drm_mm.c +++ b/drivers/gpu/drm/drm_mm.c @@ -836,9 +836,24 @@ struct drm_mm_node *drm_mm_scan_color_evict(struct drm_mm_scan *scan)  	if (!mm->color_adjust)  		return NULL; -	hole = list_first_entry(&mm->hole_stack, typeof(*hole), hole_stack); -	hole_start = __drm_mm_hole_node_start(hole); -	hole_end = hole_start + hole->hole_size; +	/* +	 * The hole found during scanning should ideally be the first element +	 * in the hole_stack list, but due to side-effects in the driver it +	 * may not be. +	 */ +	list_for_each_entry(hole, &mm->hole_stack, hole_stack) { +		hole_start = __drm_mm_hole_node_start(hole); +		hole_end = hole_start + hole->hole_size; + +		if (hole_start <= scan->hit_start && +		    hole_end >= scan->hit_end) +			break; +	} + +	/* We should only be called after we found the hole previously */ +	DRM_MM_BUG_ON(&hole->hole_stack == &mm->hole_stack); +	if (unlikely(&hole->hole_stack == &mm->hole_stack)) +		return NULL;  	DRM_MM_BUG_ON(hole_start > scan->hit_start);  	DRM_MM_BUG_ON(hole_end < scan->hit_end); |