From mboxrd@z Thu Jan 1 00:00:00 1970 From: Christoffer Dall Subject: Re: [PATCH] KVM: arm/arm64: Handle hva aging while destroying the vm Date: Mon, 3 Jul 2017 10:03:13 +0200 Message-ID: <20170703080313.GB4066@cbox> References: <1498231319-199734-1-git-send-email-agraf@suse.de> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Cc: kvmarm@lists.cs.columbia.edu, kvm@vger.kernel.org, linux-kernel@vger.kernel.org To: Alexander Graf Return-path: Content-Disposition: inline In-Reply-To: <1498231319-199734-1-git-send-email-agraf@suse.de> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: kvmarm-bounces@lists.cs.columbia.edu Sender: kvmarm-bounces@lists.cs.columbia.edu List-Id: kvm.vger.kernel.org Hi Alex, On Fri, Jun 23, 2017 at 05:21:59PM +0200, Alexander Graf wrote: > If we want to age an HVA while the VM is getting destroyed, we have a > tiny race window during which we may end up dereferencing an invalid > kvm->arch.pgd value. > > CPU0 CPU1 > > kvm_age_hva() > kvm_mmu_notifier_release() > kvm_arch_flush_shadow_all() > kvm_free_stage2_pgd() > > stage2_get_pmd() > > set kvm->arch.pgd = 0 > > > stage2_get_pud() > arch.pgd> > I don't think this sequence, can happen, but I think kvm_age_hva() can be called with the mmu_lock held and kvm->pgd already being NULL. Is that possible for the mmu notifiers to be calling clear(_flush)_young while also calling notifier_release? If so, the patch below looks good to me. Thanks, -Christoffer > > This patch adds a check for that case. > > Signed-off-by: Alexander Graf > --- > virt/kvm/arm/mmu.c | 4 ++++ > 1 file changed, 4 insertions(+) > > diff --git a/virt/kvm/arm/mmu.c b/virt/kvm/arm/mmu.c > index f2d5b6c..227931f 100644 > --- a/virt/kvm/arm/mmu.c > +++ b/virt/kvm/arm/mmu.c > @@ -861,6 +861,10 @@ static pud_t *stage2_get_pud(struct kvm *kvm, struct kvm_mmu_memory_cache *cache > pgd_t *pgd; > pud_t *pud; > > + /* Do we clash with kvm_free_stage2_pgd()? */ > + if (!kvm->arch.pgd) > + return NULL; > + > pgd = kvm->arch.pgd + stage2_pgd_index(addr); > if (WARN_ON(stage2_pgd_none(*pgd))) { > if (!cache) > -- > 1.8.5.6 > > _______________________________________________ > kvmarm mailing list > kvmarm@lists.cs.columbia.edu > https://lists.cs.columbia.edu/mailman/listinfo/kvmarm