Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp953798yba; Wed, 24 Apr 2019 12:21:55 -0700 (PDT) X-Google-Smtp-Source: APXvYqwvn/wzUqbGb0lAaxsmr+UAs9ucm6P8DB0/SgK34OoBu6XeB8em/sveTXoOmxHx/SmfA2D+ X-Received: by 2002:a63:d816:: with SMTP id b22mr31905499pgh.349.1556133715717; Wed, 24 Apr 2019 12:21:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556133715; cv=none; d=google.com; s=arc-20160816; b=u1iHeGp3E+P0Kln3dLKafssDQBKiaaaHLo2e+L4GZ+ThqgJEuPJ/b1hIHNu8Tqv1/z TOg4cN1rAxItFJHUPcJJSB3wHkK/CST3mRSCFz/F5fXLsOqpLvSSYiTXOXwJofwrCMoE 0TzQ3LFaTZOZIhBSZ73ztFs8S5Cwd0m7wCDh03SYcto6+0sCth/zvbJYJezOlfa8ZPhJ Z4OxbgPMsi1FQnfCtXYEDbyX6T+WHyMZqlz9+/mzRDVYwA8qvdGQg+UtFKytYGnF5dpr Q2p1KWkHsfkvX5FP+ABuKTa+H08zTAF+lRephfohFTcN2KtMqQ427JzYkg/LVq8Vp53S V4Dw== 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=6F+WjIKFzPJ1ZQ2J5eIhLU0f1Gyiu+6q0x9WIwmn1KQ=; b=Nm0HO/n6u40zWHkK8zHyAw20eI9kS+A/JjRjs2EA7RDP4UnGCgBK/uh+UHBml/0BiE 9Mn/xkAwtG9trt4VsS7+8eSmAYm4UtYXB6CGn9kj+5xY1F5CJ4x93p7jVaIcHi5xmCjn Bxcm/pckOZXy+Fx8ohra0PE7eAo/aXCweXEz0JAssxmwxCbFHdR1B/4SrtKjLOn/gLjg /e928IsWlBf/vi8KtxdyH0LMC6GYBH0PnlYwVF6OgDnX6H8/Nl569A9sz2aC1K2UZy4Q 6xpu+3TWtRmgwWE/PdZsVYvmT9/Dtkc0hqbv2utnNP8iSfCT8Qfeq4d/5KSP0/O4HrYw MfgA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="iASq/sOv"; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f17si19412880pgd.243.2019.04.24.12.21.39; Wed, 24 Apr 2019 12:21:55 -0700 (PDT) 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=@kernel.org header.s=default header.b="iASq/sOv"; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731415AbfDXOi1 (ORCPT + 99 others); Wed, 24 Apr 2019 10:38:27 -0400 Received: from mail.kernel.org ([198.145.29.99]:39152 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731341AbfDXOfV (ORCPT ); Wed, 24 Apr 2019 10:35:21 -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 27C712089F; Wed, 24 Apr 2019 14:35:18 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1556116520; bh=o0GTP6ujbkkuVyeHE7SrZp6FfvHjpIxR0turRfY0PA4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=iASq/sOvnOkX+CsDHVGFd1w6/TiE4PdCvLMxwUsLI7Q5WAMONdbcdZFiGlizeRPMS qo9173w5oRLzOQNgkKhrcYvcyWO+UbaRaaRcfdbYnx8Fh2zxILrCUW18jDP0MjhOxD kFcmtDtYj9x/ZfER8BaVl/EUHK+oMvs0jpcanzKY= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Alex Williamson , Sasha Levin , kvm@vger.kernel.org Subject: [PATCH AUTOSEL 5.0 40/66] vfio/type1: Limit DMA mappings per container Date: Wed, 24 Apr 2019 10:33:14 -0400 Message-Id: <20190424143341.27665-40-sashal@kernel.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20190424143341.27665-1-sashal@kernel.org> References: <20190424143341.27665-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: Alex Williamson [ Upstream commit 492855939bdb59c6f947b0b5b44af9ad82b7e38c ] Memory backed DMA mappings are accounted against a user's locked memory limit, including multiple mappings of the same memory. This accounting bounds the number of such mappings that a user can create. However, DMA mappings that are not backed by memory, such as DMA mappings of device MMIO via mmaps, do not make use of page pinning and therefore do not count against the user's locked memory limit. These mappings still consume memory, but the memory is not well associated to the process for the purpose of oom killing a task. To add bounding on this use case, we introduce a limit to the total number of concurrent DMA mappings that a user is allowed to create. This limit is exposed as a tunable module option where the default value of 64K is expected to be well in excess of any reasonable use case (a large virtual machine configuration would typically only make use of tens of concurrent mappings). This fixes CVE-2019-3882. Reviewed-by: Eric Auger Tested-by: Eric Auger Reviewed-by: Peter Xu Reviewed-by: Cornelia Huck Signed-off-by: Alex Williamson Signed-off-by: Sasha Levin (Microsoft) --- drivers/vfio/vfio_iommu_type1.c | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/drivers/vfio/vfio_iommu_type1.c b/drivers/vfio/vfio_iommu_type1.c index 73652e21efec..d0f731c9920a 100644 --- a/drivers/vfio/vfio_iommu_type1.c +++ b/drivers/vfio/vfio_iommu_type1.c @@ -58,12 +58,18 @@ module_param_named(disable_hugepages, MODULE_PARM_DESC(disable_hugepages, "Disable VFIO IOMMU support for IOMMU hugepages."); +static unsigned int dma_entry_limit __read_mostly = U16_MAX; +module_param_named(dma_entry_limit, dma_entry_limit, uint, 0644); +MODULE_PARM_DESC(dma_entry_limit, + "Maximum number of user DMA mappings per container (65535)."); + struct vfio_iommu { struct list_head domain_list; struct vfio_domain *external_domain; /* domain for external user */ struct mutex lock; struct rb_root dma_list; struct blocking_notifier_head notifier; + unsigned int dma_avail; bool v2; bool nesting; }; @@ -836,6 +842,7 @@ static void vfio_remove_dma(struct vfio_iommu *iommu, struct vfio_dma *dma) vfio_unlink_dma(iommu, dma); put_task_struct(dma->task); kfree(dma); + iommu->dma_avail++; } static unsigned long vfio_pgsize_bitmap(struct vfio_iommu *iommu) @@ -1081,12 +1088,18 @@ static int vfio_dma_do_map(struct vfio_iommu *iommu, goto out_unlock; } + if (!iommu->dma_avail) { + ret = -ENOSPC; + goto out_unlock; + } + dma = kzalloc(sizeof(*dma), GFP_KERNEL); if (!dma) { ret = -ENOMEM; goto out_unlock; } + iommu->dma_avail--; dma->iova = iova; dma->vaddr = vaddr; dma->prot = prot; @@ -1583,6 +1596,7 @@ static void *vfio_iommu_type1_open(unsigned long arg) INIT_LIST_HEAD(&iommu->domain_list); iommu->dma_list = RB_ROOT; + iommu->dma_avail = dma_entry_limit; mutex_init(&iommu->lock); BLOCKING_INIT_NOTIFIER_HEAD(&iommu->notifier); -- 2.19.1