Received: by 2002:a05:6a10:c604:0:0:0:0 with SMTP id y4csp3779016pxt; Tue, 10 Aug 2021 11:07:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwOUODgu2dV07bdVFogktVAzp8mYxLpGZVL5dhnZ/9yCosmOR8Xi2S7bSFkhDxTdMip25WG X-Received: by 2002:a17:906:2809:: with SMTP id r9mr28730352ejc.463.1628618835047; Tue, 10 Aug 2021 11:07:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628618835; cv=none; d=google.com; s=arc-20160816; b=tyEsP15EFQcv3Xve4cscEFhmcqobm9mBgdZvnJ4verzy7YVSbfootwBXpSxwOcPEqg jVsrLett6AXt7Ow4pa08kQdGHszvli3/oeUDTmdpMfbu7ewCdcgLvMA02C8+ql+wCMW/ G7aQij3YOC18V7BRl6vs3UYpC8MENcjHuDz/LFwF/Mc7q5AhfAaFj1VY/wnDQN7n5zKC ZRKLqslAW5XLz+gGUjtfqk1rdOZuKrPppJh+h/OPgtLqekAYjWJEhTsNkrUzQ8W3iZ8L wW44y3q83R9uOCdeZOkOnKa807EuXZEjYHRXvKahsvyolcY10LOTYl23NxyIadHJXli/ uAkQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=4MRuZQ8ESyU4k+rZiNI3TCdZPU+EBq2lvOGTCYISnK4=; b=f/0iCDjOzg5iNgnf1weIXdtkYQEGI9nFBX+Cik/izh8RbqOlmvQTlfaJDv5KewxMvb o9BM+/6/j5Mguwy6Z241LVetS1LJD3KK2WAkZvJ+1wZYybqPFQLoKHD9LZNc4S0feARt P+QtLixCDFfuPWc320vOwN81+cpTZMEE4AtYoWozjd0YNaqW9yUS1jbVZ0siOMMS2mhA lovY4IVIM2E0ezha7Rwv5sR/oLx7SwI0l3+U3L/zaFDMvIvQ6otzZXOpBRuaKKrjWEzK p1m7kHw1USgO8TSc3byhGoA7xkWPs2aVMN6H1PsesPs3QbJ7771mzw9Q6wYyqYrBoTLE mO6Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=CA24f6WR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id cw10si22215119ejc.360.2021.08.10.11.06.50; Tue, 10 Aug 2021 11:07:15 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=CA24f6WR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233817AbhHJSF2 (ORCPT + 99 others); Tue, 10 Aug 2021 14:05:28 -0400 Received: from mail.kernel.org ([198.145.29.99]:37564 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237996AbhHJSBt (ORCPT ); Tue, 10 Aug 2021 14:01:49 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id AFBA3613CE; Tue, 10 Aug 2021 17:47:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1628617637; bh=UVtXDmM+NkdpBbDZ4dLDyZuZij6eEh5uNTNwOnJFo8E=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=CA24f6WRorLplb+NRo15H8mHlBPInjN0kUWQ9b5cBlQhpneZuU09yZJVmDuvL0RVY aDSTO7S2nqt9Kz5R4drNX1FZrE9NkvsPlSp1DOIGJk0etmY+pLabY0YSZC+wZ4ixm6 35s+zrKzFKz+UXG/5d9EwL9a6uBNut9tSaSQmOfs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Stas Sergeev , Sean Christopherson , Paolo Bonzini Subject: [PATCH 5.13 147/175] KVM: x86: accept userspace interrupt only if no event is injected Date: Tue, 10 Aug 2021 19:30:55 +0200 Message-Id: <20210810173005.806546441@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210810173000.928681411@linuxfoundation.org> References: <20210810173000.928681411@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Paolo Bonzini commit fa7a549d321a4189677b0cea86e58d9db7977f7b upstream. Once an exception has been injected, any side effects related to the exception (such as setting CR2 or DR6) have been taked place. Therefore, once KVM sets the VM-entry interruption information field or the AMD EVENTINJ field, the next VM-entry must deliver that exception. Pending interrupts are processed after injected exceptions, so in theory it would not be a problem to use KVM_INTERRUPT when an injected exception is present. However, DOSEMU is using run->ready_for_interrupt_injection to detect interrupt windows and then using KVM_SET_SREGS/KVM_SET_REGS to inject the interrupt manually. For this to work, the interrupt window must be delayed after the completion of the previous event injection. Cc: stable@vger.kernel.org Reported-by: Stas Sergeev Tested-by: Stas Sergeev Fixes: 71cc849b7093 ("KVM: x86: Fix split-irqchip vs interrupt injection window request") Reviewed-by: Sean Christopherson Signed-off-by: Paolo Bonzini Signed-off-by: Greg Kroah-Hartman --- arch/x86/kvm/x86.c | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -4252,8 +4252,17 @@ static int kvm_cpu_accept_dm_intr(struct static int kvm_vcpu_ready_for_interrupt_injection(struct kvm_vcpu *vcpu) { - return kvm_arch_interrupt_allowed(vcpu) && - kvm_cpu_accept_dm_intr(vcpu); + /* + * Do not cause an interrupt window exit if an exception + * is pending or an event needs reinjection; userspace + * might want to inject the interrupt manually using KVM_SET_REGS + * or KVM_SET_SREGS. For that to work, we must be at an + * instruction boundary and with no events half-injected. + */ + return (kvm_arch_interrupt_allowed(vcpu) && + kvm_cpu_accept_dm_intr(vcpu) && + !kvm_event_needs_reinjection(vcpu) && + !vcpu->arch.exception.pending); } static int kvm_vcpu_ioctl_interrupt(struct kvm_vcpu *vcpu,