From: Christian König Date: Thu, 15 Mar 2018 15:48:20 +0000 (+0100) Subject: drm/ttm: remove the backing store if no placement is given X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=d2588d2ded0f3ac4a955cc92f6e665a2928bf4d6;p=uclinux-h8%2Flinux.git drm/ttm: remove the backing store if no placement is given Pipeline removal of the BOs backing store when no placement is given during validation. Signed-off-by: Christian König Acked-by: Daniel Vetter Link: https://patchwork.freedesktop.org/patch/353994/?series=73646&rev=1 --- diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c index 151edfd8de77..6d1e91be9c78 100644 --- a/drivers/gpu/drm/ttm/ttm_bo.c +++ b/drivers/gpu/drm/ttm/ttm_bo.c @@ -1196,6 +1196,18 @@ int ttm_bo_validate(struct ttm_buffer_object *bo, uint32_t new_flags; dma_resv_assert_held(bo->base.resv); + + /* + * Remove the backing store if no placement is given. + */ + if (!placement->num_placement && !placement->num_busy_placement) { + ret = ttm_bo_pipeline_gutting(bo); + if (ret) + return ret; + + return ttm_tt_create(bo, false); + } + /* * Check whether we need to move buffer. */