mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-09-29 05:44:11 +00:00
drm/virtio: implement context init: allocate an array of fence contexts
We don't want fences from different 3D contexts (virgl, gfxstream, venus) to be on the same timeline. With explicit context creation, we can specify the number of ring each context wants. Execbuffer can specify which ring to use. Signed-off-by: Gurchetan Singh <gurchetansingh@chromium.org> Acked-by: Lingfeng Yang <lfy@google.com> Link: http://patchwork.freedesktop.org/patch/msgid/20210921232024.817-10-gurchetansingh@chromium.org Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
parent
bbf588d7d4
commit
85c83ea915
2 changed files with 35 additions and 2 deletions
|
@ -56,6 +56,7 @@
|
|||
#define STATE_ERR 2
|
||||
|
||||
#define MAX_CAPSET_ID 63
|
||||
#define MAX_RINGS 64
|
||||
|
||||
struct virtio_gpu_object_params {
|
||||
unsigned long size;
|
||||
|
@ -263,6 +264,8 @@ struct virtio_gpu_fpriv {
|
|||
uint32_t ctx_id;
|
||||
uint32_t context_init;
|
||||
bool context_created;
|
||||
uint32_t num_rings;
|
||||
uint64_t base_fence_ctx;
|
||||
struct mutex context_lock;
|
||||
};
|
||||
|
||||
|
|
|
@ -99,6 +99,11 @@ static int virtio_gpu_execbuffer_ioctl(struct drm_device *dev, void *data,
|
|||
int in_fence_fd = exbuf->fence_fd;
|
||||
int out_fence_fd = -1;
|
||||
void *buf;
|
||||
uint64_t fence_ctx;
|
||||
uint32_t ring_idx;
|
||||
|
||||
fence_ctx = vgdev->fence_drv.context;
|
||||
ring_idx = 0;
|
||||
|
||||
if (vgdev->has_virgl_3d == false)
|
||||
return -ENOSYS;
|
||||
|
@ -106,6 +111,17 @@ static int virtio_gpu_execbuffer_ioctl(struct drm_device *dev, void *data,
|
|||
if ((exbuf->flags & ~VIRTGPU_EXECBUF_FLAGS))
|
||||
return -EINVAL;
|
||||
|
||||
if ((exbuf->flags & VIRTGPU_EXECBUF_RING_IDX)) {
|
||||
if (exbuf->ring_idx >= vfpriv->num_rings)
|
||||
return -EINVAL;
|
||||
|
||||
if (!vfpriv->base_fence_ctx)
|
||||
return -EINVAL;
|
||||
|
||||
fence_ctx = vfpriv->base_fence_ctx;
|
||||
ring_idx = exbuf->ring_idx;
|
||||
}
|
||||
|
||||
exbuf->fence_fd = -1;
|
||||
|
||||
virtio_gpu_create_context(dev, file);
|
||||
|
@ -173,7 +189,7 @@ static int virtio_gpu_execbuffer_ioctl(struct drm_device *dev, void *data,
|
|||
goto out_memdup;
|
||||
}
|
||||
|
||||
out_fence = virtio_gpu_fence_alloc(vgdev, vgdev->fence_drv.context, 0);
|
||||
out_fence = virtio_gpu_fence_alloc(vgdev, fence_ctx, ring_idx);
|
||||
if(!out_fence) {
|
||||
ret = -ENOMEM;
|
||||
goto out_unresv;
|
||||
|
@ -691,7 +707,7 @@ static int virtio_gpu_context_init_ioctl(struct drm_device *dev,
|
|||
return -EINVAL;
|
||||
|
||||
/* Number of unique parameters supported at this time. */
|
||||
if (num_params > 1)
|
||||
if (num_params > 2)
|
||||
return -EINVAL;
|
||||
|
||||
ctx_set_params = memdup_user(u64_to_user_ptr(args->ctx_set_params),
|
||||
|
@ -731,6 +747,20 @@ static int virtio_gpu_context_init_ioctl(struct drm_device *dev,
|
|||
|
||||
vfpriv->context_init |= value;
|
||||
break;
|
||||
case VIRTGPU_CONTEXT_PARAM_NUM_RINGS:
|
||||
if (vfpriv->base_fence_ctx) {
|
||||
ret = -EINVAL;
|
||||
goto out_unlock;
|
||||
}
|
||||
|
||||
if (value > MAX_RINGS) {
|
||||
ret = -EINVAL;
|
||||
goto out_unlock;
|
||||
}
|
||||
|
||||
vfpriv->base_fence_ctx = dma_fence_context_alloc(value);
|
||||
vfpriv->num_rings = value;
|
||||
break;
|
||||
default:
|
||||
ret = -EINVAL;
|
||||
goto out_unlock;
|
||||
|
|
Loading…
Reference in a new issue