Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp5225092ybl; Tue, 27 Aug 2019 01:05:59 -0700 (PDT) X-Google-Smtp-Source: APXvYqxVy31rCD/6QsJXTgRuceo9GdbB2tZXeeu5ifVmLpyanmSLrgV9DvIWRYprxQ1M/apBen3i X-Received: by 2002:a63:188:: with SMTP id 130mr19883917pgb.231.1566893158944; Tue, 27 Aug 2019 01:05:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566893158; cv=none; d=google.com; s=arc-20160816; b=waGM0wUMoUdzCOj59fn8pO9wTw2dnqwOx3WtZ9r6XNHC/ZySUZ4XE7xqKB/BQrdS+B oWlPK1TzzdfZGsjoxAJ1pdDrPXo5sk2/9XJlxI1GJ1kMVtUCU43fPJUxoO/+k09TaRjD 9+zGckW1pHSYFXAXLqzDtoTM9wkXzGF+WiLKk3GSxPVx/8SpovzhaTMJ8FuIxrOMQgja knGZXr2QypsUGV/18Cu9GDB9ukspL0600bIBGi+fohqh9MRZERIN/J7lA//XPDg1J68p RxsNUF7lezazeKGxrxCD5cAC8/vylrSH13X8L6WrXQ8+9KRlD5Ao4F2Lru/g2dQB1vnW QqvA== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=hr6zOLXqc9dQ4BJU6vpDt5HKslf2XEqN1MLv22/SHus=; b=LkkO/i9XPYZOoU1/b6UPKwT4lAoSJX27AHd8xr5vSFNots91a5+T1A2VN5rY5ukich AAVLlkDYL/D7lFpbpsM0PFffqcGSlzl8adRpX1oDgBoCulL1pXyTNslDQlmELDFiB9qX kn3oNn+Ig7Z9qIVGYBtkR71lgCnOK8ke/ZpsH+7ASDKfa7K4rOZaL3bl27FumxBR1jwu L3/CMdtn/kehFTRlnDwBHt8WYMpPIjDnb67Cp5sRnLCqCVwfXZyAQ7sMxeUUsLCL0xeF tdpxNmhP8fZvE/wZg3Abq/uoOlaRpecDPwxDHaQA0e3nYdodwfOQrnURA818dDpnzJjl VxRA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=pReHA8dU; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f23si11191304pga.449.2019.08.27.01.05.43; Tue, 27 Aug 2019 01:05:58 -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=pReHA8dU; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732100AbfH0IEi (ORCPT + 99 others); Tue, 27 Aug 2019 04:04:38 -0400 Received: from mail.kernel.org ([198.145.29.99]:34136 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732596AbfH0IEf (ORCPT ); Tue, 27 Aug 2019 04:04:35 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id A85762173E; Tue, 27 Aug 2019 08:04:34 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1566893075; bh=OQkgxgGTLnCbPxSscnSx2iY9DtJqNtDtwWWvXJBBKe0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=pReHA8dUA8MrKB3Ubv07v6VV1m9rqaaI55hSp26OAQQZycBqIGyHthmn4H1yOmu2c 1nHhSSMYnYC5t3h4loULHVL9sNHyP7gf+5zfd9f0l9xen9nIHgtk1N0vM5vkVkQCfK UbpiHuXu/ow1DuY0GTCXa0KAF0Ca4n3Nz3Kdsqh0= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Alex Willamson , Sean Christopherson , Paolo Bonzini Subject: [PATCH 5.2 113/162] Revert "KVM: x86/mmu: Zap only the relevant pages when removing a memslot" Date: Tue, 27 Aug 2019 09:50:41 +0200 Message-Id: <20190827072742.324569389@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20190827072738.093683223@linuxfoundation.org> References: <20190827072738.093683223@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Paolo Bonzini commit d012a06ab1d23178fc6856d8d2161fbcc4dd8ebd upstream. This reverts commit 4e103134b862314dc2f2f18f2fb0ab972adc3f5f. Alex Williamson reported regressions with device assignment with this patch. Even though the bug is probably elsewhere and still latent, this is needed to fix the regression. Fixes: 4e103134b862 ("KVM: x86/mmu: Zap only the relevant pages when removing a memslot", 2019-02-05) Reported-by: Alex Willamson Cc: stable@vger.kernel.org Cc: Sean Christopherson Signed-off-by: Paolo Bonzini Signed-off-by: Greg Kroah-Hartman --- arch/x86/kvm/mmu.c | 33 +-------------------------------- 1 file changed, 1 insertion(+), 32 deletions(-) --- a/arch/x86/kvm/mmu.c +++ b/arch/x86/kvm/mmu.c @@ -5649,38 +5649,7 @@ static void kvm_mmu_invalidate_zap_pages struct kvm_memory_slot *slot, struct kvm_page_track_notifier_node *node) { - struct kvm_mmu_page *sp; - LIST_HEAD(invalid_list); - unsigned long i; - bool flush; - gfn_t gfn; - - spin_lock(&kvm->mmu_lock); - - if (list_empty(&kvm->arch.active_mmu_pages)) - goto out_unlock; - - flush = slot_handle_all_level(kvm, slot, kvm_zap_rmapp, false); - - for (i = 0; i < slot->npages; i++) { - gfn = slot->base_gfn + i; - - for_each_valid_sp(kvm, sp, gfn) { - if (sp->gfn != gfn) - continue; - - kvm_mmu_prepare_zap_page(kvm, sp, &invalid_list); - } - if (need_resched() || spin_needbreak(&kvm->mmu_lock)) { - kvm_mmu_remote_flush_or_zap(kvm, &invalid_list, flush); - flush = false; - cond_resched_lock(&kvm->mmu_lock); - } - } - kvm_mmu_remote_flush_or_zap(kvm, &invalid_list, flush); - -out_unlock: - spin_unlock(&kvm->mmu_lock); + kvm_mmu_zap_all(kvm); } void kvm_mmu_init_vm(struct kvm *kvm)