Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp930317ybt; Wed, 17 Jun 2020 18:12:16 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzGVWiXzHix0q0yBj0MSjgvVZU3yRFrDVRAYql+uVrGgtaEC9YGeANx8cum/nusLGWAsdkn X-Received: by 2002:a05:6402:1714:: with SMTP id y20mr1780556edu.81.1592442736382; Wed, 17 Jun 2020 18:12:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592442736; cv=none; d=google.com; s=arc-20160816; b=QXRuOc33oc71RNggYFK+DcJmQ0OcM0fxkzF0cEltr5SofjCnzF0aHOe1u2eHlfDmUo Eqg1ubeRXlUTs6OU+00MuacuyunPXTeG5Uh4u1k31i9o6AzBmeovKJZ8j0XwZKndqyGx AgdCDVXSqTp5z0kVqqhaB70uwSXQ4192D6TPlkrIDEE91EtG2YQ8KHNrXkTVt1TO3+ZD ePPp7GfDifNwAldfcM4CZsCqo7QBzIi1y/F+QsWm2iS+4mU5nv1qIXZlrGS8+rBSNHsz t2sioOnR+Fbt1AB1KIa8NHQed17kz0ouIeeELcXVr6GN9hcFZiA1FmXYSvc614e+lNcG 1dgw== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=PSSJUeBKTsYaAiZ3in45JMIhPmg6FCjgz6RAbJvdnBY=; b=l/T8e3nOMeBILNwxSbq+HoWLAndmnr/ZngzdfZaL4WYLJ6Fn1nNPS5a7P06zHEP2I0 EW8KKGC4Ez8UJmh1Ya/nXaO9tTAw16PuR3TfDO1tLXTA5pzNWmZ4V0m/7x4jjHuSqGEU p6vmQD5Zsfu6gnHmsCHI8LFrt0x5qM4OdL8xSWjNYWAoS54GWiWnMBQLUqdXHkfS6LYr MsWi5br81/J1k2oQu0TbSRiFxyHVp0YoFWLnxC+CM3ohN1PrOmVVvRnKJlKAdg+YQoz3 34058MGSCPZiU+B91USyf+2PyAS4qopagCfdYVGP+lQgvVs7MjKnIwMpa1k3Hzf70zvQ RMsw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=P4eDBB8y; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m11si916982edp.600.2020.06.17.18.11.54; Wed, 17 Jun 2020 18:12:16 -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=@kernel.org header.s=default header.b=P4eDBB8y; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728171AbgFRBJ1 (ORCPT + 99 others); Wed, 17 Jun 2020 21:09:27 -0400 Received: from mail.kernel.org ([198.145.29.99]:35760 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728159AbgFRBJ0 (ORCPT ); Wed, 17 Jun 2020 21:09:26 -0400 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 0ACAC21D80; Thu, 18 Jun 2020 01:09:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1592442565; bh=XQZnQPb68FUNq+IfUPGgfzbfOipfqxw7R9zQj8TZNcA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=P4eDBB8yqcWqlgayAeliCEun4T1FPLXuTD6HrnNQLgmki9uHxDYAxDp/hdRba6g5F 9F7wLw2D1Caxox/eMiwVdG/3pC3femqW1LQOS3BqqXGpFk1vTn49h2h8HIhZdkyFNJ Tuc9cC1el/Qhmyp38QphEXjUccsXkF76SpoOBLpQ= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Qian Cai , Alex Williamson , Sasha Levin , kvm@vger.kernel.org Subject: [PATCH AUTOSEL 5.7 060/388] vfio/pci: fix memory leaks in alloc_perm_bits() Date: Wed, 17 Jun 2020 21:02:37 -0400 Message-Id: <20200618010805.600873-60-sashal@kernel.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200618010805.600873-1-sashal@kernel.org> References: <20200618010805.600873-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Qian Cai [ Upstream commit 3e63b94b6274324ff2e7d8615df31586de827c4e ] vfio_pci_disable() calls vfio_config_free() but forgets to call free_perm_bits() resulting in memory leaks, unreferenced object 0xc000000c4db2dee0 (size 16): comm "qemu-kvm", pid 4305, jiffies 4295020272 (age 3463.780s) hex dump (first 16 bytes): 00 00 ff 00 ff ff ff ff ff ff ff ff ff ff 00 00 ................ backtrace: [<00000000a6a4552d>] alloc_perm_bits+0x58/0xe0 [vfio_pci] [<00000000ac990549>] vfio_config_init+0xdf0/0x11b0 [vfio_pci] init_pci_cap_msi_perm at drivers/vfio/pci/vfio_pci_config.c:1125 (inlined by) vfio_msi_cap_len at drivers/vfio/pci/vfio_pci_config.c:1180 (inlined by) vfio_cap_len at drivers/vfio/pci/vfio_pci_config.c:1241 (inlined by) vfio_cap_init at drivers/vfio/pci/vfio_pci_config.c:1468 (inlined by) vfio_config_init at drivers/vfio/pci/vfio_pci_config.c:1707 [<000000006db873a1>] vfio_pci_open+0x234/0x700 [vfio_pci] [<00000000630e1906>] vfio_group_fops_unl_ioctl+0x8e0/0xb84 [vfio] [<000000009e34c54f>] ksys_ioctl+0xd8/0x130 [<000000006577923d>] sys_ioctl+0x28/0x40 [<000000006d7b1cf2>] system_call_exception+0x114/0x1e0 [<0000000008ea7dd5>] system_call_common+0xf0/0x278 unreferenced object 0xc000000c4db2e330 (size 16): comm "qemu-kvm", pid 4305, jiffies 4295020272 (age 3463.780s) hex dump (first 16 bytes): 00 ff ff 00 ff ff ff ff ff ff ff ff ff ff 00 00 ................ backtrace: [<000000004c71914f>] alloc_perm_bits+0x44/0xe0 [vfio_pci] [<00000000ac990549>] vfio_config_init+0xdf0/0x11b0 [vfio_pci] [<000000006db873a1>] vfio_pci_open+0x234/0x700 [vfio_pci] [<00000000630e1906>] vfio_group_fops_unl_ioctl+0x8e0/0xb84 [vfio] [<000000009e34c54f>] ksys_ioctl+0xd8/0x130 [<000000006577923d>] sys_ioctl+0x28/0x40 [<000000006d7b1cf2>] system_call_exception+0x114/0x1e0 [<0000000008ea7dd5>] system_call_common+0xf0/0x278 Fixes: 89e1f7d4c66d ("vfio: Add PCI device driver") Signed-off-by: Qian Cai [aw: rolled in follow-up patch] Signed-off-by: Alex Williamson Signed-off-by: Sasha Levin --- drivers/vfio/pci/vfio_pci_config.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/drivers/vfio/pci/vfio_pci_config.c b/drivers/vfio/pci/vfio_pci_config.c index 90c0b80f8acf..43b95f9cdaf7 100644 --- a/drivers/vfio/pci/vfio_pci_config.c +++ b/drivers/vfio/pci/vfio_pci_config.c @@ -1728,8 +1728,11 @@ void vfio_config_free(struct vfio_pci_device *vdev) vdev->vconfig = NULL; kfree(vdev->pci_config_map); vdev->pci_config_map = NULL; - kfree(vdev->msi_perm); - vdev->msi_perm = NULL; + if (vdev->msi_perm) { + free_perm_bits(vdev->msi_perm); + kfree(vdev->msi_perm); + vdev->msi_perm = NULL; + } } /* -- 2.25.1