Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp598941ybh; Tue, 21 Jul 2020 03:20:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx/drp9yteI4BMhmhjw4o9TXEG9LFPkL6bmJ4hB0hrS7Y4mFzWbmlfccKWQ5uc9F4beGyXZ X-Received: by 2002:a17:906:6499:: with SMTP id e25mr24178219ejm.352.1595326813065; Tue, 21 Jul 2020 03:20:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595326813; cv=none; d=google.com; s=arc-20160816; b=bbx7c2/KElMbGK8WhqXuCk4Zx61gSiGJiWKEeqUhgaCvZInV3Dj2hd8YFxl4sFFt+x 6bcY1Cf0C4VrFv4IBvHQgk6/cYqaT4DkHCy/BlZoSz+DWw7D33s7fG7arhYOlInFqlpo 7h/FA2hK2BgPYhNuiWeabsS7W/X4L/RrnDFFo4hncCJtycAI0xBdBKjOzyoErGwUgeiK qpnmOmChkHJPb6lR4M1Ip5CbYClJlwOmoQYcClGJABobaXQEIsxA+3CmH/RVQByI6b9q iju0FmnV3RsMY9lOVdjncWCif6uFPu91SiE6nLXGa8SNrCKZ4Hmjl3JuoxyboWCavwoU C+gQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=o+q+SwIxmtmY9Sx81EleZKhYAND9OH1kntiZdkYfvU0=; b=BdghIyDGAIAibNoeCaRl0173n2pok0N8wl2D87k8rZ6ZSB6XAL2SAkF0Rgmo8pIY72 Xk8I2OJDk1zgJg7Ev+xlOYXHIyQitFzTVvRMvRypnzEADS2AgGcnlmCJ1y5RD4QXwY7H 88tZfh1xvaM6MHrMfYiQdRI8ygl3ROamIrc1HxEUKHCL99hL8dwgIpDnHtWMkjF0hm3T KRaSacOw/UQQnRU/xA8E+XwMR1Z88hk7wAeG5OV3XpbqsjxxxMiiBIiXgoZ8LeFjlL2I 6vqj9A3Di3DzMhkOpzGkxXMMOE7nD2aJpD7H1a/zTjWpUYVQiA8FC7HAXDpooeMAL+rU MhTw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=qWUN5QA1; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ds3si1638087ejc.369.2020.07.21.03.19.50; Tue, 21 Jul 2020 03:20:13 -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=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=qWUN5QA1; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728951AbgGUKRa (ORCPT + 99 others); Tue, 21 Jul 2020 06:17:30 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43394 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726147AbgGUKR2 (ORCPT ); Tue, 21 Jul 2020 06:17:28 -0400 Received: from mail-pl1-x641.google.com (mail-pl1-x641.google.com [IPv6:2607:f8b0:4864:20::641]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1FB48C0619D8 for ; Tue, 21 Jul 2020 03:17:28 -0700 (PDT) Received: by mail-pl1-x641.google.com with SMTP id 72so10060433ple.0 for ; Tue, 21 Jul 2020 03:17:28 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=o+q+SwIxmtmY9Sx81EleZKhYAND9OH1kntiZdkYfvU0=; b=qWUN5QA1aFxfB2DjiMqONNST2jbTf6OJYJuEncUgJ0vCiHbJxunBCOUDrf4lekJ8ha xuuUm8Cl2v7EumQrQheCESumNpdnZvcS/90E63isULze+vaWc8aZYciRvxhmhyyP0TSf Fx5i/21HwbbQOGJLhczghtvtyGJAlsTYvRpp+0AqdPzgsjBVROzbARZ5qgx2026dMlub TArir1DbUviFSysJwu5HANPdXBogPkA0ZUAF5zTOKrPGXo9tLNFEoeCG8VQ3YO8q5LMj G/H0qmzRixx5hp8uXhDFskCspzBv5cfBU+5AglKLR3sVFp2gP3rGCESR0X453einKieP 5v/A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=o+q+SwIxmtmY9Sx81EleZKhYAND9OH1kntiZdkYfvU0=; b=PE/4qXef/X/DmNRWfcU41Xb/JTEdwBIWt68NX3EheEvuDbRvV7tFfawB5KXM/HdB3z hq18o/DiglvjX1Kw4nk/bN1xzNepel7Bwk1pO+lpQ790xEP3Vv8KNOhgjmRb3W8J3dUl dt8lFpuNzPvZnw2+yyw+5D37hq5j7iY3MYd3THZvSuPVzfCgbaLtPzdhnSvYjKP9hWjq t00Vvkb9FIkqtey91rHuK84yMv0PZVGMPtis4v+xFNPjHTqMA/F/tgzPS5Gk5ckezhgS iR7KZKbwVsAr331niDRCRFmODzW695AJgnTIXYqL8c2pSaHaLoYE47nJABus/BYWt+Gd DZjQ== X-Gm-Message-State: AOAM530ykj444f46d7OxT1MQktOR78+clPfohzG/cPBwEt7v/N31V31e /uCFqXTcXMktdAt+LXwP7AUOOw== X-Received: by 2002:a17:90a:f68c:: with SMTP id cl12mr3570326pjb.116.1595326647639; Tue, 21 Jul 2020 03:17:27 -0700 (PDT) Received: from C02ZK051LVCK.local.net ([61.120.150.77]) by smtp.gmail.com with ESMTPSA id e195sm19694815pfh.218.2020.07.21.03.17.22 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Tue, 21 Jul 2020 03:17:26 -0700 (PDT) From: Xin He To: daniel@ffwll.ch, airlied@linux.ie, kraxel@redhat.com, sumit.semwal@linaro.org Cc: linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, virtualization@lists.linux-foundation.org, linux-media@vger.kernel.org, linaro-mm-sig@lists.linaro.org, Qi Liu , Xin He , Muchun Song Subject: [PATCH v3] drm/virtio: fix missing dma_fence_put() in virtio_gpu_execbuffer_ioctl() Date: Tue, 21 Jul 2020 18:16:47 +0800 Message-Id: <20200721101647.42653-1-hexin.op@bytedance.com> X-Mailer: git-send-email 2.21.1 (Apple Git-122.3) MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Qi Liu We should put the reference count of the fence after calling virtio_gpu_cmd_submit(). So add the missing dma_fence_put(). Fixes: 2cd7b6f08bc4 ("drm/virtio: add in/out fence support for explicit synchronization") Co-developed-by: Xin He Signed-off-by: Xin He Signed-off-by: Qi Liu Reviewed-by: Muchun Song --- changelog in v3: 1) Change the subject from "drm/virtio: fixed memory leak in virtio_gpu_execbuffer_ioctl()" to "drm/virtio: fix missing dma_fence_put() in virtio_gpu_execbuffer_ioctl()" 2) Rework the commit log changelog in v2: 1) Add a change description drivers/gpu/drm/virtio/virtgpu_ioctl.c | 1 + 1 file changed, 1 insertion(+) diff --git a/drivers/gpu/drm/virtio/virtgpu_ioctl.c b/drivers/gpu/drm/virtio/virtgpu_ioctl.c index 5df722072ba0..19c5bc01eb79 100644 --- a/drivers/gpu/drm/virtio/virtgpu_ioctl.c +++ b/drivers/gpu/drm/virtio/virtgpu_ioctl.c @@ -179,6 +179,7 @@ static int virtio_gpu_execbuffer_ioctl(struct drm_device *dev, void *data, virtio_gpu_cmd_submit(vgdev, buf, exbuf->size, vfpriv->ctx_id, buflist, out_fence); + dma_fence_put(&out_fence->f); virtio_gpu_notify(vgdev); return 0; -- 2.21.1 (Apple Git-122.3)