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;
        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);
                        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;
                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),
 
                        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;