Received: by 2002:ab2:6203:0:b0:1f5:f2ab:c469 with SMTP id o3csp2626154lqt; Mon, 22 Apr 2024 17:16:51 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVt2Zzef/jYAsX4dJ92ScmdZMw5PQ4GFCBRmnlawWUj3s52OB5W0A2iQQd3CJc+VEtLpEF48KRpPDHfP7xQlV6nw3rJ4Dsjt+vK1NaWuQ== X-Google-Smtp-Source: AGHT+IGBpu00YDwgryLEt4Ppg9bNbYK2HerwzRueBC6+K69Um2BX2vbGZTsXHBBjjbqZ3+OI5w4a X-Received: by 2002:a17:902:784f:b0:1e3:d8ae:df39 with SMTP id e15-20020a170902784f00b001e3d8aedf39mr9248909pln.50.1713831411098; Mon, 22 Apr 2024 17:16:51 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1713831411; cv=pass; d=google.com; s=arc-20160816; b=TY5kBmB0QizSYJYJ24POzwfLUErhxJuIFGDWepmVXjQ4Yqsl6jWe8Ry0l8McRjKLfC Mv7RhsK3YaCs6RzNu0EKTi6iC5hISHBvhVpuE1cLCkXRRuj1nxYnL44boc92aTRrORKF 6wdWMsdrGpC16YC66PlwoiIz1CVxkcIpJR9UeRv/hR+zb70EXxwQRVPoqCBASllYRneO USsZnvC7+R08eBL688EHIzsk/zeJfBoQwWJn/UsuD1j5a4djo0mwfq3h76nbndd4wa5L kQioI9rXTCEVfvDmxzn175FiRTYV7trcruawRVZWtMD87YXcfjNHxmszvxt7kgAgFQ3V YvzQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=uRZ+AC5fvbr8uV0cEFdWHYyC13i4v+hmSGNPBJmzt4c=; fh=GUrRWoeR1U9sFkVrGb0bjkRjxR8O3pa0ilewqsVtc/M=; b=SlmxtIXbVrpZWhqxIC2BNaqYyyHrt+jH9e9wsvkJOcHT/p5y0syxk6NHpDyXc2iS9G 5kgkGxrsvILKVqURSO5munczQMFbw6mG6YUfK41akJNqJiPdzpRTwhK1wzTXrBZ4g1UW Mpp6RotaeG5nUGNpvGuNNyHB6H6R8Juu65GiDyQfEkoQij7SWkiuqzTIIS7PCHZvZg9M uoAdwEqeTAK9iIOl8Rv8jEng3J4iAb7qzZ8WlFAE/6AFqJeWpMpYmuNMjDTpo4SbnpJX nhmmEvn3jq0XjJU7L2bo+p7Qx1iFevXg6ECqtIZdGk/LNKWc+dFvdZp4Jh646YUBqm3n JREw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=uNGLl0FB; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-154306-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-154306-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id e13-20020a170902ef4d00b001dd693cc79csi8696302plx.620.2024.04.22.17.16.50 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 22 Apr 2024 17:16:51 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-154306-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=uNGLl0FB; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-154306-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-154306-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id A6594285A71 for ; Tue, 23 Apr 2024 00:14:49 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 814E318131D; Mon, 22 Apr 2024 23:57:59 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="uNGLl0FB" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id A418D15884C; Mon, 22 Apr 2024 23:57:58 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713830278; cv=none; b=k6rkK9Jv/xmIngBpZZr6dbyLmD6Cuh0kiPrG1ERa1tsrbXyCW1SdqBHVACrroCya5H12vpUqryIpnH6sXul03GBN26LBrJwUhT7hupS68DP7K0oWdgqeB6BXONs0umXn4NLK1Tr/oMZYryLX7BaRAmvQzEJccRXRCYLGIeyVKV0= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713830278; c=relaxed/simple; bh=18m4ZYSaNZlIgA8xL5VdKckI3qxeX5rvbkwFzIq1d0Q=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=na7H0FA2vE5yugGoWtat/ShNv9TYmaIbmOV3mLZnNDecESn+s5riG2VCmBtnSltqV92b+cLt/TKabr7vubi/M5fSEJc2e/GwJ17vYrLt0rilc+DtKlDp2L8FOIl1K5i8BwhCfht/wLW/TjeUck/3DJz+TF2h6lCbmOlDIIg6xGs= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=uNGLl0FB; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 48313C2BD11; Mon, 22 Apr 2024 23:57:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1713830278; bh=18m4ZYSaNZlIgA8xL5VdKckI3qxeX5rvbkwFzIq1d0Q=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=uNGLl0FBCIB4OE7pEZg61inW6VNPcFPUnWsjjFwRBSJNFRxoBC8RkwzST9LGtAtdA fQGwwEQGct+FTs9/GdUdPsessju3Rrbwn77P0cyZn+f7RfEobskToPKuAibLscdAG/ jY1XtfirGPukDivEU42FoHonH0QpmsGNR61R1MUevpe5XulRiwd5S9auCQhzAFtObF HkMuFlGVvjAYqtMfqSEBQ1aVh5E63hGLhXlvGAqT6UDzy9ZKV9ziRFIuh3g3gnJReP 7PDSpYRoDpgAmTwvw/cJE7L5HhTQYXRnUGRdymSlqLmusQ8LqEmo+1yzsaeIbV8rp/ EyOKGb9eWCU/Q== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Rick Edgecombe , Michael Kelley , Kuppuswamy Sathyanarayanan , "Kirill A . Shutemov" , Wei Liu , Sasha Levin , kys@microsoft.com, haiyangz@microsoft.com, decui@microsoft.com, linux-hyperv@vger.kernel.org Subject: [PATCH AUTOSEL 6.1 16/19] Drivers: hv: vmbus: Track decrypted status in vmbus_gpadl Date: Mon, 22 Apr 2024 19:18:30 -0400 Message-ID: <20240422231845.1607921-16-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240422231845.1607921-1-sashal@kernel.org> References: <20240422231845.1607921-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore X-stable-base: Linux 6.1.87 Content-Transfer-Encoding: 8bit From: Rick Edgecombe [ Upstream commit 211f514ebf1ef5de37b1cf6df9d28a56cfd242ca ] In CoCo VMs it is possible for the untrusted host to cause set_memory_encrypted() or set_memory_decrypted() to fail such that an error is returned and the resulting memory is shared. Callers need to take care to handle these errors to avoid returning decrypted (shared) memory to the page allocator, which could lead to functional or security issues. In order to make sure callers of vmbus_establish_gpadl() and vmbus_teardown_gpadl() don't return decrypted/shared pages to allocators, add a field in struct vmbus_gpadl to keep track of the decryption status of the buffers. This will allow the callers to know if they should free or leak the pages. Signed-off-by: Rick Edgecombe Signed-off-by: Michael Kelley Reviewed-by: Kuppuswamy Sathyanarayanan Acked-by: Kirill A. Shutemov Link: https://lore.kernel.org/r/20240311161558.1310-3-mhklinux@outlook.com Signed-off-by: Wei Liu Message-ID: <20240311161558.1310-3-mhklinux@outlook.com> Signed-off-by: Sasha Levin --- drivers/hv/channel.c | 25 +++++++++++++++++++++---- include/linux/hyperv.h | 1 + 2 files changed, 22 insertions(+), 4 deletions(-) diff --git a/drivers/hv/channel.c b/drivers/hv/channel.c index 56f7e06c673e4..bb5abdcda18f8 100644 --- a/drivers/hv/channel.c +++ b/drivers/hv/channel.c @@ -472,9 +472,18 @@ static int __vmbus_establish_gpadl(struct vmbus_channel *channel, (atomic_inc_return(&vmbus_connection.next_gpadl_handle) - 1); ret = create_gpadl_header(type, kbuffer, size, send_offset, &msginfo); - if (ret) + if (ret) { + gpadl->decrypted = false; return ret; + } + /* + * Set the "decrypted" flag to true for the set_memory_decrypted() + * success case. In the failure case, the encryption state of the + * memory is unknown. Leave "decrypted" as true to ensure the + * memory will be leaked instead of going back on the free list. + */ + gpadl->decrypted = true; ret = set_memory_decrypted((unsigned long)kbuffer, PFN_UP(size)); if (ret) { @@ -563,9 +572,15 @@ static int __vmbus_establish_gpadl(struct vmbus_channel *channel, kfree(msginfo); - if (ret) - set_memory_encrypted((unsigned long)kbuffer, - PFN_UP(size)); + if (ret) { + /* + * If set_memory_encrypted() fails, the decrypted flag is + * left as true so the memory is leaked instead of being + * put back on the free list. + */ + if (!set_memory_encrypted((unsigned long)kbuffer, PFN_UP(size))) + gpadl->decrypted = false; + } return ret; } @@ -886,6 +901,8 @@ int vmbus_teardown_gpadl(struct vmbus_channel *channel, struct vmbus_gpadl *gpad if (ret) pr_warn("Fail to set mem host visibility in GPADL teardown %d.\n", ret); + gpadl->decrypted = ret; + return ret; } EXPORT_SYMBOL_GPL(vmbus_teardown_gpadl); diff --git a/include/linux/hyperv.h b/include/linux/hyperv.h index 4fbd5d8417111..811d59cf891ba 100644 --- a/include/linux/hyperv.h +++ b/include/linux/hyperv.h @@ -832,6 +832,7 @@ struct vmbus_gpadl { u32 gpadl_handle; u32 size; void *buffer; + bool decrypted; }; struct vmbus_channel { -- 2.43.0