Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch Add a per-CPU event counter that counts every time ...



details:   https://anonhg.NetBSD.org/src/rev/a0ad906851d3
branches:  trunk
changeset: 1016438:a0ad906851d3
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Sat Nov 21 11:43:59 2020 +0000

description:
Add a per-CPU event counter that counts every time an interrupt handler is
preempted by a higher priority interrupt.

diffstat:

 sys/arch/aarch64/include/cpu.h |   3 ++-
 sys/arch/arm/cortex/gicv3.c    |  12 ++++++++++--
 2 files changed, 12 insertions(+), 3 deletions(-)

diffs (61 lines):

diff -r e5df5d5ae7c4 -r a0ad906851d3 sys/arch/aarch64/include/cpu.h
--- a/sys/arch/aarch64/include/cpu.h    Sat Nov 21 11:41:54 2020 +0000
+++ b/sys/arch/aarch64/include/cpu.h    Sat Nov 21 11:43:59 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpu.h,v 1.28 2020/10/01 06:40:16 ryo Exp $ */
+/* $NetBSD: cpu.h,v 1.29 2020/11/21 11:43:59 jmcneill Exp $ */
 
 /*-
  * Copyright (c) 2014, 2020 The NetBSD Foundation, Inc.
@@ -112,6 +112,7 @@
        struct evcnt ci_vfp_save;
        struct evcnt ci_vfp_release;
        struct evcnt ci_uct_trap;
+       struct evcnt ci_intr_preempt;
 
        /* FDT or similar supplied "cpu capacity" */
        uint32_t ci_capacity_dmips_mhz;
diff -r e5df5d5ae7c4 -r a0ad906851d3 sys/arch/arm/cortex/gicv3.c
--- a/sys/arch/arm/cortex/gicv3.c       Sat Nov 21 11:41:54 2020 +0000
+++ b/sys/arch/arm/cortex/gicv3.c       Sat Nov 21 11:43:59 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: gicv3.c,v 1.32 2020/11/01 14:30:12 jmcneill Exp $ */
+/* $NetBSD: gicv3.c,v 1.33 2020/11/21 11:44:00 jmcneill Exp $ */
 
 /*-
  * Copyright (c) 2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -31,7 +31,7 @@
 #define        _INTR_PRIVATE
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: gicv3.c,v 1.32 2020/11/01 14:30:12 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: gicv3.c,v 1.33 2020/11/21 11:44:00 jmcneill Exp $");
 
 #include <sys/param.h>
 #include <sys/kernel.h>
@@ -368,6 +368,9 @@
        struct gicv3_softc * const sc = PICTOSOFTC(pic);
        uint32_t icc_sre, icc_ctlr, gicr_waker;
 
+       evcnt_attach_dynamic(&ci->ci_intr_preempt, EVCNT_TYPE_MISC, NULL,
+           ci->ci_cpuname, "intr preempt");
+
        ci->ci_gic_redist = gicv3_find_redist(sc);
        ci->ci_gic_sgir = gicv3_sgir(sc);
 
@@ -734,10 +737,15 @@
                        isb();
                }
 
+               const int64_t nintr = ci->ci_data.cpu_nintr;
+
                cpsie(I32_bit);
                pic_dispatch(is, frame);
                cpsid(I32_bit);
 
+               if (nintr != ci->ci_data.cpu_nintr)
+                       ci->ci_intr_preempt.ev_count++;
+
                if (!early_eoi) {
                        icc_eoi1r_write(iar);
                        isb();



Home | Main Index | Thread Index | Old Index