mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-17 02:36:21 +00:00
drm/ttm: rename bo->mem and make it a pointer
When we want to decouble resource management from buffer management we need to be able to handle resources separately. Add a resource pointer and rename bo->mem so that all code needs to change to access the pointer instead. No functional change. Signed-off-by: Christian König <christian.koenig@amd.com> Reviewed-by: Matthew Auld <matthew.auld@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20210430092508.60710-4-christian.koenig@amd.com
This commit is contained in:
parent
9450129ed9
commit
d3116756a7
@ -1666,7 +1666,7 @@ int amdgpu_amdkfd_gpuvm_map_memory_to_gpu(
|
|||||||
* the next restore worker
|
* the next restore worker
|
||||||
*/
|
*/
|
||||||
if (amdgpu_ttm_tt_get_usermm(bo->tbo.ttm) &&
|
if (amdgpu_ttm_tt_get_usermm(bo->tbo.ttm) &&
|
||||||
bo->tbo.mem.mem_type == TTM_PL_SYSTEM)
|
bo->tbo.resource->mem_type == TTM_PL_SYSTEM)
|
||||||
is_invalid_userptr = true;
|
is_invalid_userptr = true;
|
||||||
|
|
||||||
ret = vm_validate_pt_pd_bos(avm);
|
ret = vm_validate_pt_pd_bos(avm);
|
||||||
|
@ -4103,9 +4103,9 @@ static int amdgpu_device_recover_vram(struct amdgpu_device *adev)
|
|||||||
list_for_each_entry(shadow, &adev->shadow_list, shadow_list) {
|
list_for_each_entry(shadow, &adev->shadow_list, shadow_list) {
|
||||||
|
|
||||||
/* No need to recover an evicted BO */
|
/* No need to recover an evicted BO */
|
||||||
if (shadow->tbo.mem.mem_type != TTM_PL_TT ||
|
if (shadow->tbo.resource->mem_type != TTM_PL_TT ||
|
||||||
shadow->tbo.mem.start == AMDGPU_BO_INVALID_OFFSET ||
|
shadow->tbo.resource->start == AMDGPU_BO_INVALID_OFFSET ||
|
||||||
shadow->parent->tbo.mem.mem_type != TTM_PL_VRAM)
|
shadow->parent->tbo.resource->mem_type != TTM_PL_VRAM)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
r = amdgpu_bo_restore_shadow(shadow, &next);
|
r = amdgpu_bo_restore_shadow(shadow, &next);
|
||||||
|
@ -226,12 +226,12 @@ static struct sg_table *amdgpu_dma_buf_map(struct dma_buf_attachment *attach,
|
|||||||
if (r)
|
if (r)
|
||||||
return ERR_PTR(r);
|
return ERR_PTR(r);
|
||||||
|
|
||||||
} else if (!(amdgpu_mem_type_to_domain(bo->tbo.mem.mem_type) &
|
} else if (!(amdgpu_mem_type_to_domain(bo->tbo.resource->mem_type) &
|
||||||
AMDGPU_GEM_DOMAIN_GTT)) {
|
AMDGPU_GEM_DOMAIN_GTT)) {
|
||||||
return ERR_PTR(-EBUSY);
|
return ERR_PTR(-EBUSY);
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (bo->tbo.mem.mem_type) {
|
switch (bo->tbo.resource->mem_type) {
|
||||||
case TTM_PL_TT:
|
case TTM_PL_TT:
|
||||||
sgt = drm_prime_pages_to_sg(obj->dev,
|
sgt = drm_prime_pages_to_sg(obj->dev,
|
||||||
bo->tbo.ttm->pages,
|
bo->tbo.ttm->pages,
|
||||||
@ -245,8 +245,9 @@ static struct sg_table *amdgpu_dma_buf_map(struct dma_buf_attachment *attach,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case TTM_PL_VRAM:
|
case TTM_PL_VRAM:
|
||||||
r = amdgpu_vram_mgr_alloc_sgt(adev, &bo->tbo.mem, 0,
|
r = amdgpu_vram_mgr_alloc_sgt(adev, bo->tbo.resource, 0,
|
||||||
bo->tbo.base.size, attach->dev, dir, &sgt);
|
bo->tbo.base.size, attach->dev,
|
||||||
|
dir, &sgt);
|
||||||
if (r)
|
if (r)
|
||||||
return ERR_PTR(r);
|
return ERR_PTR(r);
|
||||||
break;
|
break;
|
||||||
@ -436,7 +437,7 @@ amdgpu_dma_buf_move_notify(struct dma_buf_attachment *attach)
|
|||||||
struct amdgpu_vm_bo_base *bo_base;
|
struct amdgpu_vm_bo_base *bo_base;
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
if (bo->tbo.mem.mem_type == TTM_PL_SYSTEM)
|
if (bo->tbo.resource->mem_type == TTM_PL_SYSTEM)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
r = ttm_bo_validate(&bo->tbo, &placement, &ctx);
|
r = ttm_bo_validate(&bo->tbo, &placement, &ctx);
|
||||||
|
@ -101,7 +101,7 @@ void amdgpu_gmc_get_pde_for_bo(struct amdgpu_bo *bo, int level,
|
|||||||
{
|
{
|
||||||
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->tbo.bdev);
|
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->tbo.bdev);
|
||||||
|
|
||||||
switch (bo->tbo.mem.mem_type) {
|
switch (bo->tbo.resource->mem_type) {
|
||||||
case TTM_PL_TT:
|
case TTM_PL_TT:
|
||||||
*addr = bo->tbo.ttm->dma_address[0];
|
*addr = bo->tbo.ttm->dma_address[0];
|
||||||
break;
|
break;
|
||||||
@ -112,7 +112,7 @@ void amdgpu_gmc_get_pde_for_bo(struct amdgpu_bo *bo, int level,
|
|||||||
*addr = 0;
|
*addr = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
*flags = amdgpu_ttm_tt_pde_flags(bo->tbo.ttm, &bo->tbo.mem);
|
*flags = amdgpu_ttm_tt_pde_flags(bo->tbo.ttm, bo->tbo.resource);
|
||||||
amdgpu_gmc_get_vm_pde(adev, level, addr, flags);
|
amdgpu_gmc_get_vm_pde(adev, level, addr, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -122,7 +122,7 @@ static int amdgpu_gtt_mgr_new(struct ttm_resource_manager *man,
|
|||||||
int r;
|
int r;
|
||||||
|
|
||||||
spin_lock(&mgr->lock);
|
spin_lock(&mgr->lock);
|
||||||
if ((&tbo->mem == mem || tbo->mem.mem_type != TTM_PL_TT) &&
|
if ((tbo->resource == mem || tbo->resource->mem_type != TTM_PL_TT) &&
|
||||||
atomic64_read(&mgr->available) < mem->num_pages) {
|
atomic64_read(&mgr->available) < mem->num_pages) {
|
||||||
spin_unlock(&mgr->lock);
|
spin_unlock(&mgr->lock);
|
||||||
return -ENOSPC;
|
return -ENOSPC;
|
||||||
|
@ -362,14 +362,14 @@ int amdgpu_bo_create_kernel_at(struct amdgpu_device *adev,
|
|||||||
if (cpu_addr)
|
if (cpu_addr)
|
||||||
amdgpu_bo_kunmap(*bo_ptr);
|
amdgpu_bo_kunmap(*bo_ptr);
|
||||||
|
|
||||||
ttm_resource_free(&(*bo_ptr)->tbo, &(*bo_ptr)->tbo.mem);
|
ttm_resource_free(&(*bo_ptr)->tbo, (*bo_ptr)->tbo.resource);
|
||||||
|
|
||||||
for (i = 0; i < (*bo_ptr)->placement.num_placement; ++i) {
|
for (i = 0; i < (*bo_ptr)->placement.num_placement; ++i) {
|
||||||
(*bo_ptr)->placements[i].fpfn = offset >> PAGE_SHIFT;
|
(*bo_ptr)->placements[i].fpfn = offset >> PAGE_SHIFT;
|
||||||
(*bo_ptr)->placements[i].lpfn = (offset + size) >> PAGE_SHIFT;
|
(*bo_ptr)->placements[i].lpfn = (offset + size) >> PAGE_SHIFT;
|
||||||
}
|
}
|
||||||
r = ttm_bo_mem_space(&(*bo_ptr)->tbo, &(*bo_ptr)->placement,
|
r = ttm_bo_mem_space(&(*bo_ptr)->tbo, &(*bo_ptr)->placement,
|
||||||
&(*bo_ptr)->tbo.mem, &ctx);
|
(*bo_ptr)->tbo.resource, &ctx);
|
||||||
if (r)
|
if (r)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
@ -573,15 +573,15 @@ int amdgpu_bo_create(struct amdgpu_device *adev,
|
|||||||
return r;
|
return r;
|
||||||
|
|
||||||
if (!amdgpu_gmc_vram_full_visible(&adev->gmc) &&
|
if (!amdgpu_gmc_vram_full_visible(&adev->gmc) &&
|
||||||
bo->tbo.mem.mem_type == TTM_PL_VRAM &&
|
bo->tbo.resource->mem_type == TTM_PL_VRAM &&
|
||||||
bo->tbo.mem.start < adev->gmc.visible_vram_size >> PAGE_SHIFT)
|
bo->tbo.resource->start < adev->gmc.visible_vram_size >> PAGE_SHIFT)
|
||||||
amdgpu_cs_report_moved_bytes(adev, ctx.bytes_moved,
|
amdgpu_cs_report_moved_bytes(adev, ctx.bytes_moved,
|
||||||
ctx.bytes_moved);
|
ctx.bytes_moved);
|
||||||
else
|
else
|
||||||
amdgpu_cs_report_moved_bytes(adev, ctx.bytes_moved, 0);
|
amdgpu_cs_report_moved_bytes(adev, ctx.bytes_moved, 0);
|
||||||
|
|
||||||
if (bp->flags & AMDGPU_GEM_CREATE_VRAM_CLEARED &&
|
if (bp->flags & AMDGPU_GEM_CREATE_VRAM_CLEARED &&
|
||||||
bo->tbo.mem.mem_type == TTM_PL_VRAM) {
|
bo->tbo.resource->mem_type == TTM_PL_VRAM) {
|
||||||
struct dma_fence *fence;
|
struct dma_fence *fence;
|
||||||
|
|
||||||
r = amdgpu_fill_buffer(bo, 0, bo->tbo.base.resv, &fence);
|
r = amdgpu_fill_buffer(bo, 0, bo->tbo.base.resv, &fence);
|
||||||
@ -761,7 +761,7 @@ int amdgpu_bo_kmap(struct amdgpu_bo *bo, void **ptr)
|
|||||||
if (r < 0)
|
if (r < 0)
|
||||||
return r;
|
return r;
|
||||||
|
|
||||||
r = ttm_bo_kmap(&bo->tbo, 0, bo->tbo.mem.num_pages, &bo->kmap);
|
r = ttm_bo_kmap(&bo->tbo, 0, bo->tbo.resource->num_pages, &bo->kmap);
|
||||||
if (r)
|
if (r)
|
||||||
return r;
|
return r;
|
||||||
|
|
||||||
@ -884,8 +884,8 @@ int amdgpu_bo_pin_restricted(struct amdgpu_bo *bo, u32 domain,
|
|||||||
domain = amdgpu_bo_get_preferred_pin_domain(adev, domain);
|
domain = amdgpu_bo_get_preferred_pin_domain(adev, domain);
|
||||||
|
|
||||||
if (bo->tbo.pin_count) {
|
if (bo->tbo.pin_count) {
|
||||||
uint32_t mem_type = bo->tbo.mem.mem_type;
|
uint32_t mem_type = bo->tbo.resource->mem_type;
|
||||||
uint32_t mem_flags = bo->tbo.mem.placement;
|
uint32_t mem_flags = bo->tbo.resource->placement;
|
||||||
|
|
||||||
if (!(domain & amdgpu_mem_type_to_domain(mem_type)))
|
if (!(domain & amdgpu_mem_type_to_domain(mem_type)))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -935,7 +935,7 @@ int amdgpu_bo_pin_restricted(struct amdgpu_bo *bo, u32 domain,
|
|||||||
|
|
||||||
ttm_bo_pin(&bo->tbo);
|
ttm_bo_pin(&bo->tbo);
|
||||||
|
|
||||||
domain = amdgpu_mem_type_to_domain(bo->tbo.mem.mem_type);
|
domain = amdgpu_mem_type_to_domain(bo->tbo.resource->mem_type);
|
||||||
if (domain == AMDGPU_GEM_DOMAIN_VRAM) {
|
if (domain == AMDGPU_GEM_DOMAIN_VRAM) {
|
||||||
atomic64_add(amdgpu_bo_size(bo), &adev->vram_pin_size);
|
atomic64_add(amdgpu_bo_size(bo), &adev->vram_pin_size);
|
||||||
atomic64_add(amdgpu_vram_mgr_bo_visible_size(bo),
|
atomic64_add(amdgpu_vram_mgr_bo_visible_size(bo),
|
||||||
@ -987,11 +987,11 @@ void amdgpu_bo_unpin(struct amdgpu_bo *bo)
|
|||||||
if (bo->tbo.base.import_attach)
|
if (bo->tbo.base.import_attach)
|
||||||
dma_buf_unpin(bo->tbo.base.import_attach);
|
dma_buf_unpin(bo->tbo.base.import_attach);
|
||||||
|
|
||||||
if (bo->tbo.mem.mem_type == TTM_PL_VRAM) {
|
if (bo->tbo.resource->mem_type == TTM_PL_VRAM) {
|
||||||
atomic64_sub(amdgpu_bo_size(bo), &adev->vram_pin_size);
|
atomic64_sub(amdgpu_bo_size(bo), &adev->vram_pin_size);
|
||||||
atomic64_sub(amdgpu_vram_mgr_bo_visible_size(bo),
|
atomic64_sub(amdgpu_vram_mgr_bo_visible_size(bo),
|
||||||
&adev->visible_pin_size);
|
&adev->visible_pin_size);
|
||||||
} else if (bo->tbo.mem.mem_type == TTM_PL_TT) {
|
} else if (bo->tbo.resource->mem_type == TTM_PL_TT) {
|
||||||
atomic64_sub(amdgpu_bo_size(bo), &adev->gart_pin_size);
|
atomic64_sub(amdgpu_bo_size(bo), &adev->gart_pin_size);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1223,7 +1223,7 @@ void amdgpu_bo_move_notify(struct ttm_buffer_object *bo,
|
|||||||
{
|
{
|
||||||
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->bdev);
|
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->bdev);
|
||||||
struct amdgpu_bo *abo;
|
struct amdgpu_bo *abo;
|
||||||
struct ttm_resource *old_mem = &bo->mem;
|
struct ttm_resource *old_mem = bo->resource;
|
||||||
|
|
||||||
if (!amdgpu_bo_is_amdgpu_bo(bo))
|
if (!amdgpu_bo_is_amdgpu_bo(bo))
|
||||||
return;
|
return;
|
||||||
@ -1234,7 +1234,7 @@ void amdgpu_bo_move_notify(struct ttm_buffer_object *bo,
|
|||||||
amdgpu_bo_kunmap(abo);
|
amdgpu_bo_kunmap(abo);
|
||||||
|
|
||||||
if (abo->tbo.base.dma_buf && !abo->tbo.base.import_attach &&
|
if (abo->tbo.base.dma_buf && !abo->tbo.base.import_attach &&
|
||||||
bo->mem.mem_type != TTM_PL_SYSTEM)
|
bo->resource->mem_type != TTM_PL_SYSTEM)
|
||||||
dma_buf_move_notify(abo->tbo.base.dma_buf);
|
dma_buf_move_notify(abo->tbo.base.dma_buf);
|
||||||
|
|
||||||
/* remember the eviction */
|
/* remember the eviction */
|
||||||
@ -1254,7 +1254,7 @@ void amdgpu_bo_get_memory(struct amdgpu_bo *bo, uint64_t *vram_mem,
|
|||||||
{
|
{
|
||||||
unsigned int domain;
|
unsigned int domain;
|
||||||
|
|
||||||
domain = amdgpu_mem_type_to_domain(bo->tbo.mem.mem_type);
|
domain = amdgpu_mem_type_to_domain(bo->tbo.resource->mem_type);
|
||||||
switch (domain) {
|
switch (domain) {
|
||||||
case AMDGPU_GEM_DOMAIN_VRAM:
|
case AMDGPU_GEM_DOMAIN_VRAM:
|
||||||
*vram_mem += amdgpu_bo_size(bo);
|
*vram_mem += amdgpu_bo_size(bo);
|
||||||
@ -1296,7 +1296,7 @@ void amdgpu_bo_release_notify(struct ttm_buffer_object *bo)
|
|||||||
if (bo->base.resv == &bo->base._resv)
|
if (bo->base.resv == &bo->base._resv)
|
||||||
amdgpu_amdkfd_remove_fence_on_pt_pd_bos(abo);
|
amdgpu_amdkfd_remove_fence_on_pt_pd_bos(abo);
|
||||||
|
|
||||||
if (bo->mem.mem_type != TTM_PL_VRAM || !bo->mem.mm_node ||
|
if (bo->resource->mem_type != TTM_PL_VRAM || !bo->resource->mm_node ||
|
||||||
!(abo->flags & AMDGPU_GEM_CREATE_VRAM_WIPE_ON_RELEASE))
|
!(abo->flags & AMDGPU_GEM_CREATE_VRAM_WIPE_ON_RELEASE))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -1333,10 +1333,10 @@ vm_fault_t amdgpu_bo_fault_reserve_notify(struct ttm_buffer_object *bo)
|
|||||||
/* Remember that this BO was accessed by the CPU */
|
/* Remember that this BO was accessed by the CPU */
|
||||||
abo->flags |= AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED;
|
abo->flags |= AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED;
|
||||||
|
|
||||||
if (bo->mem.mem_type != TTM_PL_VRAM)
|
if (bo->resource->mem_type != TTM_PL_VRAM)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
offset = bo->mem.start << PAGE_SHIFT;
|
offset = bo->resource->start << PAGE_SHIFT;
|
||||||
if ((offset + bo->base.size) <= adev->gmc.visible_vram_size)
|
if ((offset + bo->base.size) <= adev->gmc.visible_vram_size)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -1359,9 +1359,9 @@ vm_fault_t amdgpu_bo_fault_reserve_notify(struct ttm_buffer_object *bo)
|
|||||||
else if (unlikely(r))
|
else if (unlikely(r))
|
||||||
return VM_FAULT_SIGBUS;
|
return VM_FAULT_SIGBUS;
|
||||||
|
|
||||||
offset = bo->mem.start << PAGE_SHIFT;
|
offset = bo->resource->start << PAGE_SHIFT;
|
||||||
/* this should never happen */
|
/* this should never happen */
|
||||||
if (bo->mem.mem_type == TTM_PL_VRAM &&
|
if (bo->resource->mem_type == TTM_PL_VRAM &&
|
||||||
(offset + bo->base.size) > adev->gmc.visible_vram_size)
|
(offset + bo->base.size) > adev->gmc.visible_vram_size)
|
||||||
return VM_FAULT_SIGBUS;
|
return VM_FAULT_SIGBUS;
|
||||||
|
|
||||||
@ -1446,11 +1446,11 @@ int amdgpu_bo_sync_wait(struct amdgpu_bo *bo, void *owner, bool intr)
|
|||||||
*/
|
*/
|
||||||
u64 amdgpu_bo_gpu_offset(struct amdgpu_bo *bo)
|
u64 amdgpu_bo_gpu_offset(struct amdgpu_bo *bo)
|
||||||
{
|
{
|
||||||
WARN_ON_ONCE(bo->tbo.mem.mem_type == TTM_PL_SYSTEM);
|
WARN_ON_ONCE(bo->tbo.resource->mem_type == TTM_PL_SYSTEM);
|
||||||
WARN_ON_ONCE(!dma_resv_is_locked(bo->tbo.base.resv) &&
|
WARN_ON_ONCE(!dma_resv_is_locked(bo->tbo.base.resv) &&
|
||||||
!bo->tbo.pin_count && bo->tbo.type != ttm_bo_type_kernel);
|
!bo->tbo.pin_count && bo->tbo.type != ttm_bo_type_kernel);
|
||||||
WARN_ON_ONCE(bo->tbo.mem.start == AMDGPU_BO_INVALID_OFFSET);
|
WARN_ON_ONCE(bo->tbo.resource->start == AMDGPU_BO_INVALID_OFFSET);
|
||||||
WARN_ON_ONCE(bo->tbo.mem.mem_type == TTM_PL_VRAM &&
|
WARN_ON_ONCE(bo->tbo.resource->mem_type == TTM_PL_VRAM &&
|
||||||
!(bo->flags & AMDGPU_GEM_CREATE_VRAM_CONTIGUOUS));
|
!(bo->flags & AMDGPU_GEM_CREATE_VRAM_CONTIGUOUS));
|
||||||
|
|
||||||
return amdgpu_bo_gpu_offset_no_check(bo);
|
return amdgpu_bo_gpu_offset_no_check(bo);
|
||||||
@ -1468,8 +1468,8 @@ u64 amdgpu_bo_gpu_offset_no_check(struct amdgpu_bo *bo)
|
|||||||
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->tbo.bdev);
|
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->tbo.bdev);
|
||||||
uint64_t offset;
|
uint64_t offset;
|
||||||
|
|
||||||
offset = (bo->tbo.mem.start << PAGE_SHIFT) +
|
offset = (bo->tbo.resource->start << PAGE_SHIFT) +
|
||||||
amdgpu_ttm_domain_start(adev, bo->tbo.mem.mem_type);
|
amdgpu_ttm_domain_start(adev, bo->tbo.resource->mem_type);
|
||||||
|
|
||||||
return amdgpu_gmc_sign_extend(offset);
|
return amdgpu_gmc_sign_extend(offset);
|
||||||
}
|
}
|
||||||
@ -1522,7 +1522,7 @@ u64 amdgpu_bo_print_info(int id, struct amdgpu_bo *bo, struct seq_file *m)
|
|||||||
unsigned int pin_count;
|
unsigned int pin_count;
|
||||||
u64 size;
|
u64 size;
|
||||||
|
|
||||||
domain = amdgpu_mem_type_to_domain(bo->tbo.mem.mem_type);
|
domain = amdgpu_mem_type_to_domain(bo->tbo.resource->mem_type);
|
||||||
switch (domain) {
|
switch (domain) {
|
||||||
case AMDGPU_GEM_DOMAIN_VRAM:
|
case AMDGPU_GEM_DOMAIN_VRAM:
|
||||||
placement = "VRAM";
|
placement = "VRAM";
|
||||||
|
@ -219,10 +219,10 @@ static inline bool amdgpu_bo_in_cpu_visible_vram(struct amdgpu_bo *bo)
|
|||||||
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->tbo.bdev);
|
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->tbo.bdev);
|
||||||
struct amdgpu_res_cursor cursor;
|
struct amdgpu_res_cursor cursor;
|
||||||
|
|
||||||
if (bo->tbo.mem.mem_type != TTM_PL_VRAM)
|
if (bo->tbo.resource->mem_type != TTM_PL_VRAM)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
amdgpu_res_first(&bo->tbo.mem, 0, amdgpu_bo_size(bo), &cursor);
|
amdgpu_res_first(bo->tbo.resource, 0, amdgpu_bo_size(bo), &cursor);
|
||||||
while (cursor.remaining) {
|
while (cursor.remaining) {
|
||||||
if (cursor.start < adev->gmc.visible_vram_size)
|
if (cursor.start < adev->gmc.visible_vram_size)
|
||||||
return true;
|
return true;
|
||||||
|
@ -127,8 +127,8 @@ TRACE_EVENT(amdgpu_bo_create,
|
|||||||
|
|
||||||
TP_fast_assign(
|
TP_fast_assign(
|
||||||
__entry->bo = bo;
|
__entry->bo = bo;
|
||||||
__entry->pages = bo->tbo.mem.num_pages;
|
__entry->pages = bo->tbo.resource->num_pages;
|
||||||
__entry->type = bo->tbo.mem.mem_type;
|
__entry->type = bo->tbo.resource->mem_type;
|
||||||
__entry->prefer = bo->preferred_domains;
|
__entry->prefer = bo->preferred_domains;
|
||||||
__entry->allow = bo->allowed_domains;
|
__entry->allow = bo->allowed_domains;
|
||||||
__entry->visible = bo->flags;
|
__entry->visible = bo->flags;
|
||||||
|
@ -125,7 +125,8 @@ static void amdgpu_evict_flags(struct ttm_buffer_object *bo,
|
|||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
switch (bo->mem.mem_type) {
|
|
||||||
|
switch (bo->resource->mem_type) {
|
||||||
case AMDGPU_PL_GDS:
|
case AMDGPU_PL_GDS:
|
||||||
case AMDGPU_PL_GWS:
|
case AMDGPU_PL_GWS:
|
||||||
case AMDGPU_PL_OA:
|
case AMDGPU_PL_OA:
|
||||||
@ -458,7 +459,7 @@ static int amdgpu_bo_move(struct ttm_buffer_object *bo, bool evict,
|
|||||||
{
|
{
|
||||||
struct amdgpu_device *adev;
|
struct amdgpu_device *adev;
|
||||||
struct amdgpu_bo *abo;
|
struct amdgpu_bo *abo;
|
||||||
struct ttm_resource *old_mem = &bo->mem;
|
struct ttm_resource *old_mem = bo->resource;
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
if (new_mem->mem_type == TTM_PL_TT) {
|
if (new_mem->mem_type == TTM_PL_TT) {
|
||||||
@ -490,7 +491,7 @@ static int amdgpu_bo_move(struct ttm_buffer_object *bo, bool evict,
|
|||||||
return r;
|
return r;
|
||||||
|
|
||||||
amdgpu_ttm_backend_unbind(bo->bdev, bo->ttm);
|
amdgpu_ttm_backend_unbind(bo->bdev, bo->ttm);
|
||||||
ttm_resource_free(bo, &bo->mem);
|
ttm_resource_free(bo, bo->resource);
|
||||||
ttm_bo_assign_mem(bo, new_mem);
|
ttm_bo_assign_mem(bo, new_mem);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
@ -599,7 +600,8 @@ static unsigned long amdgpu_ttm_io_mem_pfn(struct ttm_buffer_object *bo,
|
|||||||
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->bdev);
|
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->bdev);
|
||||||
struct amdgpu_res_cursor cursor;
|
struct amdgpu_res_cursor cursor;
|
||||||
|
|
||||||
amdgpu_res_first(&bo->mem, (u64)page_offset << PAGE_SHIFT, 0, &cursor);
|
amdgpu_res_first(bo->resource, (u64)page_offset << PAGE_SHIFT, 0,
|
||||||
|
&cursor);
|
||||||
return (adev->gmc.aper_base + cursor.start) >> PAGE_SHIFT;
|
return (adev->gmc.aper_base + cursor.start) >> PAGE_SHIFT;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -954,12 +956,12 @@ int amdgpu_ttm_alloc_gart(struct ttm_buffer_object *bo)
|
|||||||
uint64_t addr, flags;
|
uint64_t addr, flags;
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
if (bo->mem.start != AMDGPU_BO_INVALID_OFFSET)
|
if (bo->resource->start != AMDGPU_BO_INVALID_OFFSET)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
addr = amdgpu_gmc_agp_addr(bo);
|
addr = amdgpu_gmc_agp_addr(bo);
|
||||||
if (addr != AMDGPU_BO_INVALID_OFFSET) {
|
if (addr != AMDGPU_BO_INVALID_OFFSET) {
|
||||||
bo->mem.start = addr >> PAGE_SHIFT;
|
bo->resource->start = addr >> PAGE_SHIFT;
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
/* allocate GART space */
|
/* allocate GART space */
|
||||||
@ -970,7 +972,7 @@ int amdgpu_ttm_alloc_gart(struct ttm_buffer_object *bo)
|
|||||||
placements.fpfn = 0;
|
placements.fpfn = 0;
|
||||||
placements.lpfn = adev->gmc.gart_size >> PAGE_SHIFT;
|
placements.lpfn = adev->gmc.gart_size >> PAGE_SHIFT;
|
||||||
placements.mem_type = TTM_PL_TT;
|
placements.mem_type = TTM_PL_TT;
|
||||||
placements.flags = bo->mem.placement;
|
placements.flags = bo->resource->placement;
|
||||||
|
|
||||||
r = ttm_bo_mem_space(bo, &placement, &tmp, &ctx);
|
r = ttm_bo_mem_space(bo, &placement, &tmp, &ctx);
|
||||||
if (unlikely(r))
|
if (unlikely(r))
|
||||||
@ -987,8 +989,8 @@ int amdgpu_ttm_alloc_gart(struct ttm_buffer_object *bo)
|
|||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
ttm_resource_free(bo, &bo->mem);
|
ttm_resource_free(bo, bo->resource);
|
||||||
bo->mem = tmp;
|
ttm_bo_assign_mem(bo, &tmp);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -1009,7 +1011,7 @@ int amdgpu_ttm_recover_gart(struct ttm_buffer_object *tbo)
|
|||||||
if (!tbo->ttm)
|
if (!tbo->ttm)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
flags = amdgpu_ttm_tt_pte_flags(adev, tbo->ttm, &tbo->mem);
|
flags = amdgpu_ttm_tt_pte_flags(adev, tbo->ttm, tbo->resource);
|
||||||
r = amdgpu_ttm_gart_bind(adev, tbo, flags);
|
r = amdgpu_ttm_gart_bind(adev, tbo, flags);
|
||||||
|
|
||||||
return r;
|
return r;
|
||||||
@ -1322,7 +1324,7 @@ uint64_t amdgpu_ttm_tt_pte_flags(struct amdgpu_device *adev, struct ttm_tt *ttm,
|
|||||||
static bool amdgpu_ttm_bo_eviction_valuable(struct ttm_buffer_object *bo,
|
static bool amdgpu_ttm_bo_eviction_valuable(struct ttm_buffer_object *bo,
|
||||||
const struct ttm_place *place)
|
const struct ttm_place *place)
|
||||||
{
|
{
|
||||||
unsigned long num_pages = bo->mem.num_pages;
|
unsigned long num_pages = bo->resource->num_pages;
|
||||||
struct amdgpu_res_cursor cursor;
|
struct amdgpu_res_cursor cursor;
|
||||||
struct dma_resv_list *flist;
|
struct dma_resv_list *flist;
|
||||||
struct dma_fence *f;
|
struct dma_fence *f;
|
||||||
@ -1346,7 +1348,7 @@ static bool amdgpu_ttm_bo_eviction_valuable(struct ttm_buffer_object *bo,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (bo->mem.mem_type) {
|
switch (bo->resource->mem_type) {
|
||||||
case TTM_PL_TT:
|
case TTM_PL_TT:
|
||||||
if (amdgpu_bo_is_amdgpu_bo(bo) &&
|
if (amdgpu_bo_is_amdgpu_bo(bo) &&
|
||||||
amdgpu_bo_encrypted(ttm_to_amdgpu_bo(bo)))
|
amdgpu_bo_encrypted(ttm_to_amdgpu_bo(bo)))
|
||||||
@ -1355,7 +1357,7 @@ static bool amdgpu_ttm_bo_eviction_valuable(struct ttm_buffer_object *bo,
|
|||||||
|
|
||||||
case TTM_PL_VRAM:
|
case TTM_PL_VRAM:
|
||||||
/* Check each drm MM node individually */
|
/* Check each drm MM node individually */
|
||||||
amdgpu_res_first(&bo->mem, 0, (u64)num_pages << PAGE_SHIFT,
|
amdgpu_res_first(bo->resource, 0, (u64)num_pages << PAGE_SHIFT,
|
||||||
&cursor);
|
&cursor);
|
||||||
while (cursor.remaining) {
|
while (cursor.remaining) {
|
||||||
if (place->fpfn < PFN_DOWN(cursor.start + cursor.size)
|
if (place->fpfn < PFN_DOWN(cursor.start + cursor.size)
|
||||||
@ -1397,10 +1399,10 @@ static int amdgpu_ttm_access_memory(struct ttm_buffer_object *bo,
|
|||||||
uint32_t value = 0;
|
uint32_t value = 0;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
if (bo->mem.mem_type != TTM_PL_VRAM)
|
if (bo->resource->mem_type != TTM_PL_VRAM)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
amdgpu_res_first(&bo->mem, offset, len, &cursor);
|
amdgpu_res_first(bo->resource, offset, len, &cursor);
|
||||||
while (cursor.remaining) {
|
while (cursor.remaining) {
|
||||||
uint64_t aligned_pos = cursor.start & ~(uint64_t)3;
|
uint64_t aligned_pos = cursor.start & ~(uint64_t)3;
|
||||||
uint64_t bytes = 4 - (cursor.start & 3);
|
uint64_t bytes = 4 - (cursor.start & 3);
|
||||||
@ -1917,16 +1919,16 @@ int amdgpu_fill_buffer(struct amdgpu_bo *bo,
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bo->tbo.mem.mem_type == TTM_PL_TT) {
|
if (bo->tbo.resource->mem_type == TTM_PL_TT) {
|
||||||
r = amdgpu_ttm_alloc_gart(&bo->tbo);
|
r = amdgpu_ttm_alloc_gart(&bo->tbo);
|
||||||
if (r)
|
if (r)
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
num_bytes = bo->tbo.mem.num_pages << PAGE_SHIFT;
|
num_bytes = bo->tbo.resource->num_pages << PAGE_SHIFT;
|
||||||
num_loops = 0;
|
num_loops = 0;
|
||||||
|
|
||||||
amdgpu_res_first(&bo->tbo.mem, 0, num_bytes, &cursor);
|
amdgpu_res_first(bo->tbo.resource, 0, num_bytes, &cursor);
|
||||||
while (cursor.remaining) {
|
while (cursor.remaining) {
|
||||||
num_loops += DIV_ROUND_UP_ULL(cursor.size, max_bytes);
|
num_loops += DIV_ROUND_UP_ULL(cursor.size, max_bytes);
|
||||||
amdgpu_res_next(&cursor, cursor.size);
|
amdgpu_res_next(&cursor, cursor.size);
|
||||||
@ -1951,12 +1953,13 @@ int amdgpu_fill_buffer(struct amdgpu_bo *bo,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
amdgpu_res_first(&bo->tbo.mem, 0, num_bytes, &cursor);
|
amdgpu_res_first(bo->tbo.resource, 0, num_bytes, &cursor);
|
||||||
while (cursor.remaining) {
|
while (cursor.remaining) {
|
||||||
uint32_t cur_size = min_t(uint64_t, cursor.size, max_bytes);
|
uint32_t cur_size = min_t(uint64_t, cursor.size, max_bytes);
|
||||||
uint64_t dst_addr = cursor.start;
|
uint64_t dst_addr = cursor.start;
|
||||||
|
|
||||||
dst_addr += amdgpu_ttm_domain_start(adev, bo->tbo.mem.mem_type);
|
dst_addr += amdgpu_ttm_domain_start(adev,
|
||||||
|
bo->tbo.resource->mem_type);
|
||||||
amdgpu_emit_fill_buffer(adev, &job->ibs[0], src_data, dst_addr,
|
amdgpu_emit_fill_buffer(adev, &job->ibs[0], src_data, dst_addr,
|
||||||
cur_size);
|
cur_size);
|
||||||
|
|
||||||
|
@ -342,7 +342,7 @@ static void amdgpu_vm_bo_base_init(struct amdgpu_vm_bo_base *base,
|
|||||||
amdgpu_vm_bo_idle(base);
|
amdgpu_vm_bo_idle(base);
|
||||||
|
|
||||||
if (bo->preferred_domains &
|
if (bo->preferred_domains &
|
||||||
amdgpu_mem_type_to_domain(bo->tbo.mem.mem_type))
|
amdgpu_mem_type_to_domain(bo->tbo.resource->mem_type))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -657,11 +657,11 @@ void amdgpu_vm_move_to_lru_tail(struct amdgpu_device *adev,
|
|||||||
if (!bo->parent)
|
if (!bo->parent)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
ttm_bo_move_to_lru_tail(&bo->tbo, &bo->tbo.mem,
|
ttm_bo_move_to_lru_tail(&bo->tbo, bo->tbo.resource,
|
||||||
&vm->lru_bulk_move);
|
&vm->lru_bulk_move);
|
||||||
if (bo->shadow)
|
if (bo->shadow)
|
||||||
ttm_bo_move_to_lru_tail(&bo->shadow->tbo,
|
ttm_bo_move_to_lru_tail(&bo->shadow->tbo,
|
||||||
&bo->shadow->tbo.mem,
|
bo->shadow->tbo.resource,
|
||||||
&vm->lru_bulk_move);
|
&vm->lru_bulk_move);
|
||||||
}
|
}
|
||||||
spin_unlock(&adev->mman.bdev.lru_lock);
|
spin_unlock(&adev->mman.bdev.lru_lock);
|
||||||
@ -1818,10 +1818,10 @@ int amdgpu_vm_bo_update(struct amdgpu_device *adev, struct amdgpu_bo_va *bo_va,
|
|||||||
struct drm_gem_object *gobj = dma_buf->priv;
|
struct drm_gem_object *gobj = dma_buf->priv;
|
||||||
struct amdgpu_bo *abo = gem_to_amdgpu_bo(gobj);
|
struct amdgpu_bo *abo = gem_to_amdgpu_bo(gobj);
|
||||||
|
|
||||||
if (abo->tbo.mem.mem_type == TTM_PL_VRAM)
|
if (abo->tbo.resource->mem_type == TTM_PL_VRAM)
|
||||||
bo = gem_to_amdgpu_bo(gobj);
|
bo = gem_to_amdgpu_bo(gobj);
|
||||||
}
|
}
|
||||||
mem = &bo->tbo.mem;
|
mem = bo->tbo.resource;
|
||||||
if (mem->mem_type == TTM_PL_TT)
|
if (mem->mem_type == TTM_PL_TT)
|
||||||
pages_addr = bo->tbo.ttm->dma_address;
|
pages_addr = bo->tbo.ttm->dma_address;
|
||||||
}
|
}
|
||||||
@ -1881,7 +1881,7 @@ int amdgpu_vm_bo_update(struct amdgpu_device *adev, struct amdgpu_bo_va *bo_va,
|
|||||||
* next command submission.
|
* next command submission.
|
||||||
*/
|
*/
|
||||||
if (bo && bo->tbo.base.resv == vm->root.base.bo->tbo.base.resv) {
|
if (bo && bo->tbo.base.resv == vm->root.base.bo->tbo.base.resv) {
|
||||||
uint32_t mem_type = bo->tbo.mem.mem_type;
|
uint32_t mem_type = bo->tbo.resource->mem_type;
|
||||||
|
|
||||||
if (!(bo->preferred_domains &
|
if (!(bo->preferred_domains &
|
||||||
amdgpu_mem_type_to_domain(mem_type)))
|
amdgpu_mem_type_to_domain(mem_type)))
|
||||||
|
@ -217,7 +217,7 @@ static u64 amdgpu_vram_mgr_vis_size(struct amdgpu_device *adev,
|
|||||||
u64 amdgpu_vram_mgr_bo_visible_size(struct amdgpu_bo *bo)
|
u64 amdgpu_vram_mgr_bo_visible_size(struct amdgpu_bo *bo)
|
||||||
{
|
{
|
||||||
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->tbo.bdev);
|
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->tbo.bdev);
|
||||||
struct ttm_resource *mem = &bo->tbo.mem;
|
struct ttm_resource *mem = bo->tbo.resource;
|
||||||
struct drm_mm_node *nodes = mem->mm_node;
|
struct drm_mm_node *nodes = mem->mm_node;
|
||||||
unsigned pages = mem->num_pages;
|
unsigned pages = mem->num_pages;
|
||||||
u64 usage;
|
u64 usage;
|
||||||
|
@ -409,7 +409,7 @@ svm_range_validate_svm_bo(struct amdgpu_device *adev, struct svm_range *prange)
|
|||||||
pr_debug("reuse old bo svms 0x%p [0x%lx 0x%lx]\n",
|
pr_debug("reuse old bo svms 0x%p [0x%lx 0x%lx]\n",
|
||||||
prange->svms, prange->start, prange->last);
|
prange->svms, prange->start, prange->last);
|
||||||
|
|
||||||
prange->ttm_res = &prange->svm_bo->bo->tbo.mem;
|
prange->ttm_res = prange->svm_bo->bo->tbo.resource;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -515,7 +515,7 @@ svm_range_vram_node_new(struct amdgpu_device *adev, struct svm_range *prange,
|
|||||||
|
|
||||||
svm_bo->bo = bo;
|
svm_bo->bo = bo;
|
||||||
prange->svm_bo = svm_bo;
|
prange->svm_bo = svm_bo;
|
||||||
prange->ttm_res = &bo->tbo.mem;
|
prange->ttm_res = bo->tbo.resource;
|
||||||
prange->offset = 0;
|
prange->offset = 0;
|
||||||
|
|
||||||
spin_lock(&svm_bo->list_lock);
|
spin_lock(&svm_bo->list_lock);
|
||||||
|
@ -40,12 +40,12 @@ void drm_gem_ttm_print_info(struct drm_printer *p, unsigned int indent,
|
|||||||
const struct ttm_buffer_object *bo = drm_gem_ttm_of_gem(gem);
|
const struct ttm_buffer_object *bo = drm_gem_ttm_of_gem(gem);
|
||||||
|
|
||||||
drm_printf_indent(p, indent, "placement=");
|
drm_printf_indent(p, indent, "placement=");
|
||||||
drm_print_bits(p, bo->mem.placement, plname, ARRAY_SIZE(plname));
|
drm_print_bits(p, bo->resource->placement, plname, ARRAY_SIZE(plname));
|
||||||
drm_printf(p, "\n");
|
drm_printf(p, "\n");
|
||||||
|
|
||||||
if (bo->mem.bus.is_iomem)
|
if (bo->resource->bus.is_iomem)
|
||||||
drm_printf_indent(p, indent, "bus.offset=%lx\n",
|
drm_printf_indent(p, indent, "bus.offset=%lx\n",
|
||||||
(unsigned long)bo->mem.bus.offset);
|
(unsigned long)bo->resource->bus.offset);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(drm_gem_ttm_print_info);
|
EXPORT_SYMBOL(drm_gem_ttm_print_info);
|
||||||
|
|
||||||
|
@ -248,10 +248,10 @@ EXPORT_SYMBOL(drm_gem_vram_put);
|
|||||||
static u64 drm_gem_vram_pg_offset(struct drm_gem_vram_object *gbo)
|
static u64 drm_gem_vram_pg_offset(struct drm_gem_vram_object *gbo)
|
||||||
{
|
{
|
||||||
/* Keep TTM behavior for now, remove when drivers are audited */
|
/* Keep TTM behavior for now, remove when drivers are audited */
|
||||||
if (WARN_ON_ONCE(!gbo->bo.mem.mm_node))
|
if (WARN_ON_ONCE(!gbo->bo.resource->mm_node))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
return gbo->bo.mem.start;
|
return gbo->bo.resource->start;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -312,7 +312,7 @@ nouveau_abi16_ioctl_channel_alloc(ABI16_IOCTL_ARGS)
|
|||||||
init->pushbuf_domains = NOUVEAU_GEM_DOMAIN_VRAM |
|
init->pushbuf_domains = NOUVEAU_GEM_DOMAIN_VRAM |
|
||||||
NOUVEAU_GEM_DOMAIN_GART;
|
NOUVEAU_GEM_DOMAIN_GART;
|
||||||
else
|
else
|
||||||
if (chan->chan->push.buffer->bo.mem.mem_type == TTM_PL_VRAM)
|
if (chan->chan->push.buffer->bo.resource->mem_type == TTM_PL_VRAM)
|
||||||
init->pushbuf_domains = NOUVEAU_GEM_DOMAIN_VRAM;
|
init->pushbuf_domains = NOUVEAU_GEM_DOMAIN_VRAM;
|
||||||
else
|
else
|
||||||
init->pushbuf_domains = NOUVEAU_GEM_DOMAIN_GART;
|
init->pushbuf_domains = NOUVEAU_GEM_DOMAIN_GART;
|
||||||
|
@ -433,7 +433,7 @@ nouveau_bo_pin(struct nouveau_bo *nvbo, uint32_t domain, bool contig)
|
|||||||
if (nvbo->bo.pin_count) {
|
if (nvbo->bo.pin_count) {
|
||||||
bool error = evict;
|
bool error = evict;
|
||||||
|
|
||||||
switch (bo->mem.mem_type) {
|
switch (bo->resource->mem_type) {
|
||||||
case TTM_PL_VRAM:
|
case TTM_PL_VRAM:
|
||||||
error |= !(domain & NOUVEAU_GEM_DOMAIN_VRAM);
|
error |= !(domain & NOUVEAU_GEM_DOMAIN_VRAM);
|
||||||
break;
|
break;
|
||||||
@ -446,7 +446,7 @@ nouveau_bo_pin(struct nouveau_bo *nvbo, uint32_t domain, bool contig)
|
|||||||
if (error) {
|
if (error) {
|
||||||
NV_ERROR(drm, "bo %p pinned elsewhere: "
|
NV_ERROR(drm, "bo %p pinned elsewhere: "
|
||||||
"0x%08x vs 0x%08x\n", bo,
|
"0x%08x vs 0x%08x\n", bo,
|
||||||
bo->mem.mem_type, domain);
|
bo->resource->mem_type, domain);
|
||||||
ret = -EBUSY;
|
ret = -EBUSY;
|
||||||
}
|
}
|
||||||
ttm_bo_pin(&nvbo->bo);
|
ttm_bo_pin(&nvbo->bo);
|
||||||
@ -467,7 +467,7 @@ nouveau_bo_pin(struct nouveau_bo *nvbo, uint32_t domain, bool contig)
|
|||||||
|
|
||||||
ttm_bo_pin(&nvbo->bo);
|
ttm_bo_pin(&nvbo->bo);
|
||||||
|
|
||||||
switch (bo->mem.mem_type) {
|
switch (bo->resource->mem_type) {
|
||||||
case TTM_PL_VRAM:
|
case TTM_PL_VRAM:
|
||||||
drm->gem.vram_available -= bo->base.size;
|
drm->gem.vram_available -= bo->base.size;
|
||||||
break;
|
break;
|
||||||
@ -498,7 +498,7 @@ nouveau_bo_unpin(struct nouveau_bo *nvbo)
|
|||||||
|
|
||||||
ttm_bo_unpin(&nvbo->bo);
|
ttm_bo_unpin(&nvbo->bo);
|
||||||
if (!nvbo->bo.pin_count) {
|
if (!nvbo->bo.pin_count) {
|
||||||
switch (bo->mem.mem_type) {
|
switch (bo->resource->mem_type) {
|
||||||
case TTM_PL_VRAM:
|
case TTM_PL_VRAM:
|
||||||
drm->gem.vram_available += bo->base.size;
|
drm->gem.vram_available += bo->base.size;
|
||||||
break;
|
break;
|
||||||
@ -523,7 +523,7 @@ nouveau_bo_map(struct nouveau_bo *nvbo)
|
|||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
ret = ttm_bo_kmap(&nvbo->bo, 0, nvbo->bo.mem.num_pages, &nvbo->kmap);
|
ret = ttm_bo_kmap(&nvbo->bo, 0, nvbo->bo.resource->num_pages, &nvbo->kmap);
|
||||||
|
|
||||||
ttm_bo_unreserve(&nvbo->bo);
|
ttm_bo_unreserve(&nvbo->bo);
|
||||||
return ret;
|
return ret;
|
||||||
@ -737,7 +737,7 @@ nouveau_bo_evict_flags(struct ttm_buffer_object *bo, struct ttm_placement *pl)
|
|||||||
{
|
{
|
||||||
struct nouveau_bo *nvbo = nouveau_bo(bo);
|
struct nouveau_bo *nvbo = nouveau_bo(bo);
|
||||||
|
|
||||||
switch (bo->mem.mem_type) {
|
switch (bo->resource->mem_type) {
|
||||||
case TTM_PL_VRAM:
|
case TTM_PL_VRAM:
|
||||||
nouveau_bo_placement_set(nvbo, NOUVEAU_GEM_DOMAIN_GART,
|
nouveau_bo_placement_set(nvbo, NOUVEAU_GEM_DOMAIN_GART,
|
||||||
NOUVEAU_GEM_DOMAIN_CPU);
|
NOUVEAU_GEM_DOMAIN_CPU);
|
||||||
@ -754,7 +754,7 @@ static int
|
|||||||
nouveau_bo_move_prep(struct nouveau_drm *drm, struct ttm_buffer_object *bo,
|
nouveau_bo_move_prep(struct nouveau_drm *drm, struct ttm_buffer_object *bo,
|
||||||
struct ttm_resource *reg)
|
struct ttm_resource *reg)
|
||||||
{
|
{
|
||||||
struct nouveau_mem *old_mem = nouveau_mem(&bo->mem);
|
struct nouveau_mem *old_mem = nouveau_mem(bo->resource);
|
||||||
struct nouveau_mem *new_mem = nouveau_mem(reg);
|
struct nouveau_mem *new_mem = nouveau_mem(reg);
|
||||||
struct nvif_vmm *vmm = &drm->client.vmm.vmm;
|
struct nvif_vmm *vmm = &drm->client.vmm.vmm;
|
||||||
int ret;
|
int ret;
|
||||||
@ -809,7 +809,7 @@ nouveau_bo_move_m2mf(struct ttm_buffer_object *bo, int evict,
|
|||||||
mutex_lock_nested(&cli->mutex, SINGLE_DEPTH_NESTING);
|
mutex_lock_nested(&cli->mutex, SINGLE_DEPTH_NESTING);
|
||||||
ret = nouveau_fence_sync(nouveau_bo(bo), chan, true, ctx->interruptible);
|
ret = nouveau_fence_sync(nouveau_bo(bo), chan, true, ctx->interruptible);
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
ret = drm->ttm.move(chan, bo, &bo->mem, new_reg);
|
ret = drm->ttm.move(chan, bo, bo->resource, new_reg);
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
ret = nouveau_fence_new(chan, false, &fence);
|
ret = nouveau_fence_new(chan, false, &fence);
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
@ -969,7 +969,7 @@ nouveau_bo_move(struct ttm_buffer_object *bo, bool evict,
|
|||||||
{
|
{
|
||||||
struct nouveau_drm *drm = nouveau_bdev(bo->bdev);
|
struct nouveau_drm *drm = nouveau_bdev(bo->bdev);
|
||||||
struct nouveau_bo *nvbo = nouveau_bo(bo);
|
struct nouveau_bo *nvbo = nouveau_bo(bo);
|
||||||
struct ttm_resource *old_reg = &bo->mem;
|
struct ttm_resource *old_reg = bo->resource;
|
||||||
struct nouveau_drm_tile *new_tile = NULL;
|
struct nouveau_drm_tile *new_tile = NULL;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
@ -1009,7 +1009,7 @@ nouveau_bo_move(struct ttm_buffer_object *bo, bool evict,
|
|||||||
if (old_reg->mem_type == TTM_PL_TT &&
|
if (old_reg->mem_type == TTM_PL_TT &&
|
||||||
new_reg->mem_type == TTM_PL_SYSTEM) {
|
new_reg->mem_type == TTM_PL_SYSTEM) {
|
||||||
nouveau_ttm_tt_unbind(bo->bdev, bo->ttm);
|
nouveau_ttm_tt_unbind(bo->bdev, bo->ttm);
|
||||||
ttm_resource_free(bo, &bo->mem);
|
ttm_resource_free(bo, bo->resource);
|
||||||
ttm_bo_assign_mem(bo, new_reg);
|
ttm_bo_assign_mem(bo, new_reg);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
@ -1045,7 +1045,7 @@ out:
|
|||||||
}
|
}
|
||||||
out_ntfy:
|
out_ntfy:
|
||||||
if (ret) {
|
if (ret) {
|
||||||
nouveau_bo_move_ntfy(bo, &bo->mem);
|
nouveau_bo_move_ntfy(bo, bo->resource);
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -1170,7 +1170,7 @@ out:
|
|||||||
list_del_init(&nvbo->io_reserve_lru);
|
list_del_init(&nvbo->io_reserve_lru);
|
||||||
drm_vma_node_unmap(&nvbo->bo.base.vma_node,
|
drm_vma_node_unmap(&nvbo->bo.base.vma_node,
|
||||||
bdev->dev_mapping);
|
bdev->dev_mapping);
|
||||||
nouveau_ttm_io_mem_free_locked(drm, &nvbo->bo.mem);
|
nouveau_ttm_io_mem_free_locked(drm, nvbo->bo.resource);
|
||||||
goto retry;
|
goto retry;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1200,12 +1200,12 @@ vm_fault_t nouveau_ttm_fault_reserve_notify(struct ttm_buffer_object *bo)
|
|||||||
/* as long as the bo isn't in vram, and isn't tiled, we've got
|
/* as long as the bo isn't in vram, and isn't tiled, we've got
|
||||||
* nothing to do here.
|
* nothing to do here.
|
||||||
*/
|
*/
|
||||||
if (bo->mem.mem_type != TTM_PL_VRAM) {
|
if (bo->resource->mem_type != TTM_PL_VRAM) {
|
||||||
if (drm->client.device.info.family < NV_DEVICE_INFO_V0_TESLA ||
|
if (drm->client.device.info.family < NV_DEVICE_INFO_V0_TESLA ||
|
||||||
!nvbo->kind)
|
!nvbo->kind)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (bo->mem.mem_type != TTM_PL_SYSTEM)
|
if (bo->resource->mem_type != TTM_PL_SYSTEM)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
nouveau_bo_placement_set(nvbo, NOUVEAU_GEM_DOMAIN_GART, 0);
|
nouveau_bo_placement_set(nvbo, NOUVEAU_GEM_DOMAIN_GART, 0);
|
||||||
@ -1213,7 +1213,7 @@ vm_fault_t nouveau_ttm_fault_reserve_notify(struct ttm_buffer_object *bo)
|
|||||||
} else {
|
} else {
|
||||||
/* make sure bo is in mappable vram */
|
/* make sure bo is in mappable vram */
|
||||||
if (drm->client.device.info.family >= NV_DEVICE_INFO_V0_TESLA ||
|
if (drm->client.device.info.family >= NV_DEVICE_INFO_V0_TESLA ||
|
||||||
bo->mem.start + bo->mem.num_pages < mappable)
|
bo->resource->start + bo->resource->num_pages < mappable)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
for (i = 0; i < nvbo->placement.num_placement; ++i) {
|
for (i = 0; i < nvbo->placement.num_placement; ++i) {
|
||||||
|
@ -212,7 +212,7 @@ nouveau_channel_prep(struct nouveau_drm *drm, struct nvif_device *device,
|
|||||||
args.start = 0;
|
args.start = 0;
|
||||||
args.limit = chan->vmm->vmm.limit - 1;
|
args.limit = chan->vmm->vmm.limit - 1;
|
||||||
} else
|
} else
|
||||||
if (chan->push.buffer->bo.mem.mem_type == TTM_PL_VRAM) {
|
if (chan->push.buffer->bo.resource->mem_type == TTM_PL_VRAM) {
|
||||||
if (device->info.family == NV_DEVICE_INFO_V0_TNT) {
|
if (device->info.family == NV_DEVICE_INFO_V0_TNT) {
|
||||||
/* nv04 vram pushbuf hack, retarget to its location in
|
/* nv04 vram pushbuf hack, retarget to its location in
|
||||||
* the framebuffer bar rather than direct vram access..
|
* the framebuffer bar rather than direct vram access..
|
||||||
|
@ -378,7 +378,7 @@ nouveau_fbcon_create(struct drm_fb_helper *helper,
|
|||||||
FBINFO_HWACCEL_FILLRECT |
|
FBINFO_HWACCEL_FILLRECT |
|
||||||
FBINFO_HWACCEL_IMAGEBLIT;
|
FBINFO_HWACCEL_IMAGEBLIT;
|
||||||
info->fbops = &nouveau_fbcon_sw_ops;
|
info->fbops = &nouveau_fbcon_sw_ops;
|
||||||
info->fix.smem_start = nvbo->bo.mem.bus.offset;
|
info->fix.smem_start = nvbo->bo.resource->bus.offset;
|
||||||
info->fix.smem_len = nvbo->bo.base.size;
|
info->fix.smem_len = nvbo->bo.base.size;
|
||||||
|
|
||||||
info->screen_base = nvbo_kmap_obj_iovirtual(nvbo);
|
info->screen_base = nvbo_kmap_obj_iovirtual(nvbo);
|
||||||
|
@ -276,7 +276,7 @@ nouveau_gem_info(struct drm_file *file_priv, struct drm_gem_object *gem,
|
|||||||
|
|
||||||
if (is_power_of_2(nvbo->valid_domains))
|
if (is_power_of_2(nvbo->valid_domains))
|
||||||
rep->domain = nvbo->valid_domains;
|
rep->domain = nvbo->valid_domains;
|
||||||
else if (nvbo->bo.mem.mem_type == TTM_PL_TT)
|
else if (nvbo->bo.resource->mem_type == TTM_PL_TT)
|
||||||
rep->domain = NOUVEAU_GEM_DOMAIN_GART;
|
rep->domain = NOUVEAU_GEM_DOMAIN_GART;
|
||||||
else
|
else
|
||||||
rep->domain = NOUVEAU_GEM_DOMAIN_VRAM;
|
rep->domain = NOUVEAU_GEM_DOMAIN_VRAM;
|
||||||
@ -347,11 +347,11 @@ nouveau_gem_set_domain(struct drm_gem_object *gem, uint32_t read_domains,
|
|||||||
valid_domains &= ~(NOUVEAU_GEM_DOMAIN_VRAM | NOUVEAU_GEM_DOMAIN_GART);
|
valid_domains &= ~(NOUVEAU_GEM_DOMAIN_VRAM | NOUVEAU_GEM_DOMAIN_GART);
|
||||||
|
|
||||||
if ((domains & NOUVEAU_GEM_DOMAIN_VRAM) &&
|
if ((domains & NOUVEAU_GEM_DOMAIN_VRAM) &&
|
||||||
bo->mem.mem_type == TTM_PL_VRAM)
|
bo->resource->mem_type == TTM_PL_VRAM)
|
||||||
pref_domains |= NOUVEAU_GEM_DOMAIN_VRAM;
|
pref_domains |= NOUVEAU_GEM_DOMAIN_VRAM;
|
||||||
|
|
||||||
else if ((domains & NOUVEAU_GEM_DOMAIN_GART) &&
|
else if ((domains & NOUVEAU_GEM_DOMAIN_GART) &&
|
||||||
bo->mem.mem_type == TTM_PL_TT)
|
bo->resource->mem_type == TTM_PL_TT)
|
||||||
pref_domains |= NOUVEAU_GEM_DOMAIN_GART;
|
pref_domains |= NOUVEAU_GEM_DOMAIN_GART;
|
||||||
|
|
||||||
else if (domains & NOUVEAU_GEM_DOMAIN_VRAM)
|
else if (domains & NOUVEAU_GEM_DOMAIN_VRAM)
|
||||||
@ -561,13 +561,13 @@ validate_list(struct nouveau_channel *chan, struct nouveau_cli *cli,
|
|||||||
|
|
||||||
if (drm->client.device.info.family < NV_DEVICE_INFO_V0_TESLA) {
|
if (drm->client.device.info.family < NV_DEVICE_INFO_V0_TESLA) {
|
||||||
if (nvbo->offset == b->presumed.offset &&
|
if (nvbo->offset == b->presumed.offset &&
|
||||||
((nvbo->bo.mem.mem_type == TTM_PL_VRAM &&
|
((nvbo->bo.resource->mem_type == TTM_PL_VRAM &&
|
||||||
b->presumed.domain & NOUVEAU_GEM_DOMAIN_VRAM) ||
|
b->presumed.domain & NOUVEAU_GEM_DOMAIN_VRAM) ||
|
||||||
(nvbo->bo.mem.mem_type == TTM_PL_TT &&
|
(nvbo->bo.resource->mem_type == TTM_PL_TT &&
|
||||||
b->presumed.domain & NOUVEAU_GEM_DOMAIN_GART)))
|
b->presumed.domain & NOUVEAU_GEM_DOMAIN_GART)))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (nvbo->bo.mem.mem_type == TTM_PL_TT)
|
if (nvbo->bo.resource->mem_type == TTM_PL_TT)
|
||||||
b->presumed.domain = NOUVEAU_GEM_DOMAIN_GART;
|
b->presumed.domain = NOUVEAU_GEM_DOMAIN_GART;
|
||||||
else
|
else
|
||||||
b->presumed.domain = NOUVEAU_GEM_DOMAIN_VRAM;
|
b->presumed.domain = NOUVEAU_GEM_DOMAIN_VRAM;
|
||||||
@ -681,7 +681,7 @@ nouveau_gem_pushbuf_reloc_apply(struct nouveau_cli *cli,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!nvbo->kmap.virtual) {
|
if (!nvbo->kmap.virtual) {
|
||||||
ret = ttm_bo_kmap(&nvbo->bo, 0, nvbo->bo.mem.num_pages,
|
ret = ttm_bo_kmap(&nvbo->bo, 0, nvbo->bo.resource->num_pages,
|
||||||
&nvbo->kmap);
|
&nvbo->kmap);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
NV_PRINTK(err, cli, "failed kmap for reloc\n");
|
NV_PRINTK(err, cli, "failed kmap for reloc\n");
|
||||||
@ -870,7 +870,7 @@ revalidate:
|
|||||||
if (unlikely(cmd != req->suffix0)) {
|
if (unlikely(cmd != req->suffix0)) {
|
||||||
if (!nvbo->kmap.virtual) {
|
if (!nvbo->kmap.virtual) {
|
||||||
ret = ttm_bo_kmap(&nvbo->bo, 0,
|
ret = ttm_bo_kmap(&nvbo->bo, 0,
|
||||||
nvbo->bo.mem.
|
nvbo->bo.resource->
|
||||||
num_pages,
|
num_pages,
|
||||||
&nvbo->kmap);
|
&nvbo->kmap);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
|
@ -77,7 +77,7 @@ int
|
|||||||
nouveau_vma_new(struct nouveau_bo *nvbo, struct nouveau_vmm *vmm,
|
nouveau_vma_new(struct nouveau_bo *nvbo, struct nouveau_vmm *vmm,
|
||||||
struct nouveau_vma **pvma)
|
struct nouveau_vma **pvma)
|
||||||
{
|
{
|
||||||
struct nouveau_mem *mem = nouveau_mem(&nvbo->bo.mem);
|
struct nouveau_mem *mem = nouveau_mem(nvbo->bo.resource);
|
||||||
struct nouveau_vma *vma;
|
struct nouveau_vma *vma;
|
||||||
struct nvif_vma tmp;
|
struct nvif_vma tmp;
|
||||||
int ret;
|
int ret;
|
||||||
@ -96,7 +96,7 @@ nouveau_vma_new(struct nouveau_bo *nvbo, struct nouveau_vmm *vmm,
|
|||||||
vma->fence = NULL;
|
vma->fence = NULL;
|
||||||
list_add_tail(&vma->head, &nvbo->vma_list);
|
list_add_tail(&vma->head, &nvbo->vma_list);
|
||||||
|
|
||||||
if (nvbo->bo.mem.mem_type != TTM_PL_SYSTEM &&
|
if (nvbo->bo.resource->mem_type != TTM_PL_SYSTEM &&
|
||||||
mem->mem.page == nvbo->page) {
|
mem->mem.page == nvbo->page) {
|
||||||
ret = nvif_vmm_get(&vmm->vmm, LAZY, false, mem->mem.page, 0,
|
ret = nvif_vmm_get(&vmm->vmm, LAZY, false, mem->mem.page, 0,
|
||||||
mem->mem.size, &tmp);
|
mem->mem.size, &tmp);
|
||||||
|
@ -77,8 +77,8 @@ static int
|
|||||||
nv17_fence_context_new(struct nouveau_channel *chan)
|
nv17_fence_context_new(struct nouveau_channel *chan)
|
||||||
{
|
{
|
||||||
struct nv10_fence_priv *priv = chan->drm->fence;
|
struct nv10_fence_priv *priv = chan->drm->fence;
|
||||||
|
struct ttm_resource *reg = priv->bo->bo.resource;
|
||||||
struct nv10_fence_chan *fctx;
|
struct nv10_fence_chan *fctx;
|
||||||
struct ttm_resource *reg = &priv->bo->bo.mem;
|
|
||||||
u32 start = reg->start * PAGE_SIZE;
|
u32 start = reg->start * PAGE_SIZE;
|
||||||
u32 limit = start + priv->bo->bo.base.size - 1;
|
u32 limit = start + priv->bo->bo.base.size - 1;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
@ -37,7 +37,7 @@ nv50_fence_context_new(struct nouveau_channel *chan)
|
|||||||
{
|
{
|
||||||
struct nv10_fence_priv *priv = chan->drm->fence;
|
struct nv10_fence_priv *priv = chan->drm->fence;
|
||||||
struct nv10_fence_chan *fctx;
|
struct nv10_fence_chan *fctx;
|
||||||
struct ttm_resource *reg = &priv->bo->bo.mem;
|
struct ttm_resource *reg = priv->bo->bo.resource;
|
||||||
u32 start = reg->start * PAGE_SIZE;
|
u32 start = reg->start * PAGE_SIZE;
|
||||||
u32 limit = start + priv->bo->bo.base.size - 1;
|
u32 limit = start + priv->bo->bo.base.size - 1;
|
||||||
int ret;
|
int ret;
|
||||||
|
@ -292,12 +292,12 @@ qxl_bo_physical_address(struct qxl_device *qdev, struct qxl_bo *bo,
|
|||||||
unsigned long offset)
|
unsigned long offset)
|
||||||
{
|
{
|
||||||
struct qxl_memslot *slot =
|
struct qxl_memslot *slot =
|
||||||
(bo->tbo.mem.mem_type == TTM_PL_VRAM)
|
(bo->tbo.resource->mem_type == TTM_PL_VRAM)
|
||||||
? &qdev->main_slot : &qdev->surfaces_slot;
|
? &qdev->main_slot : &qdev->surfaces_slot;
|
||||||
|
|
||||||
/* TODO - need to hold one of the locks to read bo->tbo.mem.start */
|
/* TODO - need to hold one of the locks to read bo->tbo.resource->start */
|
||||||
|
|
||||||
return slot->high_bits | ((bo->tbo.mem.start << PAGE_SHIFT) + offset);
|
return slot->high_bits | ((bo->tbo.resource->start << PAGE_SHIFT) + offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* qxl_display.c */
|
/* qxl_display.c */
|
||||||
|
@ -212,14 +212,14 @@ void *qxl_bo_kmap_atomic_page(struct qxl_device *qdev,
|
|||||||
struct io_mapping *map;
|
struct io_mapping *map;
|
||||||
struct dma_buf_map bo_map;
|
struct dma_buf_map bo_map;
|
||||||
|
|
||||||
if (bo->tbo.mem.mem_type == TTM_PL_VRAM)
|
if (bo->tbo.resource->mem_type == TTM_PL_VRAM)
|
||||||
map = qdev->vram_mapping;
|
map = qdev->vram_mapping;
|
||||||
else if (bo->tbo.mem.mem_type == TTM_PL_PRIV)
|
else if (bo->tbo.resource->mem_type == TTM_PL_PRIV)
|
||||||
map = qdev->surface_mapping;
|
map = qdev->surface_mapping;
|
||||||
else
|
else
|
||||||
goto fallback;
|
goto fallback;
|
||||||
|
|
||||||
offset = bo->tbo.mem.start << PAGE_SHIFT;
|
offset = bo->tbo.resource->start << PAGE_SHIFT;
|
||||||
return io_mapping_map_atomic_wc(map, offset + page_offset);
|
return io_mapping_map_atomic_wc(map, offset + page_offset);
|
||||||
fallback:
|
fallback:
|
||||||
if (bo->kptr) {
|
if (bo->kptr) {
|
||||||
@ -266,8 +266,8 @@ int qxl_bo_vunmap(struct qxl_bo *bo)
|
|||||||
void qxl_bo_kunmap_atomic_page(struct qxl_device *qdev,
|
void qxl_bo_kunmap_atomic_page(struct qxl_device *qdev,
|
||||||
struct qxl_bo *bo, void *pmap)
|
struct qxl_bo *bo, void *pmap)
|
||||||
{
|
{
|
||||||
if ((bo->tbo.mem.mem_type != TTM_PL_VRAM) &&
|
if ((bo->tbo.resource->mem_type != TTM_PL_VRAM) &&
|
||||||
(bo->tbo.mem.mem_type != TTM_PL_PRIV))
|
(bo->tbo.resource->mem_type != TTM_PL_PRIV))
|
||||||
goto fallback;
|
goto fallback;
|
||||||
|
|
||||||
io_mapping_unmap_atomic(pmap);
|
io_mapping_unmap_atomic(pmap);
|
||||||
|
@ -131,7 +131,7 @@ static void qxl_bo_move_notify(struct ttm_buffer_object *bo,
|
|||||||
qbo = to_qxl_bo(bo);
|
qbo = to_qxl_bo(bo);
|
||||||
qdev = to_qxl(qbo->tbo.base.dev);
|
qdev = to_qxl(qbo->tbo.base.dev);
|
||||||
|
|
||||||
if (bo->mem.mem_type == TTM_PL_PRIV && qbo->surface_id)
|
if (bo->resource->mem_type == TTM_PL_PRIV && qbo->surface_id)
|
||||||
qxl_surface_evict(qdev, qbo, new_mem ? true : false);
|
qxl_surface_evict(qdev, qbo, new_mem ? true : false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -140,7 +140,7 @@ static int qxl_bo_move(struct ttm_buffer_object *bo, bool evict,
|
|||||||
struct ttm_resource *new_mem,
|
struct ttm_resource *new_mem,
|
||||||
struct ttm_place *hop)
|
struct ttm_place *hop)
|
||||||
{
|
{
|
||||||
struct ttm_resource *old_mem = &bo->mem;
|
struct ttm_resource *old_mem = bo->resource;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
qxl_bo_move_notify(bo, new_mem);
|
qxl_bo_move_notify(bo, new_mem);
|
||||||
|
@ -400,8 +400,8 @@ static int cmp_size_smaller_first(void *priv, const struct list_head *a,
|
|||||||
struct radeon_bo_list *lb = list_entry(b, struct radeon_bo_list, tv.head);
|
struct radeon_bo_list *lb = list_entry(b, struct radeon_bo_list, tv.head);
|
||||||
|
|
||||||
/* Sort A before B if A is smaller. */
|
/* Sort A before B if A is smaller. */
|
||||||
return (int)la->robj->tbo.mem.num_pages -
|
return (int)la->robj->tbo.resource->num_pages -
|
||||||
(int)lb->robj->tbo.mem.num_pages;
|
(int)lb->robj->tbo.resource->num_pages;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -516,7 +516,7 @@ static int radeon_bo_vm_update_pte(struct radeon_cs_parser *p,
|
|||||||
}
|
}
|
||||||
|
|
||||||
r = radeon_vm_bo_update(rdev, vm->ib_bo_va,
|
r = radeon_vm_bo_update(rdev, vm->ib_bo_va,
|
||||||
&rdev->ring_tmp_bo.bo->tbo.mem);
|
rdev->ring_tmp_bo.bo->tbo.resource);
|
||||||
if (r)
|
if (r)
|
||||||
return r;
|
return r;
|
||||||
|
|
||||||
@ -530,7 +530,7 @@ static int radeon_bo_vm_update_pte(struct radeon_cs_parser *p,
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
r = radeon_vm_bo_update(rdev, bo_va, &bo->tbo.mem);
|
r = radeon_vm_bo_update(rdev, bo_va, bo->tbo.resource);
|
||||||
if (r)
|
if (r)
|
||||||
return r;
|
return r;
|
||||||
|
|
||||||
|
@ -529,7 +529,7 @@ int radeon_gem_busy_ioctl(struct drm_device *dev, void *data,
|
|||||||
else
|
else
|
||||||
r = 0;
|
r = 0;
|
||||||
|
|
||||||
cur_placement = READ_ONCE(robj->tbo.mem.mem_type);
|
cur_placement = READ_ONCE(robj->tbo.resource->mem_type);
|
||||||
args->domain = radeon_mem_type_to_domain(cur_placement);
|
args->domain = radeon_mem_type_to_domain(cur_placement);
|
||||||
drm_gem_object_put(gobj);
|
drm_gem_object_put(gobj);
|
||||||
return r;
|
return r;
|
||||||
@ -559,7 +559,7 @@ int radeon_gem_wait_idle_ioctl(struct drm_device *dev, void *data,
|
|||||||
r = ret;
|
r = ret;
|
||||||
|
|
||||||
/* Flush HDP cache via MMIO if necessary */
|
/* Flush HDP cache via MMIO if necessary */
|
||||||
cur_placement = READ_ONCE(robj->tbo.mem.mem_type);
|
cur_placement = READ_ONCE(robj->tbo.resource->mem_type);
|
||||||
if (rdev->asic->mmio_hdp_flush &&
|
if (rdev->asic->mmio_hdp_flush &&
|
||||||
radeon_mem_type_to_domain(cur_placement) == RADEON_GEM_DOMAIN_VRAM)
|
radeon_mem_type_to_domain(cur_placement) == RADEON_GEM_DOMAIN_VRAM)
|
||||||
robj->rdev->asic->mmio_hdp_flush(rdev);
|
robj->rdev->asic->mmio_hdp_flush(rdev);
|
||||||
@ -643,7 +643,7 @@ static void radeon_gem_va_update_vm(struct radeon_device *rdev,
|
|||||||
goto error_free;
|
goto error_free;
|
||||||
|
|
||||||
list_for_each_entry(entry, &list, head) {
|
list_for_each_entry(entry, &list, head) {
|
||||||
domain = radeon_mem_type_to_domain(entry->bo->mem.mem_type);
|
domain = radeon_mem_type_to_domain(entry->bo->resource->mem_type);
|
||||||
/* if anything is swapped out don't swap it in here,
|
/* if anything is swapped out don't swap it in here,
|
||||||
just abort and wait for the next CS */
|
just abort and wait for the next CS */
|
||||||
if (domain == RADEON_GEM_DOMAIN_CPU)
|
if (domain == RADEON_GEM_DOMAIN_CPU)
|
||||||
@ -656,7 +656,7 @@ static void radeon_gem_va_update_vm(struct radeon_device *rdev,
|
|||||||
goto error_unlock;
|
goto error_unlock;
|
||||||
|
|
||||||
if (bo_va->it.start)
|
if (bo_va->it.start)
|
||||||
r = radeon_vm_bo_update(rdev, bo_va, &bo_va->bo->tbo.mem);
|
r = radeon_vm_bo_update(rdev, bo_va, bo_va->bo->tbo.resource);
|
||||||
|
|
||||||
error_unlock:
|
error_unlock:
|
||||||
mutex_unlock(&bo_va->vm->mutex);
|
mutex_unlock(&bo_va->vm->mutex);
|
||||||
@ -860,7 +860,7 @@ static int radeon_debugfs_gem_info_show(struct seq_file *m, void *unused)
|
|||||||
unsigned domain;
|
unsigned domain;
|
||||||
const char *placement;
|
const char *placement;
|
||||||
|
|
||||||
domain = radeon_mem_type_to_domain(rbo->tbo.mem.mem_type);
|
domain = radeon_mem_type_to_domain(rbo->tbo.resource->mem_type);
|
||||||
switch (domain) {
|
switch (domain) {
|
||||||
case RADEON_GEM_DOMAIN_VRAM:
|
case RADEON_GEM_DOMAIN_VRAM:
|
||||||
placement = "VRAM";
|
placement = "VRAM";
|
||||||
|
@ -76,7 +76,7 @@ static void radeon_ttm_bo_destroy(struct ttm_buffer_object *tbo)
|
|||||||
|
|
||||||
bo = container_of(tbo, struct radeon_bo, tbo);
|
bo = container_of(tbo, struct radeon_bo, tbo);
|
||||||
|
|
||||||
radeon_update_memory_usage(bo, bo->tbo.mem.mem_type, -1);
|
radeon_update_memory_usage(bo, bo->tbo.resource->mem_type, -1);
|
||||||
|
|
||||||
mutex_lock(&bo->rdev->gem.mutex);
|
mutex_lock(&bo->rdev->gem.mutex);
|
||||||
list_del_init(&bo->list);
|
list_del_init(&bo->list);
|
||||||
@ -250,7 +250,7 @@ int radeon_bo_kmap(struct radeon_bo *bo, void **ptr)
|
|||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
r = ttm_bo_kmap(&bo->tbo, 0, bo->tbo.mem.num_pages, &bo->kmap);
|
r = ttm_bo_kmap(&bo->tbo, 0, bo->tbo.resource->num_pages, &bo->kmap);
|
||||||
if (r) {
|
if (r) {
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
@ -359,7 +359,7 @@ void radeon_bo_unpin(struct radeon_bo *bo)
|
|||||||
{
|
{
|
||||||
ttm_bo_unpin(&bo->tbo);
|
ttm_bo_unpin(&bo->tbo);
|
||||||
if (!bo->tbo.pin_count) {
|
if (!bo->tbo.pin_count) {
|
||||||
if (bo->tbo.mem.mem_type == TTM_PL_VRAM)
|
if (bo->tbo.resource->mem_type == TTM_PL_VRAM)
|
||||||
bo->rdev->vram_pin_size -= radeon_bo_size(bo);
|
bo->rdev->vram_pin_size -= radeon_bo_size(bo);
|
||||||
else
|
else
|
||||||
bo->rdev->gart_pin_size -= radeon_bo_size(bo);
|
bo->rdev->gart_pin_size -= radeon_bo_size(bo);
|
||||||
@ -506,7 +506,7 @@ int radeon_bo_list_validate(struct radeon_device *rdev,
|
|||||||
u32 domain = lobj->preferred_domains;
|
u32 domain = lobj->preferred_domains;
|
||||||
u32 allowed = lobj->allowed_domains;
|
u32 allowed = lobj->allowed_domains;
|
||||||
u32 current_domain =
|
u32 current_domain =
|
||||||
radeon_mem_type_to_domain(bo->tbo.mem.mem_type);
|
radeon_mem_type_to_domain(bo->tbo.resource->mem_type);
|
||||||
|
|
||||||
/* Check if this buffer will be moved and don't move it
|
/* Check if this buffer will be moved and don't move it
|
||||||
* if we have moved too many buffers for this IB already.
|
* if we have moved too many buffers for this IB already.
|
||||||
@ -605,7 +605,7 @@ int radeon_bo_get_surface_reg(struct radeon_bo *bo)
|
|||||||
|
|
||||||
out:
|
out:
|
||||||
radeon_set_surface_reg(rdev, i, bo->tiling_flags, bo->pitch,
|
radeon_set_surface_reg(rdev, i, bo->tiling_flags, bo->pitch,
|
||||||
bo->tbo.mem.start << PAGE_SHIFT,
|
bo->tbo.resource->start << PAGE_SHIFT,
|
||||||
bo->tbo.base.size);
|
bo->tbo.base.size);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -711,7 +711,7 @@ int radeon_bo_check_tiling(struct radeon_bo *bo, bool has_moved,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bo->tbo.mem.mem_type != TTM_PL_VRAM) {
|
if (bo->tbo.resource->mem_type != TTM_PL_VRAM) {
|
||||||
if (!has_moved)
|
if (!has_moved)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -743,7 +743,7 @@ void radeon_bo_move_notify(struct ttm_buffer_object *bo,
|
|||||||
if (!new_mem)
|
if (!new_mem)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
radeon_update_memory_usage(rbo, bo->mem.mem_type, -1);
|
radeon_update_memory_usage(rbo, bo->resource->mem_type, -1);
|
||||||
radeon_update_memory_usage(rbo, new_mem->mem_type, 1);
|
radeon_update_memory_usage(rbo, new_mem->mem_type, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -760,11 +760,11 @@ vm_fault_t radeon_bo_fault_reserve_notify(struct ttm_buffer_object *bo)
|
|||||||
rbo = container_of(bo, struct radeon_bo, tbo);
|
rbo = container_of(bo, struct radeon_bo, tbo);
|
||||||
radeon_bo_check_tiling(rbo, 0, 0);
|
radeon_bo_check_tiling(rbo, 0, 0);
|
||||||
rdev = rbo->rdev;
|
rdev = rbo->rdev;
|
||||||
if (bo->mem.mem_type != TTM_PL_VRAM)
|
if (bo->resource->mem_type != TTM_PL_VRAM)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
size = bo->mem.num_pages << PAGE_SHIFT;
|
size = bo->resource->num_pages << PAGE_SHIFT;
|
||||||
offset = bo->mem.start << PAGE_SHIFT;
|
offset = bo->resource->start << PAGE_SHIFT;
|
||||||
if ((offset + size) <= rdev->mc.visible_vram_size)
|
if ((offset + size) <= rdev->mc.visible_vram_size)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -786,7 +786,7 @@ vm_fault_t radeon_bo_fault_reserve_notify(struct ttm_buffer_object *bo)
|
|||||||
radeon_ttm_placement_from_domain(rbo, RADEON_GEM_DOMAIN_GTT);
|
radeon_ttm_placement_from_domain(rbo, RADEON_GEM_DOMAIN_GTT);
|
||||||
r = ttm_bo_validate(bo, &rbo->placement, &ctx);
|
r = ttm_bo_validate(bo, &rbo->placement, &ctx);
|
||||||
} else if (likely(!r)) {
|
} else if (likely(!r)) {
|
||||||
offset = bo->mem.start << PAGE_SHIFT;
|
offset = bo->resource->start << PAGE_SHIFT;
|
||||||
/* this should never happen */
|
/* this should never happen */
|
||||||
if ((offset + size) > rdev->mc.visible_vram_size)
|
if ((offset + size) > rdev->mc.visible_vram_size)
|
||||||
return VM_FAULT_SIGBUS;
|
return VM_FAULT_SIGBUS;
|
||||||
|
@ -95,7 +95,7 @@ static inline u64 radeon_bo_gpu_offset(struct radeon_bo *bo)
|
|||||||
|
|
||||||
rdev = radeon_get_rdev(bo->tbo.bdev);
|
rdev = radeon_get_rdev(bo->tbo.bdev);
|
||||||
|
|
||||||
switch (bo->tbo.mem.mem_type) {
|
switch (bo->tbo.resource->mem_type) {
|
||||||
case TTM_PL_TT:
|
case TTM_PL_TT:
|
||||||
start = rdev->mc.gtt_start;
|
start = rdev->mc.gtt_start;
|
||||||
break;
|
break;
|
||||||
@ -104,7 +104,7 @@ static inline u64 radeon_bo_gpu_offset(struct radeon_bo *bo)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return (bo->tbo.mem.start << PAGE_SHIFT) + start;
|
return (bo->tbo.resource->start << PAGE_SHIFT) + start;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline unsigned long radeon_bo_size(struct radeon_bo *bo)
|
static inline unsigned long radeon_bo_size(struct radeon_bo *bo)
|
||||||
|
@ -154,7 +154,7 @@ static void radeon_unmap_vram_bos(struct radeon_device *rdev)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
list_for_each_entry_safe(bo, n, &rdev->gem.objects, list) {
|
list_for_each_entry_safe(bo, n, &rdev->gem.objects, list) {
|
||||||
if (bo->tbo.mem.mem_type == TTM_PL_VRAM)
|
if (bo->tbo.resource->mem_type == TTM_PL_VRAM)
|
||||||
ttm_bo_unmap_virtual(&bo->tbo);
|
ttm_bo_unmap_virtual(&bo->tbo);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,7 @@ TRACE_EVENT(radeon_bo_create,
|
|||||||
|
|
||||||
TP_fast_assign(
|
TP_fast_assign(
|
||||||
__entry->bo = bo;
|
__entry->bo = bo;
|
||||||
__entry->pages = bo->tbo.mem.num_pages;
|
__entry->pages = bo->tbo.resource->num_pages;
|
||||||
),
|
),
|
||||||
TP_printk("bo=%p, pages=%u", __entry->bo, __entry->pages)
|
TP_printk("bo=%p, pages=%u", __entry->bo, __entry->pages)
|
||||||
);
|
);
|
||||||
|
@ -98,12 +98,12 @@ static void radeon_evict_flags(struct ttm_buffer_object *bo,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
rbo = container_of(bo, struct radeon_bo, tbo);
|
rbo = container_of(bo, struct radeon_bo, tbo);
|
||||||
switch (bo->mem.mem_type) {
|
switch (bo->resource->mem_type) {
|
||||||
case TTM_PL_VRAM:
|
case TTM_PL_VRAM:
|
||||||
if (rbo->rdev->ring[radeon_copy_ring_index(rbo->rdev)].ready == false)
|
if (rbo->rdev->ring[radeon_copy_ring_index(rbo->rdev)].ready == false)
|
||||||
radeon_ttm_placement_from_domain(rbo, RADEON_GEM_DOMAIN_CPU);
|
radeon_ttm_placement_from_domain(rbo, RADEON_GEM_DOMAIN_CPU);
|
||||||
else if (rbo->rdev->mc.visible_vram_size < rbo->rdev->mc.real_vram_size &&
|
else if (rbo->rdev->mc.visible_vram_size < rbo->rdev->mc.real_vram_size &&
|
||||||
bo->mem.start < (rbo->rdev->mc.visible_vram_size >> PAGE_SHIFT)) {
|
bo->resource->start < (rbo->rdev->mc.visible_vram_size >> PAGE_SHIFT)) {
|
||||||
unsigned fpfn = rbo->rdev->mc.visible_vram_size >> PAGE_SHIFT;
|
unsigned fpfn = rbo->rdev->mc.visible_vram_size >> PAGE_SHIFT;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@ -195,9 +195,9 @@ static int radeon_bo_move(struct ttm_buffer_object *bo, bool evict,
|
|||||||
struct ttm_resource *new_mem,
|
struct ttm_resource *new_mem,
|
||||||
struct ttm_place *hop)
|
struct ttm_place *hop)
|
||||||
{
|
{
|
||||||
|
struct ttm_resource *old_mem = bo->resource;
|
||||||
struct radeon_device *rdev;
|
struct radeon_device *rdev;
|
||||||
struct radeon_bo *rbo;
|
struct radeon_bo *rbo;
|
||||||
struct ttm_resource *old_mem = &bo->mem;
|
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
if (new_mem->mem_type == TTM_PL_TT) {
|
if (new_mem->mem_type == TTM_PL_TT) {
|
||||||
@ -229,7 +229,7 @@ static int radeon_bo_move(struct ttm_buffer_object *bo, bool evict,
|
|||||||
if (old_mem->mem_type == TTM_PL_TT &&
|
if (old_mem->mem_type == TTM_PL_TT &&
|
||||||
new_mem->mem_type == TTM_PL_SYSTEM) {
|
new_mem->mem_type == TTM_PL_SYSTEM) {
|
||||||
radeon_ttm_tt_unbind(bo->bdev, bo->ttm);
|
radeon_ttm_tt_unbind(bo->bdev, bo->ttm);
|
||||||
ttm_resource_free(bo, &bo->mem);
|
ttm_resource_free(bo, bo->resource);
|
||||||
ttm_bo_assign_mem(bo, new_mem);
|
ttm_bo_assign_mem(bo, new_mem);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -58,7 +58,7 @@ static void ttm_bo_mem_space_debug(struct ttm_buffer_object *bo,
|
|||||||
int i, mem_type;
|
int i, mem_type;
|
||||||
|
|
||||||
drm_printf(&p, "No space for %p (%lu pages, %zuK, %zuM)\n",
|
drm_printf(&p, "No space for %p (%lu pages, %zuK, %zuM)\n",
|
||||||
bo, bo->mem.num_pages, bo->base.size >> 10,
|
bo, bo->resource->num_pages, bo->base.size >> 10,
|
||||||
bo->base.size >> 20);
|
bo->base.size >> 20);
|
||||||
for (i = 0; i < placement->num_placement; i++) {
|
for (i = 0; i < placement->num_placement; i++) {
|
||||||
mem_type = placement->placement[i].mem_type;
|
mem_type = placement->placement[i].mem_type;
|
||||||
@ -109,7 +109,7 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
|
|||||||
bdev->funcs->del_from_lru_notify(bo);
|
bdev->funcs->del_from_lru_notify(bo);
|
||||||
|
|
||||||
if (bulk && !bo->pin_count) {
|
if (bulk && !bo->pin_count) {
|
||||||
switch (bo->mem.mem_type) {
|
switch (bo->resource->mem_type) {
|
||||||
case TTM_PL_TT:
|
case TTM_PL_TT:
|
||||||
ttm_bo_bulk_move_set_pos(&bulk->tt[bo->priority], bo);
|
ttm_bo_bulk_move_set_pos(&bulk->tt[bo->priority], bo);
|
||||||
break;
|
break;
|
||||||
@ -163,11 +163,13 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
|
|||||||
struct ttm_operation_ctx *ctx,
|
struct ttm_operation_ctx *ctx,
|
||||||
struct ttm_place *hop)
|
struct ttm_place *hop)
|
||||||
{
|
{
|
||||||
|
struct ttm_resource_manager *old_man, *new_man;
|
||||||
struct ttm_device *bdev = bo->bdev;
|
struct ttm_device *bdev = bo->bdev;
|
||||||
struct ttm_resource_manager *old_man = ttm_manager_type(bdev, bo->mem.mem_type);
|
|
||||||
struct ttm_resource_manager *new_man = ttm_manager_type(bdev, mem->mem_type);
|
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
old_man = ttm_manager_type(bdev, bo->resource->mem_type);
|
||||||
|
new_man = ttm_manager_type(bdev, mem->mem_type);
|
||||||
|
|
||||||
ttm_bo_unmap_virtual(bo);
|
ttm_bo_unmap_virtual(bo);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -200,7 +202,7 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
out_err:
|
out_err:
|
||||||
new_man = ttm_manager_type(bdev, bo->mem.mem_type);
|
new_man = ttm_manager_type(bdev, bo->resource->mem_type);
|
||||||
if (!new_man->use_tt)
|
if (!new_man->use_tt)
|
||||||
ttm_bo_tt_destroy(bo);
|
ttm_bo_tt_destroy(bo);
|
||||||
|
|
||||||
@ -221,7 +223,7 @@ static void ttm_bo_cleanup_memtype_use(struct ttm_buffer_object *bo)
|
|||||||
bo->bdev->funcs->delete_mem_notify(bo);
|
bo->bdev->funcs->delete_mem_notify(bo);
|
||||||
|
|
||||||
ttm_bo_tt_destroy(bo);
|
ttm_bo_tt_destroy(bo);
|
||||||
ttm_resource_free(bo, &bo->mem);
|
ttm_resource_free(bo, bo->resource);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
|
static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
|
||||||
@ -417,7 +419,7 @@ static void ttm_bo_release(struct kref *kref)
|
|||||||
bo->bdev->funcs->release_notify(bo);
|
bo->bdev->funcs->release_notify(bo);
|
||||||
|
|
||||||
drm_vma_offset_remove(bdev->vma_manager, &bo->base.vma_node);
|
drm_vma_offset_remove(bdev->vma_manager, &bo->base.vma_node);
|
||||||
ttm_mem_io_free(bdev, &bo->mem);
|
ttm_mem_io_free(bdev, bo->resource);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!dma_resv_test_signaled_rcu(bo->base.resv, true) ||
|
if (!dma_resv_test_signaled_rcu(bo->base.resv, true) ||
|
||||||
@ -438,7 +440,7 @@ static void ttm_bo_release(struct kref *kref)
|
|||||||
*/
|
*/
|
||||||
if (bo->pin_count) {
|
if (bo->pin_count) {
|
||||||
bo->pin_count = 0;
|
bo->pin_count = 0;
|
||||||
ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
|
ttm_bo_move_to_lru_tail(bo, bo->resource, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
kref_init(&bo->kref);
|
kref_init(&bo->kref);
|
||||||
@ -534,8 +536,8 @@ bool ttm_bo_eviction_valuable(struct ttm_buffer_object *bo,
|
|||||||
/* Don't evict this BO if it's outside of the
|
/* Don't evict this BO if it's outside of the
|
||||||
* requested placement range
|
* requested placement range
|
||||||
*/
|
*/
|
||||||
if (place->fpfn >= (bo->mem.start + bo->mem.num_pages) ||
|
if (place->fpfn >= (bo->resource->start + bo->resource->num_pages) ||
|
||||||
(place->lpfn && place->lpfn <= bo->mem.start))
|
(place->lpfn && place->lpfn <= bo->resource->start))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -851,7 +853,7 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
|
|||||||
}
|
}
|
||||||
|
|
||||||
error:
|
error:
|
||||||
if (bo->mem.mem_type == TTM_PL_SYSTEM && !bo->pin_count)
|
if (bo->resource->mem_type == TTM_PL_SYSTEM && !bo->pin_count)
|
||||||
ttm_bo_move_to_lru_tail_unlocked(bo);
|
ttm_bo_move_to_lru_tail_unlocked(bo);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
@ -987,7 +989,7 @@ int ttm_bo_validate(struct ttm_buffer_object *bo,
|
|||||||
/*
|
/*
|
||||||
* Check whether we need to move buffer.
|
* Check whether we need to move buffer.
|
||||||
*/
|
*/
|
||||||
if (!ttm_bo_mem_compat(placement, &bo->mem, &new_flags)) {
|
if (!ttm_bo_mem_compat(placement, bo->resource, &new_flags)) {
|
||||||
ret = ttm_bo_move_buffer(bo, placement, ctx);
|
ret = ttm_bo_move_buffer(bo, placement, ctx);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
@ -995,7 +997,7 @@ int ttm_bo_validate(struct ttm_buffer_object *bo,
|
|||||||
/*
|
/*
|
||||||
* We might need to add a TTM.
|
* We might need to add a TTM.
|
||||||
*/
|
*/
|
||||||
if (bo->mem.mem_type == TTM_PL_SYSTEM) {
|
if (bo->resource->mem_type == TTM_PL_SYSTEM) {
|
||||||
ret = ttm_tt_create(bo, true);
|
ret = ttm_tt_create(bo, true);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
@ -1027,7 +1029,8 @@ int ttm_bo_init_reserved(struct ttm_device *bdev,
|
|||||||
bo->bdev = bdev;
|
bo->bdev = bdev;
|
||||||
bo->type = type;
|
bo->type = type;
|
||||||
bo->page_alignment = page_alignment;
|
bo->page_alignment = page_alignment;
|
||||||
ttm_resource_alloc(bo, &sys_mem, &bo->mem);
|
bo->resource = &bo->_mem;
|
||||||
|
ttm_resource_alloc(bo, &sys_mem, bo->resource);
|
||||||
bo->moving = NULL;
|
bo->moving = NULL;
|
||||||
bo->pin_count = 0;
|
bo->pin_count = 0;
|
||||||
bo->sg = sg;
|
bo->sg = sg;
|
||||||
@ -1046,7 +1049,7 @@ int ttm_bo_init_reserved(struct ttm_device *bdev,
|
|||||||
if (bo->type == ttm_bo_type_device ||
|
if (bo->type == ttm_bo_type_device ||
|
||||||
bo->type == ttm_bo_type_sg)
|
bo->type == ttm_bo_type_sg)
|
||||||
ret = drm_vma_offset_add(bdev->vma_manager, &bo->base.vma_node,
|
ret = drm_vma_offset_add(bdev->vma_manager, &bo->base.vma_node,
|
||||||
bo->mem.num_pages);
|
bo->resource->num_pages);
|
||||||
|
|
||||||
/* passed reservation objects should already be locked,
|
/* passed reservation objects should already be locked,
|
||||||
* since otherwise lockdep will be angered in radeon.
|
* since otherwise lockdep will be angered in radeon.
|
||||||
@ -1108,7 +1111,7 @@ void ttm_bo_unmap_virtual(struct ttm_buffer_object *bo)
|
|||||||
struct ttm_device *bdev = bo->bdev;
|
struct ttm_device *bdev = bo->bdev;
|
||||||
|
|
||||||
drm_vma_node_unmap(&bo->base.vma_node, bdev->dev_mapping);
|
drm_vma_node_unmap(&bo->base.vma_node, bdev->dev_mapping);
|
||||||
ttm_mem_io_free(bdev, &bo->mem);
|
ttm_mem_io_free(bdev, bo->resource);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(ttm_bo_unmap_virtual);
|
EXPORT_SYMBOL(ttm_bo_unmap_virtual);
|
||||||
|
|
||||||
@ -1165,7 +1168,7 @@ int ttm_bo_swapout(struct ttm_buffer_object *bo, struct ttm_operation_ctx *ctx,
|
|||||||
/*
|
/*
|
||||||
* Move to system cached
|
* Move to system cached
|
||||||
*/
|
*/
|
||||||
if (bo->mem.mem_type != TTM_PL_SYSTEM) {
|
if (bo->resource->mem_type != TTM_PL_SYSTEM) {
|
||||||
struct ttm_operation_ctx ctx = { false, false };
|
struct ttm_operation_ctx ctx = { false, false };
|
||||||
struct ttm_resource evict_mem;
|
struct ttm_resource evict_mem;
|
||||||
struct ttm_place place, hop;
|
struct ttm_place place, hop;
|
||||||
|
@ -179,7 +179,7 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo,
|
|||||||
struct ttm_device *bdev = bo->bdev;
|
struct ttm_device *bdev = bo->bdev;
|
||||||
struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
|
struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
|
||||||
struct ttm_tt *ttm = bo->ttm;
|
struct ttm_tt *ttm = bo->ttm;
|
||||||
struct ttm_resource *old_mem = &bo->mem;
|
struct ttm_resource *old_mem = bo->resource;
|
||||||
struct ttm_resource old_copy = *old_mem;
|
struct ttm_resource old_copy = *old_mem;
|
||||||
void *old_iomap;
|
void *old_iomap;
|
||||||
void *new_iomap;
|
void *new_iomap;
|
||||||
@ -365,24 +365,23 @@ static int ttm_bo_ioremap(struct ttm_buffer_object *bo,
|
|||||||
unsigned long size,
|
unsigned long size,
|
||||||
struct ttm_bo_kmap_obj *map)
|
struct ttm_bo_kmap_obj *map)
|
||||||
{
|
{
|
||||||
struct ttm_resource *mem = &bo->mem;
|
struct ttm_resource *mem = bo->resource;
|
||||||
|
|
||||||
if (bo->mem.bus.addr) {
|
if (bo->resource->bus.addr) {
|
||||||
map->bo_kmap_type = ttm_bo_map_premapped;
|
map->bo_kmap_type = ttm_bo_map_premapped;
|
||||||
map->virtual = (void *)(((u8 *)bo->mem.bus.addr) + offset);
|
map->virtual = ((u8 *)bo->resource->bus.addr) + offset;
|
||||||
} else {
|
} else {
|
||||||
|
resource_size_t res = bo->resource->bus.offset + offset;
|
||||||
|
|
||||||
map->bo_kmap_type = ttm_bo_map_iomap;
|
map->bo_kmap_type = ttm_bo_map_iomap;
|
||||||
if (mem->bus.caching == ttm_write_combined)
|
if (mem->bus.caching == ttm_write_combined)
|
||||||
map->virtual = ioremap_wc(bo->mem.bus.offset + offset,
|
map->virtual = ioremap_wc(res, size);
|
||||||
size);
|
|
||||||
#ifdef CONFIG_X86
|
#ifdef CONFIG_X86
|
||||||
else if (mem->bus.caching == ttm_cached)
|
else if (mem->bus.caching == ttm_cached)
|
||||||
map->virtual = ioremap_cache(bo->mem.bus.offset + offset,
|
map->virtual = ioremap_cache(res, size);
|
||||||
size);
|
|
||||||
#endif
|
#endif
|
||||||
else
|
else
|
||||||
map->virtual = ioremap(bo->mem.bus.offset + offset,
|
map->virtual = ioremap(res, size);
|
||||||
size);
|
|
||||||
}
|
}
|
||||||
return (!map->virtual) ? -ENOMEM : 0;
|
return (!map->virtual) ? -ENOMEM : 0;
|
||||||
}
|
}
|
||||||
@ -392,7 +391,7 @@ static int ttm_bo_kmap_ttm(struct ttm_buffer_object *bo,
|
|||||||
unsigned long num_pages,
|
unsigned long num_pages,
|
||||||
struct ttm_bo_kmap_obj *map)
|
struct ttm_bo_kmap_obj *map)
|
||||||
{
|
{
|
||||||
struct ttm_resource *mem = &bo->mem;
|
struct ttm_resource *mem = bo->resource;
|
||||||
struct ttm_operation_ctx ctx = {
|
struct ttm_operation_ctx ctx = {
|
||||||
.interruptible = false,
|
.interruptible = false,
|
||||||
.no_wait_gpu = false
|
.no_wait_gpu = false
|
||||||
@ -438,15 +437,15 @@ int ttm_bo_kmap(struct ttm_buffer_object *bo,
|
|||||||
|
|
||||||
map->virtual = NULL;
|
map->virtual = NULL;
|
||||||
map->bo = bo;
|
map->bo = bo;
|
||||||
if (num_pages > bo->mem.num_pages)
|
if (num_pages > bo->resource->num_pages)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
if ((start_page + num_pages) > bo->mem.num_pages)
|
if ((start_page + num_pages) > bo->resource->num_pages)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
ret = ttm_mem_io_reserve(bo->bdev, &bo->mem);
|
ret = ttm_mem_io_reserve(bo->bdev, bo->resource);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
if (!bo->mem.bus.is_iomem) {
|
if (!bo->resource->bus.is_iomem) {
|
||||||
return ttm_bo_kmap_ttm(bo, start_page, num_pages, map);
|
return ttm_bo_kmap_ttm(bo, start_page, num_pages, map);
|
||||||
} else {
|
} else {
|
||||||
offset = start_page << PAGE_SHIFT;
|
offset = start_page << PAGE_SHIFT;
|
||||||
@ -475,7 +474,7 @@ void ttm_bo_kunmap(struct ttm_bo_kmap_obj *map)
|
|||||||
default:
|
default:
|
||||||
BUG();
|
BUG();
|
||||||
}
|
}
|
||||||
ttm_mem_io_free(map->bo->bdev, &map->bo->mem);
|
ttm_mem_io_free(map->bo->bdev, map->bo->resource);
|
||||||
map->virtual = NULL;
|
map->virtual = NULL;
|
||||||
map->page = NULL;
|
map->page = NULL;
|
||||||
}
|
}
|
||||||
@ -483,7 +482,7 @@ EXPORT_SYMBOL(ttm_bo_kunmap);
|
|||||||
|
|
||||||
int ttm_bo_vmap(struct ttm_buffer_object *bo, struct dma_buf_map *map)
|
int ttm_bo_vmap(struct ttm_buffer_object *bo, struct dma_buf_map *map)
|
||||||
{
|
{
|
||||||
struct ttm_resource *mem = &bo->mem;
|
struct ttm_resource *mem = bo->resource;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
ret = ttm_mem_io_reserve(bo->bdev, mem);
|
ret = ttm_mem_io_reserve(bo->bdev, mem);
|
||||||
@ -542,7 +541,7 @@ EXPORT_SYMBOL(ttm_bo_vmap);
|
|||||||
|
|
||||||
void ttm_bo_vunmap(struct ttm_buffer_object *bo, struct dma_buf_map *map)
|
void ttm_bo_vunmap(struct ttm_buffer_object *bo, struct dma_buf_map *map)
|
||||||
{
|
{
|
||||||
struct ttm_resource *mem = &bo->mem;
|
struct ttm_resource *mem = bo->resource;
|
||||||
|
|
||||||
if (dma_buf_map_is_null(map))
|
if (dma_buf_map_is_null(map))
|
||||||
return;
|
return;
|
||||||
@ -553,7 +552,7 @@ void ttm_bo_vunmap(struct ttm_buffer_object *bo, struct dma_buf_map *map)
|
|||||||
iounmap(map->vaddr_iomem);
|
iounmap(map->vaddr_iomem);
|
||||||
dma_buf_map_clear(map);
|
dma_buf_map_clear(map);
|
||||||
|
|
||||||
ttm_mem_io_free(bo->bdev, &bo->mem);
|
ttm_mem_io_free(bo->bdev, bo->resource);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(ttm_bo_vunmap);
|
EXPORT_SYMBOL(ttm_bo_vunmap);
|
||||||
|
|
||||||
@ -567,7 +566,7 @@ static int ttm_bo_wait_free_node(struct ttm_buffer_object *bo,
|
|||||||
|
|
||||||
if (!dst_use_tt)
|
if (!dst_use_tt)
|
||||||
ttm_bo_tt_destroy(bo);
|
ttm_bo_tt_destroy(bo);
|
||||||
ttm_resource_free(bo, &bo->mem);
|
ttm_resource_free(bo, bo->resource);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -615,7 +614,9 @@ static void ttm_bo_move_pipeline_evict(struct ttm_buffer_object *bo,
|
|||||||
struct dma_fence *fence)
|
struct dma_fence *fence)
|
||||||
{
|
{
|
||||||
struct ttm_device *bdev = bo->bdev;
|
struct ttm_device *bdev = bo->bdev;
|
||||||
struct ttm_resource_manager *from = ttm_manager_type(bdev, bo->mem.mem_type);
|
struct ttm_resource_manager *from;
|
||||||
|
|
||||||
|
from = ttm_manager_type(bdev, bo->resource->mem_type);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* BO doesn't have a TTM we need to bind/unbind. Just remember
|
* BO doesn't have a TTM we need to bind/unbind. Just remember
|
||||||
@ -628,7 +629,7 @@ static void ttm_bo_move_pipeline_evict(struct ttm_buffer_object *bo,
|
|||||||
}
|
}
|
||||||
spin_unlock(&from->move_lock);
|
spin_unlock(&from->move_lock);
|
||||||
|
|
||||||
ttm_resource_free(bo, &bo->mem);
|
ttm_resource_free(bo, bo->resource);
|
||||||
|
|
||||||
dma_fence_put(bo->moving);
|
dma_fence_put(bo->moving);
|
||||||
bo->moving = dma_fence_get(fence);
|
bo->moving = dma_fence_get(fence);
|
||||||
@ -641,7 +642,7 @@ int ttm_bo_move_accel_cleanup(struct ttm_buffer_object *bo,
|
|||||||
struct ttm_resource *new_mem)
|
struct ttm_resource *new_mem)
|
||||||
{
|
{
|
||||||
struct ttm_device *bdev = bo->bdev;
|
struct ttm_device *bdev = bo->bdev;
|
||||||
struct ttm_resource_manager *from = ttm_manager_type(bdev, bo->mem.mem_type);
|
struct ttm_resource_manager *from = ttm_manager_type(bdev, bo->resource->mem_type);
|
||||||
struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
|
struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
@ -677,7 +678,7 @@ int ttm_bo_pipeline_gutting(struct ttm_buffer_object *bo)
|
|||||||
if (ret)
|
if (ret)
|
||||||
ttm_bo_wait(bo, false, false);
|
ttm_bo_wait(bo, false, false);
|
||||||
|
|
||||||
ttm_resource_alloc(bo, &sys_mem, &bo->mem);
|
ttm_resource_alloc(bo, &sys_mem, bo->resource);
|
||||||
bo->ttm = NULL;
|
bo->ttm = NULL;
|
||||||
|
|
||||||
dma_resv_unlock(&ghost->base._resv);
|
dma_resv_unlock(&ghost->base._resv);
|
||||||
|
@ -102,7 +102,7 @@ static unsigned long ttm_bo_io_mem_pfn(struct ttm_buffer_object *bo,
|
|||||||
if (bdev->funcs->io_mem_pfn)
|
if (bdev->funcs->io_mem_pfn)
|
||||||
return bdev->funcs->io_mem_pfn(bo, page_offset);
|
return bdev->funcs->io_mem_pfn(bo, page_offset);
|
||||||
|
|
||||||
return (bo->mem.bus.offset >> PAGE_SHIFT) + page_offset;
|
return (bo->resource->bus.offset >> PAGE_SHIFT) + page_offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -200,10 +200,10 @@ static vm_fault_t ttm_bo_vm_insert_huge(struct vm_fault *vmf,
|
|||||||
|
|
||||||
/* Fault should not cross bo boundary. */
|
/* Fault should not cross bo boundary. */
|
||||||
page_offset &= ~(fault_page_size - 1);
|
page_offset &= ~(fault_page_size - 1);
|
||||||
if (page_offset + fault_page_size > bo->mem.num_pages)
|
if (page_offset + fault_page_size > bo->resource->num_pages)
|
||||||
goto out_fallback;
|
goto out_fallback;
|
||||||
|
|
||||||
if (bo->mem.bus.is_iomem)
|
if (bo->resource->bus.is_iomem)
|
||||||
pfn = ttm_bo_io_mem_pfn(bo, page_offset);
|
pfn = ttm_bo_io_mem_pfn(bo, page_offset);
|
||||||
else
|
else
|
||||||
pfn = page_to_pfn(ttm->pages[page_offset]);
|
pfn = page_to_pfn(ttm->pages[page_offset]);
|
||||||
@ -213,7 +213,7 @@ static vm_fault_t ttm_bo_vm_insert_huge(struct vm_fault *vmf,
|
|||||||
goto out_fallback;
|
goto out_fallback;
|
||||||
|
|
||||||
/* Check that memory is contiguous. */
|
/* Check that memory is contiguous. */
|
||||||
if (!bo->mem.bus.is_iomem) {
|
if (!bo->resource->bus.is_iomem) {
|
||||||
for (i = 1; i < fault_page_size; ++i) {
|
for (i = 1; i < fault_page_size; ++i) {
|
||||||
if (page_to_pfn(ttm->pages[page_offset + i]) != pfn + i)
|
if (page_to_pfn(ttm->pages[page_offset + i]) != pfn + i)
|
||||||
goto out_fallback;
|
goto out_fallback;
|
||||||
@ -299,7 +299,7 @@ vm_fault_t ttm_bo_vm_fault_reserved(struct vm_fault *vmf,
|
|||||||
if (unlikely(ret != 0))
|
if (unlikely(ret != 0))
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
err = ttm_mem_io_reserve(bdev, &bo->mem);
|
err = ttm_mem_io_reserve(bdev, bo->resource);
|
||||||
if (unlikely(err != 0))
|
if (unlikely(err != 0))
|
||||||
return VM_FAULT_SIGBUS;
|
return VM_FAULT_SIGBUS;
|
||||||
|
|
||||||
@ -308,11 +308,11 @@ vm_fault_t ttm_bo_vm_fault_reserved(struct vm_fault *vmf,
|
|||||||
page_last = vma_pages(vma) + vma->vm_pgoff -
|
page_last = vma_pages(vma) + vma->vm_pgoff -
|
||||||
drm_vma_node_start(&bo->base.vma_node);
|
drm_vma_node_start(&bo->base.vma_node);
|
||||||
|
|
||||||
if (unlikely(page_offset >= bo->mem.num_pages))
|
if (unlikely(page_offset >= bo->resource->num_pages))
|
||||||
return VM_FAULT_SIGBUS;
|
return VM_FAULT_SIGBUS;
|
||||||
|
|
||||||
prot = ttm_io_prot(bo, &bo->mem, prot);
|
prot = ttm_io_prot(bo, bo->resource, prot);
|
||||||
if (!bo->mem.bus.is_iomem) {
|
if (!bo->resource->bus.is_iomem) {
|
||||||
struct ttm_operation_ctx ctx = {
|
struct ttm_operation_ctx ctx = {
|
||||||
.interruptible = false,
|
.interruptible = false,
|
||||||
.no_wait_gpu = false,
|
.no_wait_gpu = false,
|
||||||
@ -337,7 +337,7 @@ vm_fault_t ttm_bo_vm_fault_reserved(struct vm_fault *vmf,
|
|||||||
* first page.
|
* first page.
|
||||||
*/
|
*/
|
||||||
for (i = 0; i < num_prefault; ++i) {
|
for (i = 0; i < num_prefault; ++i) {
|
||||||
if (bo->mem.bus.is_iomem) {
|
if (bo->resource->bus.is_iomem) {
|
||||||
pfn = ttm_bo_io_mem_pfn(bo, page_offset);
|
pfn = ttm_bo_io_mem_pfn(bo, page_offset);
|
||||||
} else {
|
} else {
|
||||||
page = ttm->pages[page_offset];
|
page = ttm->pages[page_offset];
|
||||||
@ -521,14 +521,14 @@ int ttm_bo_vm_access(struct vm_area_struct *vma, unsigned long addr,
|
|||||||
<< PAGE_SHIFT);
|
<< PAGE_SHIFT);
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (len < 1 || (offset + len) >> PAGE_SHIFT > bo->mem.num_pages)
|
if (len < 1 || (offset + len) >> PAGE_SHIFT > bo->resource->num_pages)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
ret = ttm_bo_reserve(bo, true, false, NULL);
|
ret = ttm_bo_reserve(bo, true, false, NULL);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
switch (bo->mem.mem_type) {
|
switch (bo->resource->mem_type) {
|
||||||
case TTM_PL_SYSTEM:
|
case TTM_PL_SYSTEM:
|
||||||
if (unlikely(bo->ttm->page_flags & TTM_PAGE_FLAG_SWAPPED)) {
|
if (unlikely(bo->ttm->page_flags & TTM_PAGE_FLAG_SWAPPED)) {
|
||||||
ret = ttm_tt_swapin(bo->ttm);
|
ret = ttm_tt_swapin(bo->ttm);
|
||||||
|
@ -483,10 +483,10 @@ int vmw_bo_cpu_blit(struct ttm_buffer_object *dst,
|
|||||||
d.src_addr = NULL;
|
d.src_addr = NULL;
|
||||||
d.dst_pages = dst->ttm->pages;
|
d.dst_pages = dst->ttm->pages;
|
||||||
d.src_pages = src->ttm->pages;
|
d.src_pages = src->ttm->pages;
|
||||||
d.dst_num_pages = dst->mem.num_pages;
|
d.dst_num_pages = dst->resource->num_pages;
|
||||||
d.src_num_pages = src->mem.num_pages;
|
d.src_num_pages = src->resource->num_pages;
|
||||||
d.dst_prot = ttm_io_prot(dst, &dst->mem, PAGE_KERNEL);
|
d.dst_prot = ttm_io_prot(dst, dst->resource, PAGE_KERNEL);
|
||||||
d.src_prot = ttm_io_prot(src, &src->mem, PAGE_KERNEL);
|
d.src_prot = ttm_io_prot(src, src->resource, PAGE_KERNEL);
|
||||||
d.diff = diff;
|
d.diff = diff;
|
||||||
|
|
||||||
for (j = 0; j < h; ++j) {
|
for (j = 0; j < h; ++j) {
|
||||||
|
@ -103,7 +103,7 @@ int vmw_bo_pin_in_placement(struct vmw_private *dev_priv,
|
|||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
if (buf->base.pin_count > 0)
|
if (buf->base.pin_count > 0)
|
||||||
ret = ttm_bo_mem_compat(placement, &bo->mem,
|
ret = ttm_bo_mem_compat(placement, bo->resource,
|
||||||
&new_flags) == true ? 0 : -EINVAL;
|
&new_flags) == true ? 0 : -EINVAL;
|
||||||
else
|
else
|
||||||
ret = ttm_bo_validate(bo, placement, &ctx);
|
ret = ttm_bo_validate(bo, placement, &ctx);
|
||||||
@ -145,7 +145,7 @@ int vmw_bo_pin_in_vram_or_gmr(struct vmw_private *dev_priv,
|
|||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
if (buf->base.pin_count > 0) {
|
if (buf->base.pin_count > 0) {
|
||||||
ret = ttm_bo_mem_compat(&vmw_vram_gmr_placement, &bo->mem,
|
ret = ttm_bo_mem_compat(&vmw_vram_gmr_placement, bo->resource,
|
||||||
&new_flags) == true ? 0 : -EINVAL;
|
&new_flags) == true ? 0 : -EINVAL;
|
||||||
goto out_unreserve;
|
goto out_unreserve;
|
||||||
}
|
}
|
||||||
@ -211,7 +211,7 @@ int vmw_bo_pin_in_start_of_vram(struct vmw_private *dev_priv,
|
|||||||
uint32_t new_flags;
|
uint32_t new_flags;
|
||||||
|
|
||||||
place = vmw_vram_placement.placement[0];
|
place = vmw_vram_placement.placement[0];
|
||||||
place.lpfn = bo->mem.num_pages;
|
place.lpfn = bo->resource->num_pages;
|
||||||
placement.num_placement = 1;
|
placement.num_placement = 1;
|
||||||
placement.placement = &place;
|
placement.placement = &place;
|
||||||
placement.num_busy_placement = 1;
|
placement.num_busy_placement = 1;
|
||||||
@ -227,22 +227,22 @@ int vmw_bo_pin_in_start_of_vram(struct vmw_private *dev_priv,
|
|||||||
* In that case, evict it first because TTM isn't good at handling
|
* In that case, evict it first because TTM isn't good at handling
|
||||||
* that situation.
|
* that situation.
|
||||||
*/
|
*/
|
||||||
if (bo->mem.mem_type == TTM_PL_VRAM &&
|
if (bo->resource->mem_type == TTM_PL_VRAM &&
|
||||||
bo->mem.start < bo->mem.num_pages &&
|
bo->resource->start < bo->resource->num_pages &&
|
||||||
bo->mem.start > 0 &&
|
bo->resource->start > 0 &&
|
||||||
buf->base.pin_count == 0) {
|
buf->base.pin_count == 0) {
|
||||||
ctx.interruptible = false;
|
ctx.interruptible = false;
|
||||||
(void) ttm_bo_validate(bo, &vmw_sys_placement, &ctx);
|
(void) ttm_bo_validate(bo, &vmw_sys_placement, &ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (buf->base.pin_count > 0)
|
if (buf->base.pin_count > 0)
|
||||||
ret = ttm_bo_mem_compat(&placement, &bo->mem,
|
ret = ttm_bo_mem_compat(&placement, bo->resource,
|
||||||
&new_flags) == true ? 0 : -EINVAL;
|
&new_flags) == true ? 0 : -EINVAL;
|
||||||
else
|
else
|
||||||
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->mem.start != 0);
|
WARN_ON(ret == 0 && bo->resource->start != 0);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
vmw_bo_pin_reserved(buf, true);
|
vmw_bo_pin_reserved(buf, true);
|
||||||
|
|
||||||
@ -293,11 +293,11 @@ err:
|
|||||||
void vmw_bo_get_guest_ptr(const struct ttm_buffer_object *bo,
|
void vmw_bo_get_guest_ptr(const struct ttm_buffer_object *bo,
|
||||||
SVGAGuestPtr *ptr)
|
SVGAGuestPtr *ptr)
|
||||||
{
|
{
|
||||||
if (bo->mem.mem_type == TTM_PL_VRAM) {
|
if (bo->resource->mem_type == TTM_PL_VRAM) {
|
||||||
ptr->gmrId = SVGA_GMR_FRAMEBUFFER;
|
ptr->gmrId = SVGA_GMR_FRAMEBUFFER;
|
||||||
ptr->offset = bo->mem.start << PAGE_SHIFT;
|
ptr->offset = bo->resource->start << PAGE_SHIFT;
|
||||||
} else {
|
} else {
|
||||||
ptr->gmrId = bo->mem.start;
|
ptr->gmrId = bo->resource->start;
|
||||||
ptr->offset = 0;
|
ptr->offset = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -316,7 +316,7 @@ void vmw_bo_pin_reserved(struct vmw_buffer_object *vbo, bool pin)
|
|||||||
struct ttm_place pl;
|
struct ttm_place pl;
|
||||||
struct ttm_placement placement;
|
struct ttm_placement placement;
|
||||||
struct ttm_buffer_object *bo = &vbo->base;
|
struct ttm_buffer_object *bo = &vbo->base;
|
||||||
uint32_t old_mem_type = bo->mem.mem_type;
|
uint32_t old_mem_type = bo->resource->mem_type;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
dma_resv_assert_held(bo->base.resv);
|
dma_resv_assert_held(bo->base.resv);
|
||||||
@ -326,8 +326,8 @@ void vmw_bo_pin_reserved(struct vmw_buffer_object *vbo, bool pin)
|
|||||||
|
|
||||||
pl.fpfn = 0;
|
pl.fpfn = 0;
|
||||||
pl.lpfn = 0;
|
pl.lpfn = 0;
|
||||||
pl.mem_type = bo->mem.mem_type;
|
pl.mem_type = bo->resource->mem_type;
|
||||||
pl.flags = bo->mem.placement;
|
pl.flags = bo->resource->placement;
|
||||||
|
|
||||||
memset(&placement, 0, sizeof(placement));
|
memset(&placement, 0, sizeof(placement));
|
||||||
placement.num_placement = 1;
|
placement.num_placement = 1;
|
||||||
@ -335,7 +335,7 @@ void vmw_bo_pin_reserved(struct vmw_buffer_object *vbo, bool pin)
|
|||||||
|
|
||||||
ret = ttm_bo_validate(bo, &placement, &ctx);
|
ret = ttm_bo_validate(bo, &placement, &ctx);
|
||||||
|
|
||||||
BUG_ON(ret != 0 || bo->mem.mem_type != old_mem_type);
|
BUG_ON(ret != 0 || bo->resource->mem_type != old_mem_type);
|
||||||
|
|
||||||
if (pin)
|
if (pin)
|
||||||
ttm_bo_pin(bo);
|
ttm_bo_pin(bo);
|
||||||
@ -369,7 +369,7 @@ void *vmw_bo_map_and_cache(struct vmw_buffer_object *vbo)
|
|||||||
if (virtual)
|
if (virtual)
|
||||||
return virtual;
|
return virtual;
|
||||||
|
|
||||||
ret = ttm_bo_kmap(bo, 0, bo->mem.num_pages, &vbo->map);
|
ret = ttm_bo_kmap(bo, 0, bo->resource->num_pages, &vbo->map);
|
||||||
if (ret)
|
if (ret)
|
||||||
DRM_ERROR("Buffer object map failed: %d.\n", ret);
|
DRM_ERROR("Buffer object map failed: %d.\n", ret);
|
||||||
|
|
||||||
@ -1197,7 +1197,7 @@ void vmw_bo_move_notify(struct ttm_buffer_object *bo,
|
|||||||
* With other types of moves, the underlying pages stay the same,
|
* With other types of moves, the underlying pages stay the same,
|
||||||
* and the map can be kept.
|
* and the map can be kept.
|
||||||
*/
|
*/
|
||||||
if (mem->mem_type == TTM_PL_VRAM || bo->mem.mem_type == TTM_PL_VRAM)
|
if (mem->mem_type == TTM_PL_VRAM || bo->resource->mem_type == TTM_PL_VRAM)
|
||||||
vmw_bo_unmap(vbo);
|
vmw_bo_unmap(vbo);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1205,6 +1205,6 @@ void vmw_bo_move_notify(struct ttm_buffer_object *bo,
|
|||||||
* read back all resource content first, and unbind the MOB from
|
* read back all resource content first, and unbind the MOB from
|
||||||
* the resource.
|
* the resource.
|
||||||
*/
|
*/
|
||||||
if (mem->mem_type != VMW_PL_MOB && bo->mem.mem_type == VMW_PL_MOB)
|
if (mem->mem_type != VMW_PL_MOB && bo->resource->mem_type == VMW_PL_MOB)
|
||||||
vmw_resource_unbind_list(vbo);
|
vmw_resource_unbind_list(vbo);
|
||||||
}
|
}
|
||||||
|
@ -576,11 +576,11 @@ static int vmw_cmd_emit_dummy_legacy_query(struct vmw_private *dev_priv,
|
|||||||
cmd->body.cid = cid;
|
cmd->body.cid = cid;
|
||||||
cmd->body.type = SVGA3D_QUERYTYPE_OCCLUSION;
|
cmd->body.type = SVGA3D_QUERYTYPE_OCCLUSION;
|
||||||
|
|
||||||
if (bo->mem.mem_type == TTM_PL_VRAM) {
|
if (bo->resource->mem_type == TTM_PL_VRAM) {
|
||||||
cmd->body.guestResult.gmrId = SVGA_GMR_FRAMEBUFFER;
|
cmd->body.guestResult.gmrId = SVGA_GMR_FRAMEBUFFER;
|
||||||
cmd->body.guestResult.offset = bo->mem.start << PAGE_SHIFT;
|
cmd->body.guestResult.offset = bo->resource->start << PAGE_SHIFT;
|
||||||
} else {
|
} else {
|
||||||
cmd->body.guestResult.gmrId = bo->mem.start;
|
cmd->body.guestResult.gmrId = bo->resource->start;
|
||||||
cmd->body.guestResult.offset = 0;
|
cmd->body.guestResult.offset = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -621,8 +621,8 @@ static int vmw_cmd_emit_dummy_gb_query(struct vmw_private *dev_priv,
|
|||||||
cmd->header.size = sizeof(cmd->body);
|
cmd->header.size = sizeof(cmd->body);
|
||||||
cmd->body.cid = cid;
|
cmd->body.cid = cid;
|
||||||
cmd->body.type = SVGA3D_QUERYTYPE_OCCLUSION;
|
cmd->body.type = SVGA3D_QUERYTYPE_OCCLUSION;
|
||||||
BUG_ON(bo->mem.mem_type != VMW_PL_MOB);
|
BUG_ON(bo->resource->mem_type != VMW_PL_MOB);
|
||||||
cmd->body.mobid = bo->mem.start;
|
cmd->body.mobid = bo->resource->start;
|
||||||
cmd->body.offset = 0;
|
cmd->body.offset = 0;
|
||||||
|
|
||||||
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
||||||
|
@ -889,7 +889,7 @@ static int vmw_cmdbuf_space_pool(struct vmw_cmdbuf_man *man,
|
|||||||
header->cmd = man->map + offset;
|
header->cmd = man->map + offset;
|
||||||
if (man->using_mob) {
|
if (man->using_mob) {
|
||||||
cb_hdr->flags = SVGA_CB_FLAG_MOB;
|
cb_hdr->flags = SVGA_CB_FLAG_MOB;
|
||||||
cb_hdr->ptr.mob.mobid = man->cmd_space->mem.start;
|
cb_hdr->ptr.mob.mobid = man->cmd_space->resource->start;
|
||||||
cb_hdr->ptr.mob.mobOffset = offset;
|
cb_hdr->ptr.mob.mobOffset = offset;
|
||||||
} else {
|
} else {
|
||||||
cb_hdr->ptr.pa = (u64)man->handle + (u64)offset;
|
cb_hdr->ptr.pa = (u64)man->handle + (u64)offset;
|
||||||
|
@ -346,7 +346,7 @@ static int vmw_gb_context_bind(struct vmw_resource *res,
|
|||||||
} *cmd;
|
} *cmd;
|
||||||
struct ttm_buffer_object *bo = val_buf->bo;
|
struct ttm_buffer_object *bo = val_buf->bo;
|
||||||
|
|
||||||
BUG_ON(bo->mem.mem_type != VMW_PL_MOB);
|
BUG_ON(bo->resource->mem_type != VMW_PL_MOB);
|
||||||
|
|
||||||
cmd = VMW_CMD_RESERVE(dev_priv, sizeof(*cmd));
|
cmd = VMW_CMD_RESERVE(dev_priv, sizeof(*cmd));
|
||||||
if (unlikely(cmd == NULL))
|
if (unlikely(cmd == NULL))
|
||||||
@ -355,7 +355,7 @@ static int vmw_gb_context_bind(struct vmw_resource *res,
|
|||||||
cmd->header.id = SVGA_3D_CMD_BIND_GB_CONTEXT;
|
cmd->header.id = SVGA_3D_CMD_BIND_GB_CONTEXT;
|
||||||
cmd->header.size = sizeof(cmd->body);
|
cmd->header.size = sizeof(cmd->body);
|
||||||
cmd->body.cid = res->id;
|
cmd->body.cid = res->id;
|
||||||
cmd->body.mobid = bo->mem.start;
|
cmd->body.mobid = bo->resource->start;
|
||||||
cmd->body.validContents = res->backup_dirty;
|
cmd->body.validContents = res->backup_dirty;
|
||||||
res->backup_dirty = false;
|
res->backup_dirty = false;
|
||||||
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
||||||
@ -385,7 +385,7 @@ static int vmw_gb_context_unbind(struct vmw_resource *res,
|
|||||||
uint8_t *cmd;
|
uint8_t *cmd;
|
||||||
|
|
||||||
|
|
||||||
BUG_ON(bo->mem.mem_type != VMW_PL_MOB);
|
BUG_ON(bo->resource->mem_type != VMW_PL_MOB);
|
||||||
|
|
||||||
mutex_lock(&dev_priv->binding_mutex);
|
mutex_lock(&dev_priv->binding_mutex);
|
||||||
vmw_binding_state_scrub(uctx->cbs);
|
vmw_binding_state_scrub(uctx->cbs);
|
||||||
@ -513,7 +513,7 @@ static int vmw_dx_context_bind(struct vmw_resource *res,
|
|||||||
} *cmd;
|
} *cmd;
|
||||||
struct ttm_buffer_object *bo = val_buf->bo;
|
struct ttm_buffer_object *bo = val_buf->bo;
|
||||||
|
|
||||||
BUG_ON(bo->mem.mem_type != VMW_PL_MOB);
|
BUG_ON(bo->resource->mem_type != VMW_PL_MOB);
|
||||||
|
|
||||||
cmd = VMW_CMD_RESERVE(dev_priv, sizeof(*cmd));
|
cmd = VMW_CMD_RESERVE(dev_priv, sizeof(*cmd));
|
||||||
if (unlikely(cmd == NULL))
|
if (unlikely(cmd == NULL))
|
||||||
@ -522,7 +522,7 @@ static int vmw_dx_context_bind(struct vmw_resource *res,
|
|||||||
cmd->header.id = SVGA_3D_CMD_DX_BIND_CONTEXT;
|
cmd->header.id = SVGA_3D_CMD_DX_BIND_CONTEXT;
|
||||||
cmd->header.size = sizeof(cmd->body);
|
cmd->header.size = sizeof(cmd->body);
|
||||||
cmd->body.cid = res->id;
|
cmd->body.cid = res->id;
|
||||||
cmd->body.mobid = bo->mem.start;
|
cmd->body.mobid = bo->resource->start;
|
||||||
cmd->body.validContents = res->backup_dirty;
|
cmd->body.validContents = res->backup_dirty;
|
||||||
res->backup_dirty = false;
|
res->backup_dirty = false;
|
||||||
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
||||||
@ -594,7 +594,7 @@ static int vmw_dx_context_unbind(struct vmw_resource *res,
|
|||||||
uint8_t *cmd;
|
uint8_t *cmd;
|
||||||
|
|
||||||
|
|
||||||
BUG_ON(bo->mem.mem_type != VMW_PL_MOB);
|
BUG_ON(bo->resource->mem_type != VMW_PL_MOB);
|
||||||
|
|
||||||
mutex_lock(&dev_priv->binding_mutex);
|
mutex_lock(&dev_priv->binding_mutex);
|
||||||
vmw_dx_context_scrub_cotables(res, readback);
|
vmw_dx_context_scrub_cotables(res, readback);
|
||||||
|
@ -173,7 +173,7 @@ static int vmw_cotable_unscrub(struct vmw_resource *res)
|
|||||||
SVGA3dCmdDXSetCOTable body;
|
SVGA3dCmdDXSetCOTable body;
|
||||||
} *cmd;
|
} *cmd;
|
||||||
|
|
||||||
WARN_ON_ONCE(bo->mem.mem_type != VMW_PL_MOB);
|
WARN_ON_ONCE(bo->resource->mem_type != VMW_PL_MOB);
|
||||||
dma_resv_assert_held(bo->base.resv);
|
dma_resv_assert_held(bo->base.resv);
|
||||||
|
|
||||||
cmd = VMW_CMD_RESERVE(dev_priv, sizeof(*cmd));
|
cmd = VMW_CMD_RESERVE(dev_priv, sizeof(*cmd));
|
||||||
@ -181,12 +181,12 @@ static int vmw_cotable_unscrub(struct vmw_resource *res)
|
|||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
WARN_ON(vcotbl->ctx->id == SVGA3D_INVALID_ID);
|
WARN_ON(vcotbl->ctx->id == SVGA3D_INVALID_ID);
|
||||||
WARN_ON(bo->mem.mem_type != VMW_PL_MOB);
|
WARN_ON(bo->resource->mem_type != VMW_PL_MOB);
|
||||||
cmd->header.id = SVGA_3D_CMD_DX_SET_COTABLE;
|
cmd->header.id = SVGA_3D_CMD_DX_SET_COTABLE;
|
||||||
cmd->header.size = sizeof(cmd->body);
|
cmd->header.size = sizeof(cmd->body);
|
||||||
cmd->body.cid = vcotbl->ctx->id;
|
cmd->body.cid = vcotbl->ctx->id;
|
||||||
cmd->body.type = vcotbl->type;
|
cmd->body.type = vcotbl->type;
|
||||||
cmd->body.mobid = bo->mem.start;
|
cmd->body.mobid = bo->resource->start;
|
||||||
cmd->body.validSizeInBytes = vcotbl->size_read_back;
|
cmd->body.validSizeInBytes = vcotbl->size_read_back;
|
||||||
|
|
||||||
vmw_cmd_commit_flush(dev_priv, sizeof(*cmd));
|
vmw_cmd_commit_flush(dev_priv, sizeof(*cmd));
|
||||||
@ -315,7 +315,7 @@ static int vmw_cotable_unbind(struct vmw_resource *res,
|
|||||||
if (!vmw_resource_mob_attached(res))
|
if (!vmw_resource_mob_attached(res))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
WARN_ON_ONCE(bo->mem.mem_type != VMW_PL_MOB);
|
WARN_ON_ONCE(bo->resource->mem_type != VMW_PL_MOB);
|
||||||
dma_resv_assert_held(bo->base.resv);
|
dma_resv_assert_held(bo->base.resv);
|
||||||
|
|
||||||
mutex_lock(&dev_priv->binding_mutex);
|
mutex_lock(&dev_priv->binding_mutex);
|
||||||
@ -431,7 +431,7 @@ static int vmw_cotable_resize(struct vmw_resource *res, size_t new_size)
|
|||||||
* Do a page by page copy of COTables. This eliminates slow vmap()s.
|
* Do a page by page copy of COTables. This eliminates slow vmap()s.
|
||||||
* This should really be a TTM utility.
|
* This should really be a TTM utility.
|
||||||
*/
|
*/
|
||||||
for (i = 0; i < old_bo->mem.num_pages; ++i) {
|
for (i = 0; i < old_bo->resource->num_pages; ++i) {
|
||||||
bool dummy;
|
bool dummy;
|
||||||
|
|
||||||
ret = ttm_bo_kmap(old_bo, i, 1, &old_map);
|
ret = ttm_bo_kmap(old_bo, i, 1, &old_map);
|
||||||
|
@ -735,7 +735,7 @@ static int vmw_rebind_all_dx_query(struct vmw_resource *ctx_res)
|
|||||||
cmd->header.id = SVGA_3D_CMD_DX_BIND_ALL_QUERY;
|
cmd->header.id = SVGA_3D_CMD_DX_BIND_ALL_QUERY;
|
||||||
cmd->header.size = sizeof(cmd->body);
|
cmd->header.size = sizeof(cmd->body);
|
||||||
cmd->body.cid = ctx_res->id;
|
cmd->body.cid = ctx_res->id;
|
||||||
cmd->body.mobid = dx_query_mob->base.mem.start;
|
cmd->body.mobid = dx_query_mob->base.resource->start;
|
||||||
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
||||||
|
|
||||||
vmw_context_bind_dx_query(ctx_res, dx_query_mob);
|
vmw_context_bind_dx_query(ctx_res, dx_query_mob);
|
||||||
@ -1046,7 +1046,7 @@ static int vmw_query_bo_switch_prepare(struct vmw_private *dev_priv,
|
|||||||
|
|
||||||
if (unlikely(new_query_bo != sw_context->cur_query_bo)) {
|
if (unlikely(new_query_bo != sw_context->cur_query_bo)) {
|
||||||
|
|
||||||
if (unlikely(new_query_bo->base.mem.num_pages > 4)) {
|
if (unlikely(new_query_bo->base.resource->num_pages > 4)) {
|
||||||
VMW_DEBUG_USER("Query buffer too large.\n");
|
VMW_DEBUG_USER("Query buffer too large.\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
@ -3710,16 +3710,16 @@ static void vmw_apply_relocations(struct vmw_sw_context *sw_context)
|
|||||||
|
|
||||||
list_for_each_entry(reloc, &sw_context->bo_relocations, head) {
|
list_for_each_entry(reloc, &sw_context->bo_relocations, head) {
|
||||||
bo = &reloc->vbo->base;
|
bo = &reloc->vbo->base;
|
||||||
switch (bo->mem.mem_type) {
|
switch (bo->resource->mem_type) {
|
||||||
case TTM_PL_VRAM:
|
case TTM_PL_VRAM:
|
||||||
reloc->location->offset += bo->mem.start << PAGE_SHIFT;
|
reloc->location->offset += bo->resource->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:
|
||||||
reloc->location->gmrId = bo->mem.start;
|
reloc->location->gmrId = bo->resource->start;
|
||||||
break;
|
break;
|
||||||
case VMW_PL_MOB:
|
case VMW_PL_MOB:
|
||||||
*reloc->mob_loc = bo->mem.start;
|
*reloc->mob_loc = bo->resource->start;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
BUG();
|
BUG();
|
||||||
|
@ -232,7 +232,7 @@ void vmw_bo_dirty_unmap(struct vmw_buffer_object *vbo,
|
|||||||
int vmw_bo_dirty_add(struct vmw_buffer_object *vbo)
|
int vmw_bo_dirty_add(struct vmw_buffer_object *vbo)
|
||||||
{
|
{
|
||||||
struct vmw_bo_dirty *dirty = vbo->dirty;
|
struct vmw_bo_dirty *dirty = vbo->dirty;
|
||||||
pgoff_t num_pages = vbo->base.mem.num_pages;
|
pgoff_t num_pages = vbo->base.resource->num_pages;
|
||||||
size_t size, acc_size;
|
size_t size, acc_size;
|
||||||
int ret;
|
int ret;
|
||||||
static struct ttm_operation_ctx ctx = {
|
static struct ttm_operation_ctx ctx = {
|
||||||
@ -413,7 +413,7 @@ vm_fault_t vmw_bo_vm_mkwrite(struct vm_fault *vmf)
|
|||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
page_offset = vmf->pgoff - drm_vma_node_start(&bo->base.vma_node);
|
page_offset = vmf->pgoff - drm_vma_node_start(&bo->base.vma_node);
|
||||||
if (unlikely(page_offset >= bo->mem.num_pages)) {
|
if (unlikely(page_offset >= bo->resource->num_pages)) {
|
||||||
ret = VM_FAULT_SIGBUS;
|
ret = VM_FAULT_SIGBUS;
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
@ -456,7 +456,7 @@ vm_fault_t vmw_bo_vm_fault(struct vm_fault *vmf)
|
|||||||
|
|
||||||
page_offset = vmf->pgoff -
|
page_offset = vmf->pgoff -
|
||||||
drm_vma_node_start(&bo->base.vma_node);
|
drm_vma_node_start(&bo->base.vma_node);
|
||||||
if (page_offset >= bo->mem.num_pages ||
|
if (page_offset >= bo->resource->num_pages ||
|
||||||
vmw_resources_clean(vbo, page_offset,
|
vmw_resources_clean(vbo, page_offset,
|
||||||
page_offset + PAGE_SIZE,
|
page_offset + PAGE_SIZE,
|
||||||
&allowed_prefault)) {
|
&allowed_prefault)) {
|
||||||
@ -529,7 +529,7 @@ vm_fault_t vmw_bo_vm_huge_fault(struct vm_fault *vmf,
|
|||||||
|
|
||||||
page_offset = vmf->pgoff -
|
page_offset = vmf->pgoff -
|
||||||
drm_vma_node_start(&bo->base.vma_node);
|
drm_vma_node_start(&bo->base.vma_node);
|
||||||
if (page_offset >= bo->mem.num_pages ||
|
if (page_offset >= bo->resource->num_pages ||
|
||||||
vmw_resources_clean(vbo, page_offset,
|
vmw_resources_clean(vbo, page_offset,
|
||||||
page_offset + PAGE_SIZE,
|
page_offset + PAGE_SIZE,
|
||||||
&allowed_prefault)) {
|
&allowed_prefault)) {
|
||||||
|
@ -254,7 +254,7 @@ static int vmw_gb_shader_bind(struct vmw_resource *res,
|
|||||||
} *cmd;
|
} *cmd;
|
||||||
struct ttm_buffer_object *bo = val_buf->bo;
|
struct ttm_buffer_object *bo = val_buf->bo;
|
||||||
|
|
||||||
BUG_ON(bo->mem.mem_type != VMW_PL_MOB);
|
BUG_ON(bo->resource->mem_type != VMW_PL_MOB);
|
||||||
|
|
||||||
cmd = VMW_CMD_RESERVE(dev_priv, sizeof(*cmd));
|
cmd = VMW_CMD_RESERVE(dev_priv, sizeof(*cmd));
|
||||||
if (unlikely(cmd == NULL))
|
if (unlikely(cmd == NULL))
|
||||||
@ -263,7 +263,7 @@ static int vmw_gb_shader_bind(struct vmw_resource *res,
|
|||||||
cmd->header.id = SVGA_3D_CMD_BIND_GB_SHADER;
|
cmd->header.id = SVGA_3D_CMD_BIND_GB_SHADER;
|
||||||
cmd->header.size = sizeof(cmd->body);
|
cmd->header.size = sizeof(cmd->body);
|
||||||
cmd->body.shid = res->id;
|
cmd->body.shid = res->id;
|
||||||
cmd->body.mobid = bo->mem.start;
|
cmd->body.mobid = bo->resource->start;
|
||||||
cmd->body.offsetInBytes = res->backup_offset;
|
cmd->body.offsetInBytes = res->backup_offset;
|
||||||
res->backup_dirty = false;
|
res->backup_dirty = false;
|
||||||
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
||||||
@ -282,7 +282,7 @@ static int vmw_gb_shader_unbind(struct vmw_resource *res,
|
|||||||
} *cmd;
|
} *cmd;
|
||||||
struct vmw_fence_obj *fence;
|
struct vmw_fence_obj *fence;
|
||||||
|
|
||||||
BUG_ON(res->backup->base.mem.mem_type != VMW_PL_MOB);
|
BUG_ON(res->backup->base.resource->mem_type != VMW_PL_MOB);
|
||||||
|
|
||||||
cmd = VMW_CMD_RESERVE(dev_priv, sizeof(*cmd));
|
cmd = VMW_CMD_RESERVE(dev_priv, sizeof(*cmd));
|
||||||
if (unlikely(cmd == NULL))
|
if (unlikely(cmd == NULL))
|
||||||
@ -402,7 +402,7 @@ static int vmw_dx_shader_unscrub(struct vmw_resource *res)
|
|||||||
cmd->header.size = sizeof(cmd->body);
|
cmd->header.size = sizeof(cmd->body);
|
||||||
cmd->body.cid = shader->ctx->id;
|
cmd->body.cid = shader->ctx->id;
|
||||||
cmd->body.shid = shader->id;
|
cmd->body.shid = shader->id;
|
||||||
cmd->body.mobid = res->backup->base.mem.start;
|
cmd->body.mobid = res->backup->base.resource->start;
|
||||||
cmd->body.offsetInBytes = res->backup_offset;
|
cmd->body.offsetInBytes = res->backup_offset;
|
||||||
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
||||||
|
|
||||||
@ -450,7 +450,7 @@ static int vmw_dx_shader_bind(struct vmw_resource *res,
|
|||||||
struct vmw_private *dev_priv = res->dev_priv;
|
struct vmw_private *dev_priv = res->dev_priv;
|
||||||
struct ttm_buffer_object *bo = val_buf->bo;
|
struct ttm_buffer_object *bo = val_buf->bo;
|
||||||
|
|
||||||
BUG_ON(bo->mem.mem_type != VMW_PL_MOB);
|
BUG_ON(bo->resource->mem_type != VMW_PL_MOB);
|
||||||
mutex_lock(&dev_priv->binding_mutex);
|
mutex_lock(&dev_priv->binding_mutex);
|
||||||
vmw_dx_shader_unscrub(res);
|
vmw_dx_shader_unscrub(res);
|
||||||
mutex_unlock(&dev_priv->binding_mutex);
|
mutex_unlock(&dev_priv->binding_mutex);
|
||||||
@ -513,7 +513,7 @@ static int vmw_dx_shader_unbind(struct vmw_resource *res,
|
|||||||
struct vmw_fence_obj *fence;
|
struct vmw_fence_obj *fence;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
BUG_ON(res->backup->base.mem.mem_type != VMW_PL_MOB);
|
BUG_ON(res->backup->base.resource->mem_type != VMW_PL_MOB);
|
||||||
|
|
||||||
mutex_lock(&dev_priv->binding_mutex);
|
mutex_lock(&dev_priv->binding_mutex);
|
||||||
ret = vmw_dx_shader_scrub(res);
|
ret = vmw_dx_shader_scrub(res);
|
||||||
|
@ -106,7 +106,7 @@ static int vmw_dx_streamoutput_unscrub(struct vmw_resource *res)
|
|||||||
cmd->header.id = SVGA_3D_CMD_DX_BIND_STREAMOUTPUT;
|
cmd->header.id = SVGA_3D_CMD_DX_BIND_STREAMOUTPUT;
|
||||||
cmd->header.size = sizeof(cmd->body);
|
cmd->header.size = sizeof(cmd->body);
|
||||||
cmd->body.soid = so->id;
|
cmd->body.soid = so->id;
|
||||||
cmd->body.mobid = res->backup->base.mem.start;
|
cmd->body.mobid = res->backup->base.resource->start;
|
||||||
cmd->body.offsetInBytes = res->backup_offset;
|
cmd->body.offsetInBytes = res->backup_offset;
|
||||||
cmd->body.sizeInBytes = so->size;
|
cmd->body.sizeInBytes = so->size;
|
||||||
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
vmw_cmd_commit(dev_priv, sizeof(*cmd));
|
||||||
@ -142,7 +142,7 @@ static int vmw_dx_streamoutput_bind(struct vmw_resource *res,
|
|||||||
struct ttm_buffer_object *bo = val_buf->bo;
|
struct ttm_buffer_object *bo = val_buf->bo;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (WARN_ON(bo->mem.mem_type != VMW_PL_MOB))
|
if (WARN_ON(bo->resource->mem_type != VMW_PL_MOB))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
mutex_lock(&dev_priv->binding_mutex);
|
mutex_lock(&dev_priv->binding_mutex);
|
||||||
@ -197,7 +197,7 @@ static int vmw_dx_streamoutput_unbind(struct vmw_resource *res, bool readback,
|
|||||||
struct vmw_fence_obj *fence;
|
struct vmw_fence_obj *fence;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (WARN_ON(res->backup->base.mem.mem_type != VMW_PL_MOB))
|
if (WARN_ON(res->backup->base.resource->mem_type != VMW_PL_MOB))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
mutex_lock(&dev_priv->binding_mutex);
|
mutex_lock(&dev_priv->binding_mutex);
|
||||||
|
@ -1212,7 +1212,7 @@ static int vmw_gb_surface_bind(struct vmw_resource *res,
|
|||||||
uint32_t submit_size;
|
uint32_t submit_size;
|
||||||
struct ttm_buffer_object *bo = val_buf->bo;
|
struct ttm_buffer_object *bo = val_buf->bo;
|
||||||
|
|
||||||
BUG_ON(bo->mem.mem_type != VMW_PL_MOB);
|
BUG_ON(bo->resource->mem_type != VMW_PL_MOB);
|
||||||
|
|
||||||
submit_size = sizeof(*cmd1) + (res->backup_dirty ? sizeof(*cmd2) : 0);
|
submit_size = sizeof(*cmd1) + (res->backup_dirty ? sizeof(*cmd2) : 0);
|
||||||
|
|
||||||
@ -1223,7 +1223,7 @@ static int vmw_gb_surface_bind(struct vmw_resource *res,
|
|||||||
cmd1->header.id = SVGA_3D_CMD_BIND_GB_SURFACE;
|
cmd1->header.id = SVGA_3D_CMD_BIND_GB_SURFACE;
|
||||||
cmd1->header.size = sizeof(cmd1->body);
|
cmd1->header.size = sizeof(cmd1->body);
|
||||||
cmd1->body.sid = res->id;
|
cmd1->body.sid = res->id;
|
||||||
cmd1->body.mobid = bo->mem.start;
|
cmd1->body.mobid = bo->resource->start;
|
||||||
if (res->backup_dirty) {
|
if (res->backup_dirty) {
|
||||||
cmd2 = (void *) &cmd1[1];
|
cmd2 = (void *) &cmd1[1];
|
||||||
cmd2->header.id = SVGA_3D_CMD_UPDATE_GB_SURFACE;
|
cmd2->header.id = SVGA_3D_CMD_UPDATE_GB_SURFACE;
|
||||||
@ -1266,7 +1266,7 @@ static int vmw_gb_surface_unbind(struct vmw_resource *res,
|
|||||||
uint8_t *cmd;
|
uint8_t *cmd;
|
||||||
|
|
||||||
|
|
||||||
BUG_ON(bo->mem.mem_type != VMW_PL_MOB);
|
BUG_ON(bo->resource->mem_type != VMW_PL_MOB);
|
||||||
|
|
||||||
submit_size = sizeof(*cmd3) + (readback ? sizeof(*cmd1) : sizeof(*cmd2));
|
submit_size = sizeof(*cmd3) + (readback ? sizeof(*cmd1) : sizeof(*cmd2));
|
||||||
cmd = VMW_CMD_RESERVE(dev_priv, submit_size);
|
cmd = VMW_CMD_RESERVE(dev_priv, submit_size);
|
||||||
|
@ -719,7 +719,7 @@ static int vmw_move(struct ttm_buffer_object *bo,
|
|||||||
struct ttm_resource *new_mem,
|
struct ttm_resource *new_mem,
|
||||||
struct ttm_place *hop)
|
struct ttm_place *hop)
|
||||||
{
|
{
|
||||||
struct ttm_resource_manager *old_man = ttm_manager_type(bo->bdev, bo->mem.mem_type);
|
struct ttm_resource_manager *old_man = ttm_manager_type(bo->bdev, bo->resource->mem_type);
|
||||||
struct ttm_resource_manager *new_man = ttm_manager_type(bo->bdev, new_mem->mem_type);
|
struct ttm_resource_manager *new_man = ttm_manager_type(bo->bdev, new_mem->mem_type);
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
@ -729,10 +729,10 @@ static int vmw_move(struct ttm_buffer_object *bo,
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
vmw_move_notify(bo, &bo->mem, new_mem);
|
vmw_move_notify(bo, bo->resource, new_mem);
|
||||||
|
|
||||||
if (old_man->use_tt && new_man->use_tt) {
|
if (old_man->use_tt && new_man->use_tt) {
|
||||||
if (bo->mem.mem_type == TTM_PL_SYSTEM) {
|
if (bo->resource->mem_type == TTM_PL_SYSTEM) {
|
||||||
ttm_bo_assign_mem(bo, new_mem);
|
ttm_bo_assign_mem(bo, new_mem);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -741,7 +741,7 @@ static int vmw_move(struct ttm_buffer_object *bo,
|
|||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
vmw_ttm_unbind(bo->bdev, bo->ttm);
|
vmw_ttm_unbind(bo->bdev, bo->ttm);
|
||||||
ttm_resource_free(bo, &bo->mem);
|
ttm_resource_free(bo, bo->resource);
|
||||||
ttm_bo_assign_mem(bo, new_mem);
|
ttm_bo_assign_mem(bo, new_mem);
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
@ -751,7 +751,7 @@ static int vmw_move(struct ttm_buffer_object *bo,
|
|||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
fail:
|
fail:
|
||||||
vmw_move_notify(bo, new_mem, &bo->mem);
|
vmw_move_notify(bo, new_mem, bo->resource);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,7 +136,8 @@ struct ttm_buffer_object {
|
|||||||
* Members protected by the bo::resv::reserved lock.
|
* Members protected by the bo::resv::reserved lock.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct ttm_resource mem;
|
struct ttm_resource *resource;
|
||||||
|
struct ttm_resource _mem;
|
||||||
struct ttm_tt *ttm;
|
struct ttm_tt *ttm;
|
||||||
bool deleted;
|
bool deleted;
|
||||||
|
|
||||||
|
@ -181,14 +181,14 @@ static inline void
|
|||||||
ttm_bo_move_to_lru_tail_unlocked(struct ttm_buffer_object *bo)
|
ttm_bo_move_to_lru_tail_unlocked(struct ttm_buffer_object *bo)
|
||||||
{
|
{
|
||||||
spin_lock(&bo->bdev->lru_lock);
|
spin_lock(&bo->bdev->lru_lock);
|
||||||
ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
|
ttm_bo_move_to_lru_tail(bo, bo->resource, NULL);
|
||||||
spin_unlock(&bo->bdev->lru_lock);
|
spin_unlock(&bo->bdev->lru_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void ttm_bo_assign_mem(struct ttm_buffer_object *bo,
|
static inline void ttm_bo_assign_mem(struct ttm_buffer_object *bo,
|
||||||
struct ttm_resource *new_mem)
|
struct ttm_resource *new_mem)
|
||||||
{
|
{
|
||||||
bo->mem = *new_mem;
|
bo->_mem = *new_mem;
|
||||||
new_mem->mm_node = NULL;
|
new_mem->mm_node = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -202,7 +202,7 @@ static inline void ttm_bo_assign_mem(struct ttm_buffer_object *bo,
|
|||||||
static inline void ttm_bo_move_null(struct ttm_buffer_object *bo,
|
static inline void ttm_bo_move_null(struct ttm_buffer_object *bo,
|
||||||
struct ttm_resource *new_mem)
|
struct ttm_resource *new_mem)
|
||||||
{
|
{
|
||||||
struct ttm_resource *old_mem = &bo->mem;
|
struct ttm_resource *old_mem = bo->resource;
|
||||||
|
|
||||||
WARN_ON(old_mem->mm_node != NULL);
|
WARN_ON(old_mem->mm_node != NULL);
|
||||||
ttm_bo_assign_mem(bo, new_mem);
|
ttm_bo_assign_mem(bo, new_mem);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user