 
	
| [Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH] x86/HVM: don't mark evtchn upcall vector as pending when vLAPIC is disabled
 On 25.11.2022 10:00, Roger Pau Monné wrote: > On Fri, Nov 25, 2022 at 09:43:59AM +0100, Jan Beulich wrote: >> On 24.11.2022 16:12, Roger Pau Monné wrote: >>> On Thu, Nov 24, 2022 at 12:16:13PM +0100, Jan Beulich wrote: >>>> We need to be careful here - the kernel treating it as "edge" (like >>>> any other interrupt coming directly from the LAPIC), it ack-s it >>>> before calling the handler, i.e. before evtchn_upcall_pending would >>>> have a chance to be cleared. See Linux'es sysvec_xen_hvm_callback(). >>> >>> Hm, that's not how I handle it on FreeBSD, where the vector is acked >>> after calling the handler (evtchn_upcall_pending gets cleared before >>> the EOI). Maybe there's some corner case I'm missing that requires >>> the EOI to be performed before clearing evtchn_upcall_pending? >> >> I think for the purpose of the one vector doing the EOI late is okay, >> but aiui the goal of doing it early for edge triggered interrupts in >> general (and yet more generally as early as possible) is to unmask >> lower priority vectors as well. > > My reasoning for doing it late was in order to avoid adding extra > latency to things like the timer handling, as the EOI will likely > trigger a vmexit. > >> Of course that's useful only if IRQs >> as a whole are unmasked during (part of) the handling. > > What do you mean with IRQs as a whole? Are you referring to setting > the interrupt flag? Yes (it being cleared). > Thanks for the input, it's appreciated, and sorry for diverging the > conversation so much. I think that's quite fine, because aspects like the one still in context are at least potentially relevant. Especially since here we're not dealing with architectural behavior, but with an extrapolation thereof. And views may (and apparently do) differ as to what the correct extrapolation would be, even if just for corner aspects. Jan 
 
 | 
|  | Lists.xenproject.org is hosted with RackSpace, monitoring our |