drm/vmwgfx: don't use ttm bo->offset
Calculate GPU offset within vmwgfx driver itself without depending on bo->offset. Signed-off-by: Nirmoy Das <nirmoy.das@amd.com> Acked-by: Christian König <christian.koenig@amd.com> Link: https://patchwork.freedesktop.org/patch/372933/ Signed-off-by: Christian König <christian.koenig@amd.com>
This commit is contained in:
parent
fbd12537b0
commit
0b17fc08e3
@ -258,7 +258,7 @@ int vmw_bo_pin_in_start_of_vram(struct vmw_private *dev_priv,
|
|||||||
ret = ttm_bo_validate(bo, &placement, &ctx);
|
ret = ttm_bo_validate(bo, &placement, &ctx);
|
||||||
|
|
||||||
/* For some reason we didn't end up at the start of vram */
|
/* For some reason we didn't end up at the start of vram */
|
||||||
WARN_ON(ret == 0 && bo->offset != 0);
|
WARN_ON(ret == 0 && bo->mem.start != 0);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
vmw_bo_pin_reserved(buf, true);
|
vmw_bo_pin_reserved(buf, true);
|
||||||
|
|
||||||
@ -317,7 +317,7 @@ void vmw_bo_get_guest_ptr(const struct ttm_buffer_object *bo,
|
|||||||
{
|
{
|
||||||
if (bo->mem.mem_type == TTM_PL_VRAM) {
|
if (bo->mem.mem_type == TTM_PL_VRAM) {
|
||||||
ptr->gmrId = SVGA_GMR_FRAMEBUFFER;
|
ptr->gmrId = SVGA_GMR_FRAMEBUFFER;
|
||||||
ptr->offset = bo->offset;
|
ptr->offset = bo->mem.start << PAGE_SHIFT;
|
||||||
} else {
|
} else {
|
||||||
ptr->gmrId = bo->mem.start;
|
ptr->gmrId = bo->mem.start;
|
||||||
ptr->offset = 0;
|
ptr->offset = 0;
|
||||||
|
@ -3696,7 +3696,7 @@ static void vmw_apply_relocations(struct vmw_sw_context *sw_context)
|
|||||||
bo = &reloc->vbo->base;
|
bo = &reloc->vbo->base;
|
||||||
switch (bo->mem.mem_type) {
|
switch (bo->mem.mem_type) {
|
||||||
case TTM_PL_VRAM:
|
case TTM_PL_VRAM:
|
||||||
reloc->location->offset += bo->offset;
|
reloc->location->offset += bo->mem.start << PAGE_SHIFT;
|
||||||
reloc->location->gmrId = SVGA_GMR_FRAMEBUFFER;
|
reloc->location->gmrId = SVGA_GMR_FRAMEBUFFER;
|
||||||
break;
|
break;
|
||||||
case VMW_PL_GMR:
|
case VMW_PL_GMR:
|
||||||
|
@ -610,7 +610,7 @@ static int vmw_fifo_emit_dummy_legacy_query(struct vmw_private *dev_priv,
|
|||||||
|
|
||||||
if (bo->mem.mem_type == TTM_PL_VRAM) {
|
if (bo->mem.mem_type == TTM_PL_VRAM) {
|
||||||
cmd->body.guestResult.gmrId = SVGA_GMR_FRAMEBUFFER;
|
cmd->body.guestResult.gmrId = SVGA_GMR_FRAMEBUFFER;
|
||||||
cmd->body.guestResult.offset = bo->offset;
|
cmd->body.guestResult.offset = bo->mem.start << PAGE_SHIFT;
|
||||||
} else {
|
} else {
|
||||||
cmd->body.guestResult.gmrId = bo->mem.start;
|
cmd->body.guestResult.gmrId = bo->mem.start;
|
||||||
cmd->body.guestResult.offset = 0;
|
cmd->body.guestResult.offset = 0;
|
||||||
|
@ -750,7 +750,6 @@ static int vmw_init_mem_type(struct ttm_bo_device *bdev, uint32_t type,
|
|||||||
case TTM_PL_VRAM:
|
case TTM_PL_VRAM:
|
||||||
/* "On-card" video ram */
|
/* "On-card" video ram */
|
||||||
man->func = &vmw_thp_func;
|
man->func = &vmw_thp_func;
|
||||||
man->gpu_offset = 0;
|
|
||||||
man->flags = TTM_MEMTYPE_FLAG_FIXED | TTM_MEMTYPE_FLAG_MAPPABLE;
|
man->flags = TTM_MEMTYPE_FLAG_FIXED | TTM_MEMTYPE_FLAG_MAPPABLE;
|
||||||
man->available_caching = TTM_PL_FLAG_CACHED;
|
man->available_caching = TTM_PL_FLAG_CACHED;
|
||||||
man->default_caching = TTM_PL_FLAG_CACHED;
|
man->default_caching = TTM_PL_FLAG_CACHED;
|
||||||
@ -763,7 +762,6 @@ static int vmw_init_mem_type(struct ttm_bo_device *bdev, uint32_t type,
|
|||||||
* slots as well as the bo size.
|
* slots as well as the bo size.
|
||||||
*/
|
*/
|
||||||
man->func = &vmw_gmrid_manager_func;
|
man->func = &vmw_gmrid_manager_func;
|
||||||
man->gpu_offset = 0;
|
|
||||||
man->flags = TTM_MEMTYPE_FLAG_CMA | TTM_MEMTYPE_FLAG_MAPPABLE;
|
man->flags = TTM_MEMTYPE_FLAG_CMA | TTM_MEMTYPE_FLAG_MAPPABLE;
|
||||||
man->available_caching = TTM_PL_FLAG_CACHED;
|
man->available_caching = TTM_PL_FLAG_CACHED;
|
||||||
man->default_caching = TTM_PL_FLAG_CACHED;
|
man->default_caching = TTM_PL_FLAG_CACHED;
|
||||||
|
Loading…
Reference in New Issue
Block a user