The current addition to the interrupt nesting level in
xen_arch_intr_handle_upcall() is wrong, as intr_execute_handlers() as called byneeds to be compensated in
xen_arch_intr_execute_handlers() will already add one nesting level and savehandle_upcall(), otherwise interrupts dispatched by the upcall handler
the previous frameend up seeing a td_intr_nesting_level of 2 or more, which makes them assume
there's been an interrupt nesting.
Such extra interrupt nesting count lead to statclock() reporting idle time as
interrupt, as the call from interrupt context will always be seen as a nested
one (td->td_intr_nesting_level >= 2) due to the nesting count increase done by
both xen_arch_intr_handle_upcall() and intr_execute_handlers().
Fix this by removadjusting the extra nesting increase done innested interrupt count before dispatching interrupts
xen_archfrom xen_intr_handle_upcall().
PR: 277231
Reported by: Matthew Grooms <mgrooms@shrew.net>
Fixes: af610cabf1f4 ('xen/intr: adjust xen_intr_handle_upcall() to match driver filter')
Sponsored by: Cloud Software Group