[Intel-gfx] [PATCH v9 11/70] drm/i915: Disable userptr pread/pwrite support.

Jason Ekstrand jason at jlekstrand.net
Wed Mar 24 13:57:55 UTC 2021


Never used by Mesa AFAIK

Acked-by: Jason Ekstrand <jason at jlekstrand.net>

On Tue, Mar 23, 2021 at 10:51 AM Maarten Lankhorst
<maarten.lankhorst at linux.intel.com> wrote:
>
> Userptr should not need the kernel for a userspace memcpy, userspace
> needs to call memcpy directly.
>
> Specifically, disable i915_gem_pwrite_ioctl() and i915_gem_pread_ioctl().
>
> Signed-off-by: Maarten Lankhorst <maarten.lankhorst at linux.intel.com>
> Reviewed-by: Thomas Hellström <thomas.hellstrom at linux.intel.com>
>
> -- Still needs an ack from relevant userspace that it won't break, but should be good.
> ---
>  drivers/gpu/drm/i915/gem/i915_gem_userptr.c | 20 ++++++++++++++++++++
>  drivers/gpu/drm/i915/i915_gem.c             |  5 +++++
>  2 files changed, 25 insertions(+)
>
> diff --git a/drivers/gpu/drm/i915/gem/i915_gem_userptr.c b/drivers/gpu/drm/i915/gem/i915_gem_userptr.c
> index 0f9024c62c06..5a19699c2d7e 100644
> --- a/drivers/gpu/drm/i915/gem/i915_gem_userptr.c
> +++ b/drivers/gpu/drm/i915/gem/i915_gem_userptr.c
> @@ -700,6 +700,24 @@ i915_gem_userptr_dmabuf_export(struct drm_i915_gem_object *obj)
>         return i915_gem_userptr_init__mmu_notifier(obj, 0);
>  }
>
> +static int
> +i915_gem_userptr_pwrite(struct drm_i915_gem_object *obj,
> +                       const struct drm_i915_gem_pwrite *args)
> +{
> +       drm_dbg(obj->base.dev, "pwrite to userptr no longer allowed\n");
> +
> +       return -EINVAL;
> +}
> +
> +static int
> +i915_gem_userptr_pread(struct drm_i915_gem_object *obj,
> +                      const struct drm_i915_gem_pread *args)
> +{
> +       drm_dbg(obj->base.dev, "pread from userptr no longer allowed\n");
> +
> +       return -EINVAL;
> +}
> +
>  static const struct drm_i915_gem_object_ops i915_gem_userptr_ops = {
>         .name = "i915_gem_object_userptr",
>         .flags = I915_GEM_OBJECT_IS_SHRINKABLE |
> @@ -708,6 +726,8 @@ static const struct drm_i915_gem_object_ops i915_gem_userptr_ops = {
>         .get_pages = i915_gem_userptr_get_pages,
>         .put_pages = i915_gem_userptr_put_pages,
>         .dmabuf_export = i915_gem_userptr_dmabuf_export,
> +       .pwrite = i915_gem_userptr_pwrite,
> +       .pread = i915_gem_userptr_pread,
>         .release = i915_gem_userptr_release,
>  };
>
> diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c
> index 25444d360f7f..dde12ce4f90b 100644
> --- a/drivers/gpu/drm/i915/i915_gem.c
> +++ b/drivers/gpu/drm/i915/i915_gem.c
> @@ -403,6 +403,11 @@ i915_gem_pread_ioctl(struct drm_device *dev, void *data,
>         }
>
>         trace_i915_gem_object_pread(obj, args->offset, args->size);
> +       ret = -ENODEV;
> +       if (obj->ops->pread)
> +               ret = obj->ops->pread(obj, args);
> +       if (ret != -ENODEV)
> +               goto out;
>
>         ret = -ENODEV;
>         if (obj->ops->pread)
> --
> 2.31.0
>
> _______________________________________________
> Intel-gfx mailing list
> Intel-gfx at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/intel-gfx


More information about the Intel-gfx mailing list