aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/gpu/drm/radeon/radeon.h2
-rw-r--r--drivers/gpu/drm/radeon/radeon_gart.c34
-rw-r--r--drivers/gpu/drm/radeon/radeon_gem.c2
-rw-r--r--drivers/gpu/drm/radeon/radeon_object.c13
-rw-r--r--drivers/gpu/drm/radeon/radeon_object.h2
5 files changed, 33 insertions, 20 deletions
diff --git a/drivers/gpu/drm/radeon/radeon.h b/drivers/gpu/drm/radeon/radeon.h
index 55f17f9bc095..8cca1d2f0510 100644
--- a/drivers/gpu/drm/radeon/radeon.h
+++ b/drivers/gpu/drm/radeon/radeon.h
@@ -1846,6 +1846,8 @@ int radeon_vm_bo_update_pte(struct radeon_device *rdev,
1846 struct ttm_mem_reg *mem); 1846 struct ttm_mem_reg *mem);
1847void radeon_vm_bo_invalidate(struct radeon_device *rdev, 1847void radeon_vm_bo_invalidate(struct radeon_device *rdev,
1848 struct radeon_bo *bo); 1848 struct radeon_bo *bo);
1849struct radeon_bo_va *radeon_vm_bo_find(struct radeon_vm *vm,
1850 struct radeon_bo *bo);
1849int radeon_vm_bo_add(struct radeon_device *rdev, 1851int radeon_vm_bo_add(struct radeon_device *rdev,
1850 struct radeon_vm *vm, 1852 struct radeon_vm *vm,
1851 struct radeon_bo *bo, 1853 struct radeon_bo *bo,
diff --git a/drivers/gpu/drm/radeon/radeon_gart.c b/drivers/gpu/drm/radeon/radeon_gart.c
index 1b1c001e269a..2c594910064d 100644
--- a/drivers/gpu/drm/radeon/radeon_gart.c
+++ b/drivers/gpu/drm/radeon/radeon_gart.c
@@ -662,7 +662,31 @@ void radeon_vm_fence(struct radeon_device *rdev,
662 vm->fence = radeon_fence_ref(fence); 662 vm->fence = radeon_fence_ref(fence);
663} 663}
664 664
665/* object have to be reserved */ 665/**
666 * radeon_vm_bo_find - find the bo_va for a specific vm & bo
667 *
668 * @vm: requested vm
669 * @bo: requested buffer object
670 *
671 * Find @bo inside the requested vm (cayman+).
672 * Search inside the @bos vm list for the requested vm
673 * Returns the found bo_va or NULL if none is found
674 *
675 * Object has to be reserved!
676 */
677struct radeon_bo_va *radeon_vm_bo_find(struct radeon_vm *vm,
678 struct radeon_bo *bo)
679{
680 struct radeon_bo_va *bo_va;
681
682 list_for_each_entry(bo_va, &bo->va, bo_list) {
683 if (bo_va->vm == vm) {
684 return bo_va;
685 }
686 }
687 return NULL;
688}
689
666/** 690/**
667 * radeon_vm_bo_add - add a bo to a specific vm 691 * radeon_vm_bo_add - add a bo to a specific vm
668 * 692 *
@@ -676,6 +700,8 @@ void radeon_vm_fence(struct radeon_device *rdev,
676 * Add @bo to the list of bos associated with the vm and validate 700 * Add @bo to the list of bos associated with the vm and validate
677 * the offset requested within the vm address space. 701 * the offset requested within the vm address space.
678 * Returns 0 for success, error for failure. 702 * Returns 0 for success, error for failure.
703 *
704 * Object has to be reserved!
679 */ 705 */
680int radeon_vm_bo_add(struct radeon_device *rdev, 706int radeon_vm_bo_add(struct radeon_device *rdev,
681 struct radeon_vm *vm, 707 struct radeon_vm *vm,
@@ -823,7 +849,7 @@ int radeon_vm_bo_update_pte(struct radeon_device *rdev,
823 if (vm->sa_bo == NULL) 849 if (vm->sa_bo == NULL)
824 return 0; 850 return 0;
825 851
826 bo_va = radeon_bo_va(bo, vm); 852 bo_va = radeon_vm_bo_find(vm, bo);
827 if (bo_va == NULL) { 853 if (bo_va == NULL) {
828 dev_err(rdev->dev, "bo %p not in vm %p\n", bo, vm); 854 dev_err(rdev->dev, "bo %p not in vm %p\n", bo, vm);
829 return -EINVAL; 855 return -EINVAL;
@@ -912,7 +938,7 @@ int radeon_vm_bo_rmv(struct radeon_device *rdev,
912 struct radeon_bo_va *bo_va; 938 struct radeon_bo_va *bo_va;
913 int r; 939 int r;
914 940
915 bo_va = radeon_bo_va(bo, vm); 941 bo_va = radeon_vm_bo_find(vm, bo);
916 if (bo_va == NULL) 942 if (bo_va == NULL)
917 return 0; 943 return 0;
918 944
@@ -1009,7 +1035,7 @@ void radeon_vm_fini(struct radeon_device *rdev, struct radeon_vm *vm)
1009 */ 1035 */
1010 r = radeon_bo_reserve(rdev->ring_tmp_bo.bo, false); 1036 r = radeon_bo_reserve(rdev->ring_tmp_bo.bo, false);
1011 if (!r) { 1037 if (!r) {
1012 bo_va = radeon_bo_va(rdev->ring_tmp_bo.bo, vm); 1038 bo_va = radeon_vm_bo_find(vm, rdev->ring_tmp_bo.bo);
1013 list_del_init(&bo_va->bo_list); 1039 list_del_init(&bo_va->bo_list);
1014 list_del_init(&bo_va->vm_list); 1040 list_del_init(&bo_va->vm_list);
1015 radeon_bo_unreserve(rdev->ring_tmp_bo.bo); 1041 radeon_bo_unreserve(rdev->ring_tmp_bo.bo);
diff --git a/drivers/gpu/drm/radeon/radeon_gem.c b/drivers/gpu/drm/radeon/radeon_gem.c
index 1b57b0058ad6..6cac5cca3d81 100644
--- a/drivers/gpu/drm/radeon/radeon_gem.c
+++ b/drivers/gpu/drm/radeon/radeon_gem.c
@@ -461,7 +461,7 @@ int radeon_gem_va_ioctl(struct drm_device *dev, void *data,
461 } 461 }
462 switch (args->operation) { 462 switch (args->operation) {
463 case RADEON_VA_MAP: 463 case RADEON_VA_MAP:
464 bo_va = radeon_bo_va(rbo, &fpriv->vm); 464 bo_va = radeon_vm_bo_find(&fpriv->vm, rbo);
465 if (bo_va) { 465 if (bo_va) {
466 args->operation = RADEON_VA_RESULT_VA_EXIST; 466 args->operation = RADEON_VA_RESULT_VA_EXIST;
467 args->offset = bo_va->soffset; 467 args->offset = bo_va->soffset;
diff --git a/drivers/gpu/drm/radeon/radeon_object.c b/drivers/gpu/drm/radeon/radeon_object.c
index 9024e7222839..2844e0b204b0 100644
--- a/drivers/gpu/drm/radeon/radeon_object.c
+++ b/drivers/gpu/drm/radeon/radeon_object.c
@@ -646,16 +646,3 @@ int radeon_bo_reserve(struct radeon_bo *bo, bool no_wait)
646 } 646 }
647 return 0; 647 return 0;
648} 648}
649
650/* object have to be reserved */
651struct radeon_bo_va *radeon_bo_va(struct radeon_bo *rbo, struct radeon_vm *vm)
652{
653 struct radeon_bo_va *bo_va;
654
655 list_for_each_entry(bo_va, &rbo->va, bo_list) {
656 if (bo_va->vm == vm) {
657 return bo_va;
658 }
659 }
660 return NULL;
661}
diff --git a/drivers/gpu/drm/radeon/radeon_object.h b/drivers/gpu/drm/radeon/radeon_object.h
index 17fb99f177cf..2aaf6e305e42 100644
--- a/drivers/gpu/drm/radeon/radeon_object.h
+++ b/drivers/gpu/drm/radeon/radeon_object.h
@@ -141,8 +141,6 @@ extern void radeon_bo_move_notify(struct ttm_buffer_object *bo,
141 struct ttm_mem_reg *mem); 141 struct ttm_mem_reg *mem);
142extern int radeon_bo_fault_reserve_notify(struct ttm_buffer_object *bo); 142extern int radeon_bo_fault_reserve_notify(struct ttm_buffer_object *bo);
143extern int radeon_bo_get_surface_reg(struct radeon_bo *bo); 143extern int radeon_bo_get_surface_reg(struct radeon_bo *bo);
144extern struct radeon_bo_va *radeon_bo_va(struct radeon_bo *rbo,
145 struct radeon_vm *vm);
146 144
147/* 145/*
148 * sub allocation 146 * sub allocation