Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp544470ybv; Fri, 7 Feb 2020 04:15:59 -0800 (PST) X-Google-Smtp-Source: APXvYqwJfwlxFObkK26PjozdZaQ1Qqc4ftk3ORThJp8HhFKgKscvmSgZ7XLXuvPkIa30qoMMLVE5 X-Received: by 2002:a9d:5e82:: with SMTP id f2mr2364525otl.240.1581077759503; Fri, 07 Feb 2020 04:15:59 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581077759; cv=none; d=google.com; s=arc-20160816; b=hms9iHh6j3OBFZlsjA2BgJQpVqoHZ2jqUJL+etoQuyKk0ah9O96SJGrcTGZ+MuKh5J OuBeTDr6HmkCtG3Ux/7DkQjqgLXr62wOu8YFHbgIM8rDIyvUrIU+zu5M/d+PrCxdQo/6 CAUw4wtDMlgWEsttiukXX84+WVSepOQ42DjOV0+5e2lVpG8/hWP1SLzu1ELACTHx5f7e rH30Db7meGBDZvjSo+HT2yXM6fHyydFitXEEoJhJk6vvBtyVgXSBsGHHHwIqnpu3mkPF Z71vbWAAESRILVRb7cR6/A72FL05pH+1zAmAbhVa+5m1StpLFfx0h/bzLKPzrsyRxUQT ycKg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=qgdKn4lgo+b2XQi8bs8ab6gIv/l1YpMtN0ktSmN9xDI=; b=j1Mi38YeCfkeLnSTTvHXEedVMN6kX7FEoHyS1D1NvAsPYOirBsUv7Ef2qsVOxC++Pz OoGwflMGm1N7lRvKvro3ZhVbTnZs4x6rcSXE2A3CQ93v6Q71fGUHXgVoLyvs9CRexNJN kos9cJmnkJp5hiSeyHHDrC4G6nctBapMtrBOEma4GvzNXzn0m3sfGitSG0LGnIWTRT8a UlCwLd2BBzQSPtB1VtZdFeP1y99avjZO3MPbL80uNy5y0hoP28ADZwyrSzqiVg9+sJ1e 6O6aJ5BvX454fmEBqHBt7Yb9VcNf7dGZ6yU0cmMBE1ovzUuvigLRmAA0VDWlel2kQy0P 6QoA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=jLeOu4ok; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l5si1547473otn.35.2020.02.07.04.15.47; Fri, 07 Feb 2020 04:15:59 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=jLeOu4ok; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727162AbgBGMOa (ORCPT + 99 others); Fri, 7 Feb 2020 07:14:30 -0500 Received: from us-smtp-delivery-1.mimecast.com ([207.211.31.120]:45869 "EHLO us-smtp-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726674AbgBGMO3 (ORCPT ); Fri, 7 Feb 2020 07:14:29 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1581077669; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc; bh=qgdKn4lgo+b2XQi8bs8ab6gIv/l1YpMtN0ktSmN9xDI=; b=jLeOu4ok03INMm/LcJ0NssDbB+cd9/hf4i1077CjxuRKrG0Iy2IsLZoPKc+Yfdg1+Du6kl JU3+s/aC7UzDcmYcMJ5H2l+Qzy2xLrMbufrONtK9mvgwKhj14AbEpBZL9jh9Q8abz0xjM6 6/KP7/dSAbVM7VS6xWMgeqUKYoDhDRs= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-309-1VVY6-LjOZmoqGo5Q-hRBg-1; Fri, 07 Feb 2020 07:14:25 -0500 X-MC-Unique: 1VVY6-LjOZmoqGo5Q-hRBg-1 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.phx2.redhat.com [10.5.11.15]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id A3E4D1088387; Fri, 7 Feb 2020 12:14:23 +0000 (UTC) Received: from sirius.home.kraxel.org (ovpn-116-112.ams2.redhat.com [10.36.116.112]) by smtp.corp.redhat.com (Postfix) with ESMTP id EB513790D8; Fri, 7 Feb 2020 12:14:20 +0000 (UTC) Received: by sirius.home.kraxel.org (Postfix, from userid 1000) id 470731747D; Fri, 7 Feb 2020 13:14:20 +0100 (CET) From: Gerd Hoffmann To: dri-devel@lists.freedesktop.org Cc: gurchetansingh@chromium.org, olvaffe@gmail.com, Gerd Hoffmann , David Airlie , Daniel Vetter , virtualization@lists.linux-foundation.org (open list:VIRTIO GPU DRIVER), linux-kernel@vger.kernel.org (open list) Subject: [PATCH] drm/virtio: add drm_driver.release callback. Date: Fri, 7 Feb 2020 13:14:20 +0100 Message-Id: <20200207121420.26222-1-kraxel@redhat.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.15 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Split virtio_gpu_deinit(), move the drm shutdown and release to virtio_gpu_release(). Also free vbufs in case we can't queue them. Signed-off-by: Gerd Hoffmann --- drivers/gpu/drm/virtio/virtgpu_drv.h | 1 + drivers/gpu/drm/virtio/virtgpu_drv.c | 4 ++++ drivers/gpu/drm/virtio/virtgpu_kms.c | 5 +++++ drivers/gpu/drm/virtio/virtgpu_vq.c | 9 ++++++++- 4 files changed, 18 insertions(+), 1 deletion(-) diff --git a/drivers/gpu/drm/virtio/virtgpu_drv.h b/drivers/gpu/drm/virtio/virtgpu_drv.h index d278c8c50f39..09a485b001e7 100644 --- a/drivers/gpu/drm/virtio/virtgpu_drv.h +++ b/drivers/gpu/drm/virtio/virtgpu_drv.h @@ -217,6 +217,7 @@ extern struct drm_ioctl_desc virtio_gpu_ioctls[DRM_VIRTIO_NUM_IOCTLS]; /* virtio_kms.c */ int virtio_gpu_init(struct drm_device *dev); void virtio_gpu_deinit(struct drm_device *dev); +void virtio_gpu_release(struct drm_device *dev); int virtio_gpu_driver_open(struct drm_device *dev, struct drm_file *file); void virtio_gpu_driver_postclose(struct drm_device *dev, struct drm_file *file); diff --git a/drivers/gpu/drm/virtio/virtgpu_drv.c b/drivers/gpu/drm/virtio/virtgpu_drv.c index 8cf27af3ad53..664a741a3b0b 100644 --- a/drivers/gpu/drm/virtio/virtgpu_drv.c +++ b/drivers/gpu/drm/virtio/virtgpu_drv.c @@ -31,6 +31,7 @@ #include #include +#include #include #include @@ -136,6 +137,7 @@ static void virtio_gpu_remove(struct virtio_device *vdev) struct drm_device *dev = vdev->priv; drm_dev_unregister(dev); + drm_atomic_helper_shutdown(dev); virtio_gpu_deinit(dev); drm_dev_put(dev); } @@ -214,4 +216,6 @@ static struct drm_driver driver = { .major = DRIVER_MAJOR, .minor = DRIVER_MINOR, .patchlevel = DRIVER_PATCHLEVEL, + + .release = virtio_gpu_release, }; diff --git a/drivers/gpu/drm/virtio/virtgpu_kms.c b/drivers/gpu/drm/virtio/virtgpu_kms.c index c1086df49816..b45d12e3db2a 100644 --- a/drivers/gpu/drm/virtio/virtgpu_kms.c +++ b/drivers/gpu/drm/virtio/virtgpu_kms.c @@ -240,6 +240,11 @@ void virtio_gpu_deinit(struct drm_device *dev) flush_work(&vgdev->config_changed_work); vgdev->vdev->config->reset(vgdev->vdev); vgdev->vdev->config->del_vqs(vgdev->vdev); +} + +void virtio_gpu_release(struct drm_device *dev) +{ + struct virtio_gpu_device *vgdev = dev->dev_private; virtio_gpu_modeset_fini(vgdev); virtio_gpu_free_vbufs(vgdev); diff --git a/drivers/gpu/drm/virtio/virtgpu_vq.c b/drivers/gpu/drm/virtio/virtgpu_vq.c index cc02fc4bab2a..cc674b45f904 100644 --- a/drivers/gpu/drm/virtio/virtgpu_vq.c +++ b/drivers/gpu/drm/virtio/virtgpu_vq.c @@ -330,6 +330,11 @@ static void virtio_gpu_queue_ctrl_sgs(struct virtio_gpu_device *vgdev, bool notify = false; int ret; + if (!vgdev->vqs_ready) { + free_vbuf(vgdev, vbuf); + return; + } + if (vgdev->has_indirect) elemcnt = 1; @@ -462,8 +467,10 @@ static void virtio_gpu_queue_cursor(struct virtio_gpu_device *vgdev, int ret; int outcnt; - if (!vgdev->vqs_ready) + if (!vgdev->vqs_ready) { + free_vbuf(vgdev, vbuf); return; + } sg_init_one(&ccmd, vbuf->buf, vbuf->size); sgs[0] = &ccmd; -- 2.18.1