From: Honglei Huang <[email protected]>

Integrate userptr functionality into the blob resource creation path:

- Add userptr flags to VIRTGPU_BLOB_FLAG_USE_MASK for validation
- Check userptr feature support in verify_blob()
- Route userptr requests to virtio_gpu_userptr_create()
- Pass userptr address from ioctl to params structure

With this change, userspace can create userptr blob resources by setting
VIRTGPU_BLOB_FLAG_USE_USERPTR flag and providing a valid userptr address.

Signed-off-by: Honglei Huang <[email protected]>
---
 drivers/gpu/drm/virtio/virtgpu_ioctl.c | 11 +++++++++--
 1 file changed, 9 insertions(+), 2 deletions(-)

diff --git a/drivers/gpu/drm/virtio/virtgpu_ioctl.c 
b/drivers/gpu/drm/virtio/virtgpu_ioctl.c
index 9081dbeaa362..6744c3f2867d 100644
--- a/drivers/gpu/drm/virtio/virtgpu_ioctl.c
+++ b/drivers/gpu/drm/virtio/virtgpu_ioctl.c
@@ -36,7 +36,9 @@
 
 #define VIRTGPU_BLOB_FLAG_USE_MASK (VIRTGPU_BLOB_FLAG_USE_MAPPABLE | \
                                    VIRTGPU_BLOB_FLAG_USE_SHAREABLE | \
-                                   VIRTGPU_BLOB_FLAG_USE_CROSS_DEVICE)
+                                   VIRTGPU_BLOB_FLAG_USE_CROSS_DEVICE | \
+                                   VIRTGPU_BLOB_FLAG_USE_USERPTR | \
+                                   VIRTGPU_BLOB_FLAG_USERPTR_RDONLY)
 
 /* Must be called with &virtio_gpu_fpriv.struct_mutex held. */
 static void virtio_gpu_create_context_locked(struct virtio_gpu_device *vgdev,
@@ -447,6 +449,8 @@ static int verify_blob(struct virtio_gpu_device *vgdev,
 {
        if (!vgdev->has_resource_blob)
                return -EINVAL;
+       if (!vgdev->has_resource_userptr && rc_blob->userptr)
+               return -EINVAL;
 
        if (rc_blob->blob_flags & ~VIRTGPU_BLOB_FLAG_USE_MASK)
                return -EINVAL;
@@ -492,6 +496,7 @@ static int verify_blob(struct virtio_gpu_device *vgdev,
        params->size = rc_blob->size;
        params->blob = true;
        params->blob_flags = rc_blob->blob_flags;
+       params->userptr = rc_blob->userptr;
        return 0;
 }
 
@@ -530,8 +535,10 @@ static int virtio_gpu_resource_create_blob_ioctl(struct 
drm_device *dev,
                                      vfpriv->ctx_id, NULL, NULL);
        }
 
-       if (guest_blob)
+       if (guest_blob && !params.userptr)
                ret = virtio_gpu_object_create(vgdev, &params, &bo, NULL);
+       else if (guest_blob && params.userptr)
+               ret = virtio_gpu_userptr_create(vgdev, file, &params, &bo);
        else if (!guest_blob && host3d_blob)
                ret = virtio_gpu_vram_create(vgdev, &params, &bo);
        else
-- 
2.34.1

Reply via email to