drm/radeon: move and rename radeon_bo_va function
It doesn't really belong into the object functions, also rename it to avoid collisions with struct radeon_bo_va. Signed-off-by: Christian König <deathsimple@vodafone.de> Reviewed-by: Jerome Glisse <jglisse@redhat.com>
This commit is contained in:
parent
ca19f21ece
commit
421ca7ab86
5 changed files with 33 additions and 20 deletions
|
@ -1846,6 +1846,8 @@ int radeon_vm_bo_update_pte(struct radeon_device *rdev,
|
||||||
struct ttm_mem_reg *mem);
|
struct ttm_mem_reg *mem);
|
||||||
void radeon_vm_bo_invalidate(struct radeon_device *rdev,
|
void radeon_vm_bo_invalidate(struct radeon_device *rdev,
|
||||||
struct radeon_bo *bo);
|
struct radeon_bo *bo);
|
||||||
|
struct radeon_bo_va *radeon_vm_bo_find(struct radeon_vm *vm,
|
||||||
|
struct radeon_bo *bo);
|
||||||
int radeon_vm_bo_add(struct radeon_device *rdev,
|
int radeon_vm_bo_add(struct radeon_device *rdev,
|
||||||
struct radeon_vm *vm,
|
struct radeon_vm *vm,
|
||||||
struct radeon_bo *bo,
|
struct radeon_bo *bo,
|
||||||
|
|
|
@ -662,7 +662,31 @@ void radeon_vm_fence(struct radeon_device *rdev,
|
||||||
vm->fence = radeon_fence_ref(fence);
|
vm->fence = radeon_fence_ref(fence);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* object have to be reserved */
|
/**
|
||||||
|
* radeon_vm_bo_find - find the bo_va for a specific vm & bo
|
||||||
|
*
|
||||||
|
* @vm: requested vm
|
||||||
|
* @bo: requested buffer object
|
||||||
|
*
|
||||||
|
* Find @bo inside the requested vm (cayman+).
|
||||||
|
* Search inside the @bos vm list for the requested vm
|
||||||
|
* Returns the found bo_va or NULL if none is found
|
||||||
|
*
|
||||||
|
* Object has to be reserved!
|
||||||
|
*/
|
||||||
|
struct radeon_bo_va *radeon_vm_bo_find(struct radeon_vm *vm,
|
||||||
|
struct radeon_bo *bo)
|
||||||
|
{
|
||||||
|
struct radeon_bo_va *bo_va;
|
||||||
|
|
||||||
|
list_for_each_entry(bo_va, &bo->va, bo_list) {
|
||||||
|
if (bo_va->vm == vm) {
|
||||||
|
return bo_va;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* radeon_vm_bo_add - add a bo to a specific vm
|
* radeon_vm_bo_add - add a bo to a specific vm
|
||||||
*
|
*
|
||||||
|
@ -676,6 +700,8 @@ void radeon_vm_fence(struct radeon_device *rdev,
|
||||||
* Add @bo to the list of bos associated with the vm and validate
|
* Add @bo to the list of bos associated with the vm and validate
|
||||||
* the offset requested within the vm address space.
|
* the offset requested within the vm address space.
|
||||||
* Returns 0 for success, error for failure.
|
* Returns 0 for success, error for failure.
|
||||||
|
*
|
||||||
|
* Object has to be reserved!
|
||||||
*/
|
*/
|
||||||
int radeon_vm_bo_add(struct radeon_device *rdev,
|
int radeon_vm_bo_add(struct radeon_device *rdev,
|
||||||
struct radeon_vm *vm,
|
struct radeon_vm *vm,
|
||||||
|
@ -823,7 +849,7 @@ int radeon_vm_bo_update_pte(struct radeon_device *rdev,
|
||||||
if (vm->sa_bo == NULL)
|
if (vm->sa_bo == NULL)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
bo_va = radeon_bo_va(bo, vm);
|
bo_va = radeon_vm_bo_find(vm, bo);
|
||||||
if (bo_va == NULL) {
|
if (bo_va == NULL) {
|
||||||
dev_err(rdev->dev, "bo %p not in vm %p\n", bo, vm);
|
dev_err(rdev->dev, "bo %p not in vm %p\n", bo, vm);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -912,7 +938,7 @@ int radeon_vm_bo_rmv(struct radeon_device *rdev,
|
||||||
struct radeon_bo_va *bo_va;
|
struct radeon_bo_va *bo_va;
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
bo_va = radeon_bo_va(bo, vm);
|
bo_va = radeon_vm_bo_find(vm, bo);
|
||||||
if (bo_va == NULL)
|
if (bo_va == NULL)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
@ -1009,7 +1035,7 @@ void radeon_vm_fini(struct radeon_device *rdev, struct radeon_vm *vm)
|
||||||
*/
|
*/
|
||||||
r = radeon_bo_reserve(rdev->ring_tmp_bo.bo, false);
|
r = radeon_bo_reserve(rdev->ring_tmp_bo.bo, false);
|
||||||
if (!r) {
|
if (!r) {
|
||||||
bo_va = radeon_bo_va(rdev->ring_tmp_bo.bo, vm);
|
bo_va = radeon_vm_bo_find(vm, rdev->ring_tmp_bo.bo);
|
||||||
list_del_init(&bo_va->bo_list);
|
list_del_init(&bo_va->bo_list);
|
||||||
list_del_init(&bo_va->vm_list);
|
list_del_init(&bo_va->vm_list);
|
||||||
radeon_bo_unreserve(rdev->ring_tmp_bo.bo);
|
radeon_bo_unreserve(rdev->ring_tmp_bo.bo);
|
||||||
|
|
|
@ -461,7 +461,7 @@ int radeon_gem_va_ioctl(struct drm_device *dev, void *data,
|
||||||
}
|
}
|
||||||
switch (args->operation) {
|
switch (args->operation) {
|
||||||
case RADEON_VA_MAP:
|
case RADEON_VA_MAP:
|
||||||
bo_va = radeon_bo_va(rbo, &fpriv->vm);
|
bo_va = radeon_vm_bo_find(&fpriv->vm, rbo);
|
||||||
if (bo_va) {
|
if (bo_va) {
|
||||||
args->operation = RADEON_VA_RESULT_VA_EXIST;
|
args->operation = RADEON_VA_RESULT_VA_EXIST;
|
||||||
args->offset = bo_va->soffset;
|
args->offset = bo_va->soffset;
|
||||||
|
|
|
@ -646,16 +646,3 @@ int radeon_bo_reserve(struct radeon_bo *bo, bool no_wait)
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* object have to be reserved */
|
|
||||||
struct radeon_bo_va *radeon_bo_va(struct radeon_bo *rbo, struct radeon_vm *vm)
|
|
||||||
{
|
|
||||||
struct radeon_bo_va *bo_va;
|
|
||||||
|
|
||||||
list_for_each_entry(bo_va, &rbo->va, bo_list) {
|
|
||||||
if (bo_va->vm == vm) {
|
|
||||||
return bo_va;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
|
@ -141,8 +141,6 @@ extern void radeon_bo_move_notify(struct ttm_buffer_object *bo,
|
||||||
struct ttm_mem_reg *mem);
|
struct ttm_mem_reg *mem);
|
||||||
extern int radeon_bo_fault_reserve_notify(struct ttm_buffer_object *bo);
|
extern int radeon_bo_fault_reserve_notify(struct ttm_buffer_object *bo);
|
||||||
extern int radeon_bo_get_surface_reg(struct radeon_bo *bo);
|
extern int radeon_bo_get_surface_reg(struct radeon_bo *bo);
|
||||||
extern struct radeon_bo_va *radeon_bo_va(struct radeon_bo *rbo,
|
|
||||||
struct radeon_vm *vm);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* sub allocation
|
* sub allocation
|
||||||
|
|
Loading…
Add table
Reference in a new issue