[PATCH] drm/xe: Don't use drm exec locking in SVM pagefaults

Summers, Stuart stuart.summers at intel.com
Wed Jun 11 19:47:35 UTC 2025


On Tue, 2025-06-03 at 10:40 -0700, Matthew Brost wrote:
> Only the VM dma-resv lock is needed in SVM pagefaults so
> xe_vm_lock/unlock can be used instead of drm exec. Micro optimization
> but should save some CPU cycles in a critical path.
> 
> Signed-off-by: Matthew Brost <matthew.brost at intel.com>

Reviewed-by: Stuart Summers <stuart.summers at intel.com>

Looks great, thanks Matt!

> ---
>  drivers/gpu/drm/xe/xe_svm.c | 36 +++++++++++++----------------------
> -
>  1 file changed, 13 insertions(+), 23 deletions(-)
> 
> diff --git a/drivers/gpu/drm/xe/xe_svm.c
> b/drivers/gpu/drm/xe/xe_svm.c
> index f27fb9b588de..952b75a4264d 100644
> --- a/drivers/gpu/drm/xe/xe_svm.c
> +++ b/drivers/gpu/drm/xe/xe_svm.c
> @@ -858,7 +858,6 @@ int xe_svm_handle_pagefault(struct xe_vm *vm,
> struct xe_vma *vma,
>                         vm->xe->atomic_svm_timeslice_ms : 0,
>         };
>         struct xe_svm_range *range;
> -       struct drm_exec exec;
>         struct dma_fence *fence;
>         struct xe_tile *tile = gt_to_tile(gt);
>         int migrate_try_count = ctx.devmem_only ? 3 : 1;
> @@ -933,30 +932,21 @@ int xe_svm_handle_pagefault(struct xe_vm *vm,
> struct xe_vma *vma,
>         range_debug(range, "PAGE FAULT - BIND");
>  
>  retry_bind:
> -       drm_exec_init(&exec, 0, 0);
> -       drm_exec_until_all_locked(&exec) {
> -               err = drm_exec_lock_obj(&exec, vm->gpuvm.r_obj);
> -               drm_exec_retry_on_contention(&exec);
> -               if (err) {
> -                       drm_exec_fini(&exec);
> -                       goto err_out;
> -               }
> -
> -               fence = xe_vm_range_rebind(vm, vma, range, BIT(tile-
> >id));
> -               if (IS_ERR(fence)) {
> -                       drm_exec_fini(&exec);
> -                       err = PTR_ERR(fence);
> -                       if (err == -EAGAIN) {
> -                               ctx.timeslice_ms <<= 1; /* Double
> timeslice if we have to retry */
> -                               range_debug(range, "PAGE FAULT -
> RETRY BIND");
> -                               goto retry;
> -                       }
> -                       if (xe_vm_validate_should_retry(&exec, err,
> &end))
> -                               goto retry_bind;
> -                       goto err_out;
> +       xe_vm_lock(vm, false);
> +       fence = xe_vm_range_rebind(vm, vma, range, BIT(tile->id));
> +       if (IS_ERR(fence)) {
> +               xe_vm_unlock(vm);
> +               err = PTR_ERR(fence);
> +               if (err == -EAGAIN) {
> +                       ctx.timeslice_ms <<= 1; /* Double timeslice
> if we have to retry */
> +                       range_debug(range, "PAGE FAULT - RETRY
> BIND");
> +                       goto retry;
>                 }
> +               if (xe_vm_validate_should_retry(NULL, err, &end))
> +                       goto retry_bind;
> +               goto err_out;
>         }
> -       drm_exec_fini(&exec);
> +       xe_vm_unlock(vm);
>  
>         dma_fence_wait(fence, false);
>         dma_fence_put(fence);



More information about the Intel-xe mailing list