<div dir="ltr"><div dir="ltr"><br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Tue, Jul 2, 2019 at 7:19 AM Gerd Hoffmann <<a href="mailto:kraxel@redhat.com" target="_blank">kraxel@redhat.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Switch to the virtio_gpu_array_* helper workflow.<br>
<br>
Signed-off-by: Gerd Hoffmann <<a href="mailto:kraxel@redhat.com" target="_blank">kraxel@redhat.com</a>><br>
---<br>
 drivers/gpu/drm/virtio/virtgpu_drv.h |  4 ++--<br>
 drivers/gpu/drm/virtio/virtgpu_gem.c | 24 +++++++++++-------------<br>
 drivers/gpu/drm/virtio/virtgpu_vq.c  | 10 ++++++----<br>
 3 files changed, 19 insertions(+), 19 deletions(-)<br>
<br>
diff --git a/drivers/gpu/drm/virtio/virtgpu_drv.h b/drivers/gpu/drm/virtio/virtgpu_drv.h<br>
index b1f63a21abb6..d99c54abd090 100644<br>
--- a/drivers/gpu/drm/virtio/virtgpu_drv.h<br>
+++ b/drivers/gpu/drm/virtio/virtgpu_drv.h<br>
@@ -292,10 +292,10 @@ void virtio_gpu_cmd_context_destroy(struct virtio_gpu_device *vgdev,<br>
                                    uint32_t id);<br>
 void virtio_gpu_cmd_context_attach_resource(struct virtio_gpu_device *vgdev,<br>
                                            uint32_t ctx_id,<br>
-                                           uint32_t resource_id);<br>
+                                           struct virtio_gpu_object_array *objs);<br>
 void virtio_gpu_cmd_context_detach_resource(struct virtio_gpu_device *vgdev,<br>
                                            uint32_t ctx_id,<br>
-                                           uint32_t resource_id);<br>
+                                           struct virtio_gpu_object_array *objs);<br>
 void virtio_gpu_cmd_submit(struct virtio_gpu_device *vgdev,<br>
                           void *data, uint32_t data_size,<br>
                           uint32_t ctx_id,<br>
diff --git a/drivers/gpu/drm/virtio/virtgpu_gem.c b/drivers/gpu/drm/virtio/virtgpu_gem.c<br>
index 6baf64141645..e75819dbba80 100644<br>
--- a/drivers/gpu/drm/virtio/virtgpu_gem.c<br>
+++ b/drivers/gpu/drm/virtio/virtgpu_gem.c<br>
@@ -111,19 +111,18 @@ int virtio_gpu_gem_object_open(struct drm_gem_object *obj,<br>
 {<br>
        struct virtio_gpu_device *vgdev = obj->dev->dev_private;<br>
        struct virtio_gpu_fpriv *vfpriv = file->driver_priv;<br>
-       struct virtio_gpu_object *qobj = gem_to_virtio_gpu_obj(obj);<br>
-       int r;<br>
+       struct virtio_gpu_object_array *objs;<br>
<br>
        if (!vgdev->has_virgl_3d)<br>
                return 0;<br>
<br>
-       r = virtio_gpu_object_reserve(qobj);<br>
-       if (r)<br>
-               return r;<br>
+       objs = virtio_gpu_array_alloc(1);<br>
+       if (!objs)<br>
+               return -ENOMEM;<br>
+       virtio_gpu_array_add_obj(objs, obj);<br>
<br>
        virtio_gpu_cmd_context_attach_resource(vgdev, vfpriv->ctx_id,<br>
-                                              qobj->hw_res_handle);<br>
-       virtio_gpu_object_unreserve(qobj);<br>
+                                              objs);<br>
        return 0;<br>
 }<br>
<br>
@@ -132,19 +131,18 @@ void virtio_gpu_gem_object_close(struct drm_gem_object *obj,<br>
 {<br>
        struct virtio_gpu_device *vgdev = obj->dev->dev_private;<br>
        struct virtio_gpu_fpriv *vfpriv = file->driver_priv;<br>
-       struct virtio_gpu_object *qobj = gem_to_virtio_gpu_obj(obj);<br>
-       int r;<br>
+       struct virtio_gpu_object_array *objs;<br>
<br>
        if (!vgdev->has_virgl_3d)<br>
                return;<br>
<br>
-       r = virtio_gpu_object_reserve(qobj);<br>
-       if (r)<br>
+       objs = virtio_gpu_array_alloc(1);<br>
+       if (!objs)<br>
                return;<br>
+       virtio_gpu_array_add_obj(objs, obj);<br></blockquote><div><br></div><div>This seems to call drm_gem_object_get.  Without adding the objects to the vbuf, aren't we missing the corresponding drm_gem_object_put_unlocked?</div><div><br></div><div>Some miscellaneous comments:</div><div>1) Maybe virtio_gpu_array can have it's own header and file?  virtgpu_drv.h is getting rather big..</div><div>2) What data are you trying to protect with the additional references?  Is it host side resources (i.e, the host GL texture or buffer object) or is it guest side resources (fences)?  Guest side resources seem properly counted to me.  GL is supposed to reference count pending resources as well, but that's not always the case in practice.  A little blurb somewhere like "hold on to 3D GEM buffers until the host response as a safety measure" or "we could potential cause a kernel oops if [...]" would be useful.</div><div><br></div><div>The guest side looks sufficiently referenced to me, while the GL spec indicates   </div><div> <br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
        virtio_gpu_cmd_context_detach_resource(vgdev, vfpriv->ctx_id,<br>
-                                               qobj->hw_res_handle);<br>
-       virtio_gpu_object_unreserve(qobj);<br>
+                                              objs);<br>
 }<br>
<br>
 struct virtio_gpu_object_array *virtio_gpu_array_alloc(u32 nents)<br>
diff --git a/drivers/gpu/drm/virtio/virtgpu_vq.c b/drivers/gpu/drm/virtio/virtgpu_vq.c<br>
index 1c0097de419a..799d1339ee0f 100644<br>
--- a/drivers/gpu/drm/virtio/virtgpu_vq.c<br>
+++ b/drivers/gpu/drm/virtio/virtgpu_vq.c<br>
@@ -835,8 +835,9 @@ void virtio_gpu_cmd_context_destroy(struct virtio_gpu_device *vgdev,<br>
<br>
 void virtio_gpu_cmd_context_attach_resource(struct virtio_gpu_device *vgdev,<br>
                                            uint32_t ctx_id,<br>
-                                           uint32_t resource_id)<br>
+                                           struct virtio_gpu_object_array *objs)<br>
 {<br>
+       struct virtio_gpu_object *bo = gem_to_virtio_gpu_obj(objs->objs[0]);<br>
        struct virtio_gpu_ctx_resource *cmd_p;<br>
        struct virtio_gpu_vbuffer *vbuf;<br>
<br>
@@ -845,15 +846,16 @@ void virtio_gpu_cmd_context_attach_resource(struct virtio_gpu_device *vgdev,<br>
<br>
        cmd_p->hdr.type = cpu_to_le32(VIRTIO_GPU_CMD_CTX_ATTACH_RESOURCE);<br>
        cmd_p->hdr.ctx_id = cpu_to_le32(ctx_id);<br>
-       cmd_p->resource_id = cpu_to_le32(resource_id);<br>
+       cmd_p->resource_id = cpu_to_le32(bo->hw_res_handle);<br>
        virtio_gpu_queue_ctrl_buffer(vgdev, vbuf);<br>
<br>
 }<br>
<br>
 void virtio_gpu_cmd_context_detach_resource(struct virtio_gpu_device *vgdev,<br>
                                            uint32_t ctx_id,<br>
-                                           uint32_t resource_id)<br>
+                                           struct virtio_gpu_object_array *objs)<br>
 {<br>
+       struct virtio_gpu_object *bo = gem_to_virtio_gpu_obj(objs->objs[0]);<br>
        struct virtio_gpu_ctx_resource *cmd_p;<br>
        struct virtio_gpu_vbuffer *vbuf;<br>
<br>
@@ -862,7 +864,7 @@ void virtio_gpu_cmd_context_detach_resource(struct virtio_gpu_device *vgdev,<br>
<br>
        cmd_p->hdr.type = cpu_to_le32(VIRTIO_GPU_CMD_CTX_DETACH_RESOURCE);<br>
        cmd_p->hdr.ctx_id = cpu_to_le32(ctx_id);<br>
-       cmd_p->resource_id = cpu_to_le32(resource_id);<br>
+       cmd_p->resource_id = cpu_to_le32(bo->hw_res_handle);<br>
        virtio_gpu_queue_ctrl_buffer(vgdev, vbuf);<br>
 }<br>
<br>
-- <br>
2.18.1<br>
<br>
</blockquote></div></div>