Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/mips/cavium Support 128 IRQs instead of 64. This is...



details:   https://anonhg.NetBSD.org/src/rev/d21103455db0
branches:  trunk
changeset: 973900:d21103455db0
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Thu Jul 16 21:33:50 2020 +0000

description:
Support 128 IRQs instead of 64. This is icky and needs to be cleaned up.

diffstat:

 sys/arch/mips/cavium/octeon_intr.c |  158 +++++++++++++++++++++++++-----------
 sys/arch/mips/cavium/octeonvar.h   |   10 +-
 2 files changed, 119 insertions(+), 49 deletions(-)

diffs (truncated from 319 to 300 lines):

diff -r 444fb0f7688d -r d21103455db0 sys/arch/mips/cavium/octeon_intr.c
--- a/sys/arch/mips/cavium/octeon_intr.c        Thu Jul 16 21:32:44 2020 +0000
+++ b/sys/arch/mips/cavium/octeon_intr.c        Thu Jul 16 21:33:50 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: octeon_intr.c,v 1.14 2020/06/23 05:14:39 simonb Exp $  */
+/*     $NetBSD: octeon_intr.c,v 1.15 2020/07/16 21:33:50 jmcneill Exp $        */
 /*
  * Copyright 2001, 2002 Wasabi Systems, Inc.
  * All rights reserved.
@@ -44,7 +44,7 @@
 #define __INTR_PRIVATE
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: octeon_intr.c,v 1.14 2020/06/23 05:14:39 simonb Exp $");
+__KERNEL_RCSID(0, "$NetBSD: octeon_intr.c,v 1.15 2020/07/16 21:33:50 jmcneill Exp $");
 
 #include <sys/param.h>
 #include <sys/cpu.h>
@@ -80,7 +80,7 @@
     },
 };
 
-const char * const octeon_intrnames[NIRQS] = {
+const char * octeon_intrnames[NIRQS] = {
        "workq 0",
        "workq 1",
        "workq 2",
@@ -191,6 +191,8 @@
        .cpu_int1_sum0 = X(CIU_INT1_SUM0),
        .cpu_int2_sum0 = X(CIU_INT4_SUM0),
 
+       .cpu_int_sum1 = X(CIU_INT_SUM1),
+
        .cpu_int0_en0 = X(CIU_INT0_EN0),
        .cpu_int1_en0 = X(CIU_INT1_EN0),
        .cpu_int2_en0 = X(CIU_INT4_EN00),
@@ -217,6 +219,8 @@
        .cpu_int1_sum0 = X(CIU_INT3_SUM0),
        .cpu_int2_sum0 = X(CIU_INT4_SUM1),
 
+       .cpu_int_sum1 = X(CIU_INT_SUM1),
+
        .cpu_int0_en0 = X(CIU_INT2_EN0),
        .cpu_int1_en0 = X(CIU_INT3_EN0),
        .cpu_int2_en0 = X(CIU_INT4_EN10),
@@ -344,15 +348,17 @@
 
        mips3_sd(cpu->cpu_int32_en, 0);
 
-       mips3_sd(cpu->cpu_int0_en1, 0); // WDOG IPL2
-       mips3_sd(cpu->cpu_int1_en1, 0); // WDOG IPL3
-       mips3_sd(cpu->cpu_int2_en1, 0); // WDOG IPL4
+       mips3_sd(cpu->cpu_int0_en1, cpu->cpu_int0_enable1);
+       mips3_sd(cpu->cpu_int1_en1, cpu->cpu_int1_enable1);
+       mips3_sd(cpu->cpu_int2_en1, cpu->cpu_int2_enable1);
 
 #ifdef MULTIPROCESSOR
        mips3_sd(cpu->cpu_mbox_clr, __BITS(31,0));
 #endif
 
-       for (size_t i = 0; i < NIRQS; i++) {
+       for (int i = 0; i < NIRQS; i++) {
+               if (octeon_intrnames[i] == NULL)
+                       octeon_intrnames[i] = kmem_asprintf("irq %d", i);
                evcnt_attach_dynamic(&cpu->cpu_intr_evs[i],
                    EVCNT_TYPE_INTR, NULL, xname, octeon_intrnames[i]);
        }
@@ -411,7 +417,8 @@
        /*
         * Now enable it.
         */
-       const uint64_t irq_mask = __BIT(irq);
+       const int bank = irq / 64;
+       const uint64_t irq_mask = __BIT(irq % 64);
        struct cpu_softc * const cpu0 = &octeon_cpu0_softc;
 #if MULTIPROCESSOR
        struct cpu_softc * const cpu1 = &octeon_cpu1_softc;
@@ -419,27 +426,51 @@
 
        switch (ipl) {
        case IPL_VM:
-               cpu0->cpu_int0_enable0 |= irq_mask;
-               mips3_sd(cpu0->cpu_int0_en0, cpu0->cpu_int0_enable0);
+               if (bank == 0) {
+                       cpu0->cpu_int0_enable0 |= irq_mask;
+                       mips3_sd(cpu0->cpu_int0_en0, cpu0->cpu_int0_enable0);
+               } else {
+                       cpu0->cpu_int0_enable1 |= irq_mask;
+                       mips3_sd(cpu0->cpu_int0_en1, cpu0->cpu_int0_enable1);
+               }
                break;
 
        case IPL_SCHED:
-               cpu0->cpu_int1_enable0 |= irq_mask;
-               mips3_sd(cpu0->cpu_int1_en0, cpu0->cpu_int1_enable0);
+               if (bank == 0) {
+                       cpu0->cpu_int1_enable0 |= irq_mask;
+                       mips3_sd(cpu0->cpu_int1_en0, cpu0->cpu_int1_enable0);
 #ifdef MULTIPROCESSOR
-               cpu1->cpu_int1_enable0 = cpu0->cpu_int1_enable0;
-               mips3_sd(cpu1->cpu_int1_en0, cpu1->cpu_int1_enable0);
+                       cpu1->cpu_int1_enable0 = cpu0->cpu_int1_enable0;
+                       mips3_sd(cpu1->cpu_int1_en0, cpu1->cpu_int1_enable0);
 #endif
+               } else {
+                       cpu0->cpu_int1_enable1 |= irq_mask;
+                       mips3_sd(cpu0->cpu_int1_en1, cpu0->cpu_int1_enable1);
+#ifdef MULTIPROCESSOR
+                       cpu1->cpu_int1_enable1 = cpu0->cpu_int1_enable1;
+                       mips3_sd(cpu1->cpu_int1_en1, cpu1->cpu_int1_enable1);
+#endif
+               }
+
                break;
 
        case IPL_DDB:
        case IPL_HIGH:
-               cpu0->cpu_int2_enable0 |= irq_mask;
-               mips3_sd(cpu0->cpu_int2_en0, cpu0->cpu_int2_enable0);
+               if (bank == 0) {
+                       cpu0->cpu_int2_enable0 |= irq_mask;
+                       mips3_sd(cpu0->cpu_int2_en0, cpu0->cpu_int2_enable0);
 #ifdef MULTIPROCESSOR
-               cpu1->cpu_int2_enable0 = cpu0->cpu_int2_enable0;
-               mips3_sd(cpu1->cpu_int2_en0, cpu1->cpu_int2_enable0);
+                       cpu1->cpu_int2_enable0 = cpu0->cpu_int2_enable0;
+                       mips3_sd(cpu1->cpu_int2_en0, cpu1->cpu_int2_enable0);
 #endif
+               } else {
+                       cpu0->cpu_int2_enable1 |= irq_mask;
+                       mips3_sd(cpu0->cpu_int2_en1, cpu0->cpu_int2_enable1);
+#ifdef MULTIPROCESSOR
+                       cpu1->cpu_int2_enable1 = cpu0->cpu_int2_enable1;
+                       mips3_sd(cpu1->cpu_int2_en1, cpu1->cpu_int2_enable1);
+#endif
+               }
                break;
        }
 
@@ -460,7 +491,8 @@
        /*
         * First disable it.
         */
-       const uint64_t irq_mask = ~__BIT(irq);
+       const int bank = irq / 64;
+       const uint64_t irq_mask = ~__BIT(irq % 64);
        struct cpu_softc * const cpu0 = &octeon_cpu0_softc;
 #if MULTIPROCESSOR
        struct cpu_softc * const cpu1 = &octeon_cpu1_softc;
@@ -468,27 +500,50 @@
 
        switch (ipl) {
        case IPL_VM:
-               cpu0->cpu_int0_enable0 &= ~irq_mask;
-               mips3_sd(cpu0->cpu_int0_en0, cpu0->cpu_int0_enable0);
+               if (bank == 0) {
+                       cpu0->cpu_int0_enable0 &= ~irq_mask;
+                       mips3_sd(cpu0->cpu_int0_en0, cpu0->cpu_int0_enable0);
+               } else {
+                       cpu0->cpu_int0_enable1 &= ~irq_mask;
+                       mips3_sd(cpu0->cpu_int0_en1, cpu0->cpu_int0_enable1);
+               }
                break;
 
        case IPL_SCHED:
-               cpu0->cpu_int1_enable0 &= ~irq_mask;
-               mips3_sd(cpu0->cpu_int1_en0, cpu0->cpu_int1_enable0);
+               if (bank == 0) {
+                       cpu0->cpu_int1_enable0 &= ~irq_mask;
+                       mips3_sd(cpu0->cpu_int1_en0, cpu0->cpu_int1_enable0);
 #ifdef MULTIPROCESSOR
-               cpu1->cpu_int1_enable0 = cpu0->cpu_int1_enable0;
-               mips3_sd(cpu1->cpu_int1_en0, cpu1->cpu_int1_enable0);
+                       cpu1->cpu_int1_enable0 = cpu0->cpu_int1_enable0;
+                       mips3_sd(cpu1->cpu_int1_en0, cpu1->cpu_int1_enable0);
 #endif
+               } else {
+                       cpu0->cpu_int1_enable1 &= ~irq_mask;
+                       mips3_sd(cpu0->cpu_int1_en1, cpu0->cpu_int1_enable1);
+#ifdef MULTIPROCESSOR
+                       cpu1->cpu_int1_enable1 = cpu0->cpu_int1_enable1;
+                       mips3_sd(cpu1->cpu_int1_en1, cpu1->cpu_int1_enable1);
+#endif
+               }
                break;
 
        case IPL_DDB:
        case IPL_HIGH:
-               cpu0->cpu_int2_enable0 &= ~irq_mask;
-               mips3_sd(cpu0->cpu_int2_en0, cpu0->cpu_int2_enable0);
+               if (bank == 0) {
+                       cpu0->cpu_int2_enable0 &= ~irq_mask;
+                       mips3_sd(cpu0->cpu_int2_en0, cpu0->cpu_int2_enable0);
 #ifdef MULTIPROCESSOR
-               cpu1->cpu_int2_enable0 = cpu0->cpu_int2_enable0;
-               mips3_sd(cpu1->cpu_int2_en0, cpu1->cpu_int2_enable0);
+                       cpu1->cpu_int2_enable0 = cpu0->cpu_int2_enable0;
+                       mips3_sd(cpu1->cpu_int2_en0, cpu1->cpu_int2_enable0);
 #endif
+               } else {
+                       cpu0->cpu_int2_enable1 &= ~irq_mask;
+                       mips3_sd(cpu0->cpu_int2_en1, cpu0->cpu_int2_enable1);
+#ifdef MULTIPROCESSOR
+                       cpu1->cpu_int2_enable1 = cpu0->cpu_int2_enable1;
+                       mips3_sd(cpu1->cpu_int2_en1, cpu1->cpu_int2_enable1);
+#endif
+               }
                break;
        }
 
@@ -507,43 +562,52 @@
 {
        struct cpu_info * const ci = curcpu();
        struct cpu_softc * const cpu = ci->ci_softc;
+       int bank;
 
        KDASSERT(mips_cp0_status_read() & MIPS_SR_INT_IE);
        KASSERT((ipending & ~MIPS_INT_MASK) == 0);
        KASSERT(ipending & MIPS_HARD_INT_MASK);
-       uint64_t hwpend = 0;
+       uint64_t hwpend[2] = { 0, 0 };
+
+       const uint64_t sum1 = mips3_ld(cpu->cpu_int_sum1);
 
        if (ipending & MIPS_INT_MASK_2) {
-               hwpend = mips3_ld(cpu->cpu_int2_sum0)
+               hwpend[0] = mips3_ld(cpu->cpu_int2_sum0)
                    & cpu->cpu_int2_enable0;
+               hwpend[1] = sum1 & cpu->cpu_int2_enable1;
        } else if (ipending & MIPS_INT_MASK_1) {
-               hwpend = mips3_ld(cpu->cpu_int1_sum0)
+               hwpend[0] = mips3_ld(cpu->cpu_int1_sum0)
                    & cpu->cpu_int1_enable0;
+               hwpend[1] = sum1 & cpu->cpu_int1_enable1;
        } else if (ipending & MIPS_INT_MASK_0) {
-               hwpend = mips3_ld(cpu->cpu_int0_sum0)
+               hwpend[0] = mips3_ld(cpu->cpu_int0_sum0)
                    & cpu->cpu_int0_enable0;
+               hwpend[1] = sum1 & cpu->cpu_int0_enable1;
        } else {
                panic("octeon_iointr: unexpected ipending %#x", ipending);
        }
-       while (hwpend != 0) {
-               const int irq = ffs64(hwpend) - 1;
-               hwpend &= ~__BIT(irq);
+       for (bank = 0; bank <= 1; bank++) {
+               while (hwpend[bank] != 0) {
+                       const int bit = ffs64(hwpend[bank]) - 1;
+                       const int irq = (bank * 64) + bit;
+                       hwpend[bank] &= ~__BIT(bit);
 
-               struct octeon_intrhand * const ih = octciu_intrs[irq];
-               cpu->cpu_intr_evs[irq].ev_count++;
-               if (__predict_true(ih != NULL)) {
+                       struct octeon_intrhand * const ih = octciu_intrs[irq];
+                       cpu->cpu_intr_evs[irq].ev_count++;
+                       if (__predict_true(ih != NULL)) {
 #ifdef MULTIPROCESSOR
-                       if (ipl == IPL_VM) {
-                               KERNEL_LOCK(1, NULL);
+                               if (ipl == IPL_VM) {
+                                       KERNEL_LOCK(1, NULL);
 #endif
-                               (*ih->ih_func)(ih->ih_arg);
+                                       (*ih->ih_func)(ih->ih_arg);
 #ifdef MULTIPROCESSOR
-                               KERNEL_UNLOCK_ONE(NULL);
-                       } else {
-                               (*ih->ih_func)(ih->ih_arg);
+                                       KERNEL_UNLOCK_ONE(NULL);
+                               } else {
+                                       (*ih->ih_func)(ih->ih_arg);
+                               }
+#endif
+                               KDASSERT(mips_cp0_status_read() & MIPS_SR_INT_IE);
                        }
-#endif
-                       KDASSERT(mips_cp0_status_read() & MIPS_SR_INT_IE);
                }
        }
        KDASSERT(mips_cp0_status_read() & MIPS_SR_INT_IE);
diff -r 444fb0f7688d -r d21103455db0 sys/arch/mips/cavium/octeonvar.h
--- a/sys/arch/mips/cavium/octeonvar.h  Thu Jul 16 21:32:44 2020 +0000
+++ b/sys/arch/mips/cavium/octeonvar.h  Thu Jul 16 21:33:50 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: octeonvar.h,v 1.13 2020/06/23 05:15:33 simonb Exp $    */
+/*     $NetBSD: octeonvar.h,v 1.14 2020/07/16 21:33:50 jmcneill Exp $  */
 
 /*-
  * Copyright (c) 2001 The NetBSD Foundation, Inc.
@@ -77,7 +77,7 @@
        int     mc_mallocsafe;
 };
 
-#define NIRQS  64
+#define NIRQS  128
 
 struct cpu_softc {
        struct cpu_info *cpu_ci;
@@ -86,6 +86,8 @@



Home | Main Index | Thread Index | Old Index