Skip to content

Commit

Permalink
drm/xe: Relax runtime pm protection around VM
Browse files Browse the repository at this point in the history
In the regular use case scenario, user space will create a
VM, and keep it alive for the entire duration of its workload.

For the regular desktop cases, it means that the VM
is alive even on idle scenarios where display goes off. This
is unacceptable since this would entirely block runtime PM
indefinitely, blocking deeper Package-C state. This would be
a waste drainage of power.

Limit the VM protection solely for long-running workloads that
are not protected by the scheduler references.
By design, run_job for long-running workloads returns NULL and
the scheduler drops all the references of it, hence protecting
the VM for this case is necessary.

v2: Update commit message to a more imperative language and to
    reflect why the VM protection is really needed.
    Also add a comment in the code to let the reason visbible.

v3: Remove vma_access case and the mentions to mmap. Mmap cases
    are already protected by the gem page fault.

Cc: Thomas Hellström <[email protected]>
Cc: Lucas De Marchi <[email protected]>
Cc: Matthew Brost <[email protected]>
Tested-by: Francois Dugast <[email protected]>
Reviewed-by: Matthew Brost <[email protected]>
Reviewed-by: Thomas Hellström <[email protected]>
Link: https://patchwork.freedesktop.org/patch/msgid/[email protected]
Signed-off-by: Rodrigo Vivi <[email protected]>
  • Loading branch information
rodrigovivi committed May 23, 2024
1 parent ad1e331 commit 73ba282
Showing 1 changed file with 9 additions and 3 deletions.
12 changes: 9 additions & 3 deletions drivers/gpu/drm/xe/xe_vm.c
Original file line number Diff line number Diff line change
Expand Up @@ -1347,7 +1347,13 @@ struct xe_vm *xe_vm_create(struct xe_device *xe, u32 flags)

vm->pt_ops = &xelp_pt_ops;

if (!(flags & XE_VM_FLAG_MIGRATION))
/*
* Long-running workloads are not protected by the scheduler references.
* By design, run_job for long-running workloads returns NULL and the
* scheduler drops all the references of it, hence protecting the VM
* for this case is necessary.
*/
if (flags & XE_VM_FLAG_LR_MODE)
xe_pm_runtime_get_noresume(xe);

vm_resv_obj = drm_gpuvm_resv_object_alloc(&xe->drm);
Expand Down Expand Up @@ -1457,7 +1463,7 @@ struct xe_vm *xe_vm_create(struct xe_device *xe, u32 flags)
for_each_tile(tile, xe, id)
xe_range_fence_tree_fini(&vm->rftree[id]);
kfree(vm);
if (!(flags & XE_VM_FLAG_MIGRATION))
if (flags & XE_VM_FLAG_LR_MODE)
xe_pm_runtime_put(xe);
return ERR_PTR(err);
}
Expand Down Expand Up @@ -1592,7 +1598,7 @@ static void vm_destroy_work_func(struct work_struct *w)

mutex_destroy(&vm->snap_mutex);

if (!(vm->flags & XE_VM_FLAG_MIGRATION))
if (vm->flags & XE_VM_FLAG_LR_MODE)
xe_pm_runtime_put(xe);

for_each_tile(tile, xe, id)
Expand Down

0 comments on commit 73ba282

Please sign in to comment.