Received: by 2002:ab2:6c55:0:b0:1fd:c486:4f03 with SMTP id v21csp652038lqp; Wed, 12 Jun 2024 11:58:38 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVF2PwDSEWyLrHoEqtcWEvBhGS7Ou0Kuw6nv/JG7warD3+4MJCGCo3yAa/oQLzYXMlq81ZgCz0ZSQwgM2WfS3TjFf1Vntyak3MjdMhpbA== X-Google-Smtp-Source: AGHT+IGf9xzchN8SzN3479kyawhA8zgwXpjnYpZ/40Qrn5WrzyrZIeCCQv1Olx/KvetgBQb1igKn X-Received: by 2002:a05:6a00:4b09:b0:704:6ea0:2bba with SMTP id d2e1a72fcca58-705bcdee282mr3455205b3a.4.1718218718342; Wed, 12 Jun 2024 11:58:38 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1718218718; cv=pass; d=google.com; s=arc-20160816; b=UUlrNYXs+mO4tFAWYArMEU3Ij+fKThUJmIw0REpFpkNBDJUZzgz4vlDQCNDoKOEVOz zWFqgXVkcO6rFn3OTmwptDhf3iXbLbne5lkXJjXq+fgNM83wGmoWK3ub1a9pJeqKBF0x pXTeABSwtexU7P91+tK8+Wpv/Lkd8dajPNEM/p6WQZcjgF+J555DyfiYNfsnt5hESHLO ACDh89A1q3anhKb9r5FpmkOGC1xgr5qDPZjIDzy+GnxNxDIgfwrSbasONstR6l0fc18e Jv37Ds82sZJ6qaknfNr/ZaJELeqOezg7YRVw4Es6/j4jc6k8Ir3cMD/YPJL2vun6mFB3 8+oA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=in-reply-to:content-transfer-encoding:content-disposition :mime-version:list-unsubscribe:list-subscribe:list-id:precedence :references:message-id:subject:cc:to:from:date:dkim-signature; bh=DKTq1IAXO6VhpWqzlV3ufeBRENaUXhVejOXYDsI20Mw=; fh=KeuTmpjxsbRidgCG7QZDXu/1q40vCAR3iUavX7qsH08=; b=vW/tPO8ai1Q45grF/MiyX1+zapKcitM0/eN22DxviT6SIq2DuBp26ZxehmREjAWR76 qovl8UAjryn8Le+wpE0kosTXPzlx8rBgyVWJ5IoWV51RHHwN8XtE2EmeFE+rEpw7htXC yccF9vwU3oJ3vfw2q7WMVwBGn5B6fb1CiNat93/bltZOKDuhKdjo78+adnT3QLBVZI0M Fcrg678fqs1UNv88TUKCxDBWpzaSGAC/ZKu6H6YfYuMTTbtk9e8LykHw2EWqq9KvXz0C gqr2BE3kMcBvzanvaOPpfuAczpvc7cGj+KMKWpg+iLYa9xNwr1iD8GWQwlZ1TsWqJF05 PY4g==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=At6Tb0Q9; arc=pass (i=1 spf=pass spfdomain=intel.com dkim=pass dkdomain=intel.com dmarc=pass fromdomain=intel.com); spf=pass (google.com: domain of linux-kernel+bounces-212097-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-212097-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [147.75.48.161]) by mx.google.com with ESMTPS id d2e1a72fcca58-703fd5742dasi11974905b3a.361.2024.06.12.11.58.37 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 12 Jun 2024 11:58:38 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-212097-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) client-ip=147.75.48.161; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=At6Tb0Q9; arc=pass (i=1 spf=pass spfdomain=intel.com dkim=pass dkdomain=intel.com dmarc=pass fromdomain=intel.com); spf=pass (google.com: domain of linux-kernel+bounces-212097-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-212097-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com 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 sy.mirrors.kernel.org (Postfix) with ESMTPS id 5DF21B280B4 for ; Wed, 12 Jun 2024 18:39:37 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id E7CFD495E5; Wed, 12 Jun 2024 18:39:08 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b="At6Tb0Q9" Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.17]) (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 456A13209; Wed, 12 Jun 2024 18:39:06 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=198.175.65.17 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1718217548; cv=none; b=mYSAMfjAFzjcJs3Wroy6VcceyD6EkK7auu6TFE+81YKv50EKLOMmy11Ly/UBPCeTweNTMhGZcRPnX2OMn4ecXT2WtKCiWjMC3sGZodboA80mHlT9CeRSBrmYWdWd0sNFD5h+mnlj6wdwtTBAppSFepvvAeu3OT9FK6KEXjMZFSo= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1718217548; c=relaxed/simple; bh=txRDCxXysbYoGs6KmB8gDyxdmCk1ImxdaQ0ie+Vtfbo=; h=Date:From:To:Cc:Subject:Message-ID:References:MIME-Version: Content-Type:Content-Disposition:In-Reply-To; b=MpKbRjI5Ov4nym4UGZnHrP6yMl78QurGLzdg0TfgYQgs4XGqopXZl42FTd54XxRiY/C3VSv8M2TkIPPlCRzNHIReCNQTFroJ7ynB/81BrCiUyZSq1zjH6kok9OuTjwnVXc8V24fSTHbAcNe6p4JRpgNY9P2R3/dqm/JrOYq9Xj8= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com; spf=pass smtp.mailfrom=intel.com; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b=At6Tb0Q9; arc=none smtp.client-ip=198.175.65.17 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=intel.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1718217546; x=1749753546; h=date:from:to:cc:subject:message-id:references: mime-version:content-transfer-encoding:in-reply-to; bh=txRDCxXysbYoGs6KmB8gDyxdmCk1ImxdaQ0ie+Vtfbo=; b=At6Tb0Q9wNmbqf7NZVwL6/ixeRELoeju0nlXKjpggETydT/aMjcTgIA7 GkVf7Q1DdBJwxJ/BBXj6hLceyLIJbYYamSepZd9pjlLNpPmCCBkUaZyGJ RBmKSwPaxaghtdCizpA1KLcLvdK8PB1n4Oa/Z6d92SQ8DCp4VZaIl6jlG CTCTMzdvL3LHIRu46+wumgHI6MWKsDv7GPPnlAER4lVwDCbQi8rSKptug ZZWo+ObM2j0zCDf8SxBbR7jE5rGqu3Mih6X1DiAOkf+iagMQv3lFqVKkM z7Yt5COz0g5dnFefKB6dDyta6yz9IfgidbC0UomjR9MobLwZgckJ1FYDS w==; X-CSE-ConnectionGUID: UW0MLy+VTxGYTr+4lcSNhg== X-CSE-MsgGUID: KZYyuVTRR3iJyLkktaFKRA== X-IronPort-AV: E=McAfee;i="6700,10204,11101"; a="15127735" X-IronPort-AV: E=Sophos;i="6.08,234,1712646000"; d="scan'208";a="15127735" Received: from orviesa004.jf.intel.com ([10.64.159.144]) by orvoesa109.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 12 Jun 2024 11:39:06 -0700 X-CSE-ConnectionGUID: /XxSs6BUTA+G2qwONlbcdw== X-CSE-MsgGUID: aA7HezJKRcWLdGIR5kNPtA== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.08,234,1712646000"; d="scan'208";a="45002458" Received: from ls.sc.intel.com (HELO localhost) ([172.25.112.54]) by orviesa004-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 12 Jun 2024 11:39:05 -0700 Date: Wed, 12 Jun 2024 11:39:05 -0700 From: Isaku Yamahata To: "Edgecombe, Rick P" Cc: "pbonzini@redhat.com" , "seanjc@google.com" , "Huang, Kai" , "sagis@google.com" , "linux-kernel@vger.kernel.org" , "Aktas, Erdem" , "Zhao, Yan Y" , "dmatlack@google.com" , "kvm@vger.kernel.org" , "Yamahata, Isaku" , "isaku.yamahata@gmail.com" , isaku.yamahata@linux.intel.com Subject: Re: [PATCH v2 11/15] KVM: x86/tdp_mmu: Reflect tearing down mirror page tables Message-ID: <20240612183905.GJ386318@ls.amr.corp.intel.com> References: <20240530210714.364118-1-rick.p.edgecombe@intel.com> <20240530210714.364118-12-rick.p.edgecombe@intel.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: On Fri, Jun 07, 2024 at 09:46:27PM +0000, "Edgecombe, Rick P" wrote: > > /* Here we only care about zapping the external leaf PTEs. */ > > if (!is_last_spte(old_spte, level)) > > > > > +       kvm_pfn_t old_pfn = spte_to_pfn(old_spte); > > > +       int ret; > > > + > > > +       /* > > > +        * Allow only leaf page to be zapped. Reclaim non-leaf page tables > > > page > > > > This comment left me confused, so I'll try to rephrase and see if I > > can explain what happens. Correct me if I'm wrong. > > > > The only paths to handle_removed_pt() are: > > - kvm_tdp_mmu_zap_leafs() > > - kvm_tdp_mmu_zap_invalidated_roots() > > > > but because kvm_mmu_zap_all_fast() does not operate on mirror roots, > > the latter can only happen at VM destruction time. > > > > But it's not clear why it's worth mentioning it here, or even why it > > is special at all. Isn't that just what handle_removed_pt() does at > > the end? Why does it matter that it's only done at VM destruction > > time? > > > > In other words, it seems to me that this comment is TMI. And if I am > > wrong (which may well be), the extra information should explain the > > "why" in more detail, and it should be around the call to > > reflect_free_spt, not here. > > TDX of course has the limitation around the ordering of the zapping S-EPT. So I > read the comment to be referring to how the implementation avoids zapping any > non-leaf PTEs during TD runtime. > > But I'm going to have to circle back here after investigating a bit more. Isaku, > any comments on this comment and conditional? It's for large page page merge/split. At this point, it seems only confusing. We need only leaf zapping. Maybe reflect_removed_leaf_spte() or something. Later we can come back when large page support. -- Isaku Yamahata