Bug 277231 - emulators/xen-kernel - top shows high interrupt usage
Summary: emulators/xen-kernel - top shows high interrupt usage
Status: Closed FIXED
Alias: None
Product: Ports & Packages
Classification: Unclassified
Component: Individual Port(s) (show other bugs)
Version: Latest
Hardware: Any Any
: --- Affects Some People
Assignee: Roger Pau Monné
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2024-02-23 04:25 UTC by mgrooms
Modified: 2024-11-25 23:45 UTC (History)
1 user (show)

See Also:


Attachments
Fix thread nesting accounting (2.58 KB, patch)
2024-03-05 13:27 UTC, Roger Pau Monné
no flags Details | Diff

Note You need to log in before you can comment on or make changes to this bug.
Description mgrooms 2024-02-23 04:25:50 UTC
When booting FreeBSD 14 on Xen as dom0, top shows interrupt usage pretty consistently > 50% even when the system is idle. Perhaps this is an accounting error as the system seems responsive.
Comment 1 Roger Pau Monné freebsd_committer freebsd_triage 2024-03-05 13:27:21 UTC
Created attachment 248948 [details]
Fix thread nesting accounting

Can you please give this a try?  It was indeed a cosmetic issue, so performance wise you should be OK without the patch.
Comment 2 mgrooms 2024-03-09 02:28:33 UTC
Hi Roger. After applying your patch, the interrupt usage in top now looks normal. Thanks again for your help with this!
Comment 3 commit-hook freebsd_committer freebsd_triage 2024-04-16 07:07:41 UTC
A commit in branch main references this bug:

URL: https://cgit.FreeBSD.org/src/commit/?id=f750dce972efaea614aa6d03ecdb24aa962a38a4

commit f750dce972efaea614aa6d03ecdb24aa962a38a4
Author:     Roger Pau Monné <royger@FreeBSD.org>
AuthorDate: 2024-03-05 13:15:03 +0000
Commit:     Roger Pau Monné <royger@FreeBSD.org>
CommitDate: 2024-04-16 07:06:33 +0000

    x86/xen: fix accounted interrupt time

    The current addition to the interrupt nesting level in
    xen_arch_intr_handle_upcall() needs to be compensated in
    xen_intr_handle_upcall(), otherwise interrupts dispatched by the upcall handler
    end 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 adjusting the nested interrupt count before dispatching interrupts
    from 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
    Reviewed by: Elliott Mitchell <ehem+freebsd@m5p.com>

 sys/dev/xen/bus/xen_intr.c | 21 ++++++++++++++++++++-
 1 file changed, 20 insertions(+), 1 deletion(-)