From: Chia-I Wu Date: Wed, 5 Feb 2020 18:19:49 +0000 (-0800) Subject: drm/virtio: unlock object array on errors X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=4d8d4869101590909fcf4bdb8fea8a9affdd2b94;p=linux.git drm/virtio: unlock object array on errors We don't propagate erros to the callers. We have to unlock object arrays on errors. Signed-off-by: Chia-I Wu Link: http://patchwork.freedesktop.org/patch/msgid/20200205181955.202485-6-olvaffe@gmail.com Signed-off-by: Gerd Hoffmann --- diff --git a/drivers/gpu/drm/virtio/virtgpu_vq.c b/drivers/gpu/drm/virtio/virtgpu_vq.c index 7fb09fc4f6a3b..0ceceb39f6a42 100644 --- a/drivers/gpu/drm/virtio/virtgpu_vq.c +++ b/drivers/gpu/drm/virtio/virtgpu_vq.c @@ -370,8 +370,11 @@ static void virtio_gpu_queue_fenced_ctrl_buffer(struct virtio_gpu_device *vgdev, if (is_vmalloc_addr(vbuf->data_buf)) { sgt = vmalloc_to_sgt(vbuf->data_buf, vbuf->data_size, &outcnt); - if (!sgt) + if (!sgt) { + if (fence && vbuf->objs) + virtio_gpu_array_unlock_resv(vbuf->objs); return; + } vout = sgt->sgl; } else { sg_init_one(&sg, vbuf->data_buf, vbuf->data_size);