drm/xe/vm: tidy up xe_runtime_pm usage
authorMatthew Auld <matthew.auld@intel.com>
Wed, 19 Jul 2023 08:38:04 +0000 (09:38 +0100)
committerRodrigo Vivi <rodrigo.vivi@intel.com>
Thu, 21 Dec 2023 16:37:35 +0000 (11:37 -0500)
The xe_device_mem_access_get() should be all that's needed here and
should now work as expected, without any strange races. In theory should
be no functional changes here.

Reported-by: Oded Gabbay <ogabbay@kernel.org>
Signed-off-by: Matthew Auld <matthew.auld@intel.com>
Cc: Rodrigo Vivi <rodrigo.vivi@intel.com>
Cc: Thomas Hellström <thomas.hellstrom@linux.intel.com>
Reviewed-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
drivers/gpu/drm/xe/xe_vm.c

index 2b9a761..d4c6ddf 100644 (file)
@@ -1245,11 +1245,8 @@ struct xe_vm *xe_vm_create(struct xe_device *xe, u32 flags)
 
        INIT_LIST_HEAD(&vm->extobj.list);
 
-       if (!(flags & XE_VM_FLAG_MIGRATION)) {
-               /* We need to immeditatelly exit from any D3 state */
-               xe_pm_runtime_get(xe);
+       if (!(flags & XE_VM_FLAG_MIGRATION))
                xe_device_mem_access_get(xe);
-       }
 
        vm_resv_obj = drm_gpuvm_resv_object_alloc(&xe->drm);
        if (!vm_resv_obj) {
@@ -1360,10 +1357,8 @@ err_close:
 
 err_no_resv:
        kfree(vm);
-       if (!(flags & XE_VM_FLAG_MIGRATION)) {
+       if (!(flags & XE_VM_FLAG_MIGRATION))
                xe_device_mem_access_put(xe);
-               xe_pm_runtime_put(xe);
-       }
        return ERR_PTR(err);
 }
 
@@ -1522,7 +1517,6 @@ static void vm_destroy_work_func(struct work_struct *w)
 
        if (!(vm->flags & XE_VM_FLAG_MIGRATION)) {
                xe_device_mem_access_put(xe);
-               xe_pm_runtime_put(xe);
 
                if (xe->info.has_asid) {
                        mutex_lock(&xe->usm.lock);