diff options
Diffstat (limited to 'drivers/gpu/drm/drm_gem_atomic_helper.c')
| -rw-r--r-- | drivers/gpu/drm/drm_gem_atomic_helper.c | 14 | 
1 files changed, 12 insertions, 2 deletions
diff --git a/drivers/gpu/drm/drm_gem_atomic_helper.c b/drivers/gpu/drm/drm_gem_atomic_helper.c index e570398abd78..c3189afe10cb 100644 --- a/drivers/gpu/drm/drm_gem_atomic_helper.c +++ b/drivers/gpu/drm/drm_gem_atomic_helper.c @@ -143,6 +143,7 @@   */  int drm_gem_plane_helper_prepare_fb(struct drm_plane *plane, struct drm_plane_state *state)  { +	struct dma_resv_iter cursor;  	struct drm_gem_object *obj;  	struct dma_fence *fence; @@ -150,9 +151,18 @@ int drm_gem_plane_helper_prepare_fb(struct drm_plane *plane, struct drm_plane_st  		return 0;  	obj = drm_gem_fb_get_obj(state->fb, 0); -	fence = dma_resv_get_excl_unlocked(obj->resv); -	drm_atomic_set_fence_for_plane(state, fence); +	dma_resv_iter_begin(&cursor, obj->resv, false); +	dma_resv_for_each_fence_unlocked(&cursor, fence) { +		/* TODO: Currently there should be only one write fence, so this +		 * here works fine. But drm_atomic_set_fence_for_plane() should +		 * be changed to be able to handle more fences in general for +		 * multiple BOs per fb anyway. */ +		dma_fence_get(fence); +		break; +	} +	dma_resv_iter_end(&cursor); +	drm_atomic_set_fence_for_plane(state, fence);  	return 0;  }  EXPORT_SYMBOL_GPL(drm_gem_plane_helper_prepare_fb);  |