Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757364AbbDVNws (ORCPT ); Wed, 22 Apr 2015 09:52:48 -0400 Received: from youngberry.canonical.com ([91.189.89.112]:35498 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756678AbbDVNwp (ORCPT ); Wed, 22 Apr 2015 09:52:45 -0400 Date: Wed, 22 Apr 2015 14:52:42 +0100 From: Luis Henriques To: Paolo Bonzini Cc: linux-kernel@vger.kernel.org, kvm@vger.kernel.org, saso.linux@astim.si, lists2009@fnarfbargle.com, Nadav Amit , stable@vger.kernel.org Subject: Re: [PATCH stable] KVM: x86: Fix lost interrupt on irr_pending race Message-ID: <20150422135242.GG3671@charon> References: <1429602745-29882-1-git-send-email-pbonzini@redhat.com> <55360EA9.2030806@redhat.com> <20150422133401.GE3671@charon> <5537A658.5060503@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <5537A658.5060503@redhat.com> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2247 Lines: 67 On Wed, Apr 22, 2015 at 03:47:04PM +0200, Paolo Bonzini wrote: > > > On 22/04/2015 15:34, Luis Henriques wrote: > > Thanks Paolo. I was going to apply this backport to the 3.16 kernel > > but it looks like the original commit is a clean cherry-pick. Shall I > > still apply your backport, or do you think the original commit should > > be applied instead? > > Indeed you're right. I wrote the backport for 3.16(.0). However, > commit 56cc2406d68c0f09505c389e276f27a99f495cbd was marked for stable, > so it's necessary to cherry-pick the entire patch on the stable kernel > where the buggy commit was backported. > > That should be, according to the stable@vger.kernel.org archives, > 3.10.54+, 3.13.11.7+, 3.14.18+, 3.16.2+. > Great, thanks for the quick reply. I'll queue the (entire) fix for the 3.16 kernel. Cheers, -- Lu?s > Paolo > > > Cheers, > > -- > > Lu?s > > > >> diff --git a/arch/x86/kvm/lapic.c b/arch/x86/kvm/lapic.c > >> index 6e8ce5a1a05d..e0e5642dae41 100644 > >> --- a/arch/x86/kvm/lapic.c > >> +++ b/arch/x86/kvm/lapic.c > >> @@ -341,8 +341,12 @@ EXPORT_SYMBOL_GPL(kvm_apic_update_irr); > >> > >> static inline void apic_set_irr(int vec, struct kvm_lapic *apic) > >> { > >> - apic->irr_pending = true; > >> apic_set_vector(vec, apic->regs + APIC_IRR); > >> + /* > >> + * irr_pending must be true if any interrupt is pending; set it after > >> + * APIC_IRR to avoid race with apic_clear_irr > >> + */ > >> + apic->irr_pending = true; > >> } > >> > >> static inline int apic_search_irr(struct kvm_lapic *apic) > >> > >> > >> Thanks, > >> > >> Paolo > >> -- > >> To unsubscribe from this list: send the line "unsubscribe stable" in > >> the body of a message to majordomo@vger.kernel.org > >> More majordomo info at http://vger.kernel.org/majordomo-info.html > -- > To unsubscribe from this list: send the line "unsubscribe stable" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/