Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp3909231pxb; Tue, 2 Nov 2021 00:10:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz4BSZRxhMVoWPSoV8+x8FuSxnOaKPAcYLQTaHklzSK4SDO4lPytX24sIH+GamZZ/eBuGWH X-Received: by 2002:a5e:8611:: with SMTP id z17mr18023531ioj.43.1635837011451; Tue, 02 Nov 2021 00:10:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1635837011; cv=none; d=google.com; s=arc-20160816; b=VlroMyduyTtUm04ubKKT7ctVLpms7gslRaln6Oxfc+esQVQ5F+JlCVWECz+rbC6vvG ZK0PjBXOplJ/lGhikbc2Pl6RvBx2YuGInmFYWWFgO5+LlY72gPY3hn51ycoskT5XZJOl 4zijqNfPixy7pYDVmT4zwR86rL6hy4utrgBJm4Zs6F/2xnDqoUOSrsdxoCqjmV38DMMs ljbOsj6bP8+SMuWK3/EcS/LtlZJ9PTCSwys15likzvEmSRfIPYjit4jCgYVedHeoy7/b 96jxfuBwkMKULZn8oHs/vQv6ZYSBHL9Dqc2wjSwbH9Y3p6787TJ6fXo+46syLZgsfZte COkg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=0cvxm+1NDIuIjwW6TCzfd8E3JMSEUjYmjWbtvzBc2eY=; b=GGacxS4IpNBthIoZYiXiMDw+bhxQBJtY4SayORlRRJnyNYPDF9i7fQzLHXvRKTXf4j f9bzjKR80Xlifi8HKF23XoXrUSqB5BGjLGmaIsn6zbwNnQ7grfZW4ZCeB78ZS6x9VGsm 0N3JuefSngDmmj9zi5OcgpE+pBqEP3bODIaznRzkZhCbKle8VoalMs56XEKMBWrAVMda L+hTzxQBnFVRy3vVVtPO+fDGp9T11IMbwstIbC7/eLy5VioXrAF1gZcP+c2B1SjGCVzS iL+vTtYzfbZh/wD5Bqvj5OYxAwNejWAQmdjFqGB7C0HlRP7BvUx9XxxgnAiDqTkYVOY3 EUWg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=bombadil.20210309 header.b="d/eDM1VE"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y13si14213548ioc.90.2021.11.02.00.10.00; Tue, 02 Nov 2021 00:10:11 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@infradead.org header.s=bombadil.20210309 header.b="d/eDM1VE"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231873AbhKBHLd (ORCPT + 99 others); Tue, 2 Nov 2021 03:11:33 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53802 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231165AbhKBHLD (ORCPT ); Tue, 2 Nov 2021 03:11:03 -0400 Received: from bombadil.infradead.org (bombadil.infradead.org [IPv6:2607:7c80:54:e::133]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BD37FC06120E for ; Tue, 2 Nov 2021 00:08:28 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20210309; h=Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-Id:Date:Subject:Cc:To:From:Sender :Reply-To:Content-Type:Content-ID:Content-Description; bh=0cvxm+1NDIuIjwW6TCzfd8E3JMSEUjYmjWbtvzBc2eY=; b=d/eDM1VEchLVS3pbAngUVSb+Qf b2W9RL6bmvkl2DcGj7oxtAp7vHWBhMzv9RBi0DAezAZcn612RJppDZKn10f8vcl9rhTkFvKLL7pMo oF4zA4QvA7ucMy6xCmz7zoYReSC6fRyTEt0XgmaGL+Th5VCIpliXhb5ZjCVR+0+XLae/9Q3t8Nqxg X2Y7jzQfct9ndhhgvtwkSkgNRmjxciUhMlgo++kAneKZ1f30dwf+COv+yq/2G+PYWO+wRy7cwKUef FflP0r+U8CavuCOSRgdlf9i2rBL2YjQFZeikY0UjPf+ABm/r0E2B+6yj2BULeXI20ebAhVn3QN2RO 56xR7aNw==; Received: from 213-225-15-89.nat.highway.a1.net ([213.225.15.89] helo=localhost) by bombadil.infradead.org with esmtpsa (Exim 4.94.2 #2 (Red Hat Linux)) id 1mhnuE-000iOC-GT; Tue, 02 Nov 2021 07:08:27 +0000 From: Christoph Hellwig To: Jani Nikula , Joonas Lahtinen , Rodrigo Vivi , Zhenyu Wang , Zhi Wang Cc: Jason Gunthorpe , intel-gfx@lists.freedesktop.org, intel-gvt-dev@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Subject: [PATCH 24/29] drm/i915/gvt: remove the extra vfio_device refcounting for dmabufs Date: Tue, 2 Nov 2021 08:05:56 +0100 Message-Id: <20211102070601.155501-25-hch@lst.de> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20211102070601.155501-1-hch@lst.de> References: <20211102070601.155501-1-hch@lst.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SRS-Rewrite: SMTP reverse-path rewritten from by bombadil.infradead.org. See http://www.infradead.org/rpr.html Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org All the dmabufs are torn down when th VGPU is released, so there is no need for extra refcounting here. Based on an patch from Jason Gunthorpe. Signed-off-by: Christoph Hellwig --- drivers/gpu/drm/i915/gvt/dmabuf.c | 12 ------------ drivers/gpu/drm/i915/gvt/gvt.h | 1 - 2 files changed, 13 deletions(-) diff --git a/drivers/gpu/drm/i915/gvt/dmabuf.c b/drivers/gpu/drm/i915/gvt/dmabuf.c index eacfe7beaaf67..88c4f8b02ffb6 100644 --- a/drivers/gpu/drm/i915/gvt/dmabuf.c +++ b/drivers/gpu/drm/i915/gvt/dmabuf.c @@ -134,7 +134,6 @@ static void dmabuf_gem_object_free(struct kref *kref) struct intel_vgpu_dmabuf_obj, list); if (dmabuf_obj == obj) { list_del(pos); - vfio_device_put(vgpu->vfio_device); idr_remove(&vgpu->object_idr, dmabuf_obj->dmabuf_id); kfree(dmabuf_obj->info); @@ -474,16 +473,6 @@ int intel_vgpu_query_plane(struct intel_vgpu *vgpu, void *args) kref_init(&dmabuf_obj->kref); - mutex_lock(&vgpu->dmabuf_lock); - vgpu->vfio_device = vfio_device_get_from_dev(mdev_dev(vgpu->mdev)); - if (!vgpu->vfio_device) { - gvt_vgpu_err("failed to get vfio device\n"); - mutex_unlock(&vgpu->dmabuf_lock); - ret = -ENODEV; - goto out_free_info; - } - mutex_unlock(&vgpu->dmabuf_lock); - update_fb_info(gfx_plane_info, &fb_info); INIT_LIST_HEAD(&dmabuf_obj->list); @@ -589,7 +578,6 @@ void intel_vgpu_dmabuf_cleanup(struct intel_vgpu *vgpu) dmabuf_obj->vgpu = NULL; idr_remove(&vgpu->object_idr, dmabuf_obj->dmabuf_id); - vfio_device_put(vgpu->vfio_device); list_del(pos); /* dmabuf_obj might be freed in dmabuf_obj_put */ diff --git a/drivers/gpu/drm/i915/gvt/gvt.h b/drivers/gpu/drm/i915/gvt/gvt.h index 7c87d7638e6b2..fa83365227514 100644 --- a/drivers/gpu/drm/i915/gvt/gvt.h +++ b/drivers/gpu/drm/i915/gvt/gvt.h @@ -230,7 +230,6 @@ struct intel_vgpu { struct kvm *kvm; struct work_struct release_work; atomic_t released; - struct vfio_device *vfio_device; struct vfio_group *vfio_group; struct kvm_page_track_notifier_node track_node; -- 2.30.2