mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-03-17 04:34:07 +00:00
drm/vmwgfx: Fix an invalid read
[ Upstream commit10a26e0d5f
] vmw_move assumed that buffers to be moved would always be vmw_buffer_object's but after introduction of new placement for mob pages that's no longer the case. The resulting invalid read didn't have any practical consequences because the memory isn't used unless the object actually is a vmw_buffer_object. Fix it by moving the cast to the spot where the results are used. Signed-off-by: Zack Rusin <zackr@vmware.com> Fixes:f6be23264b
("drm/vmwgfx: Introduce a new placement for MOB page tables") Reported-by: Chuck Lever III <chuck.lever@oracle.com> Reviewed-by: Martin Krastev <krastevm@vmware.com> Tested-by: Chuck Lever <chuck.lever@oracle.com> Link: https://patchwork.freedesktop.org/patch/msgid/20220318174332.440068-2-zack@kde.org Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
e5f4aa0170
commit
055fc180c5
1 changed files with 6 additions and 8 deletions
|
@ -862,22 +862,21 @@ void vmw_query_move_notify(struct ttm_buffer_object *bo,
|
|||
struct ttm_device *bdev = bo->bdev;
|
||||
struct vmw_private *dev_priv;
|
||||
|
||||
|
||||
dev_priv = container_of(bdev, struct vmw_private, bdev);
|
||||
|
||||
mutex_lock(&dev_priv->binding_mutex);
|
||||
|
||||
dx_query_mob = container_of(bo, struct vmw_buffer_object, base);
|
||||
if (!dx_query_mob || !dx_query_mob->dx_query_ctx) {
|
||||
mutex_unlock(&dev_priv->binding_mutex);
|
||||
return;
|
||||
}
|
||||
|
||||
/* If BO is being moved from MOB to system memory */
|
||||
if (new_mem->mem_type == TTM_PL_SYSTEM &&
|
||||
old_mem->mem_type == VMW_PL_MOB) {
|
||||
struct vmw_fence_obj *fence;
|
||||
|
||||
dx_query_mob = container_of(bo, struct vmw_buffer_object, base);
|
||||
if (!dx_query_mob || !dx_query_mob->dx_query_ctx) {
|
||||
mutex_unlock(&dev_priv->binding_mutex);
|
||||
return;
|
||||
}
|
||||
|
||||
(void) vmw_query_readback_all(dx_query_mob);
|
||||
mutex_unlock(&dev_priv->binding_mutex);
|
||||
|
||||
|
@ -891,7 +890,6 @@ void vmw_query_move_notify(struct ttm_buffer_object *bo,
|
|||
(void) ttm_bo_wait(bo, false, false);
|
||||
} else
|
||||
mutex_unlock(&dev_priv->binding_mutex);
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Add table
Reference in a new issue