Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/x86 No functional change:



details:   https://anonhg.NetBSD.org/src/rev/97ae1c2de41e
branches:  trunk
changeset: 457180:97ae1c2de41e
user:      msaitoh <msaitoh%NetBSD.org@localhost>
date:      Fri Jun 14 05:59:39 2019 +0000

description:
No functional change:
- Rename macros:
  - ICR, LVT and MSIDATA can share the bit definitions. Remove redundant
    definitions and use the common macros.
  - Consistently use LAPIC_LVT_ for all local vector table's macro names.
- Use __BITS().
- Add definition for TSC-deadline (LAPIC_LVT_TMM_TSCDLT).

diffstat:

 sys/arch/x86/include/i82489reg.h |  110 +++++++++++++++-----------------------
 sys/arch/x86/pci/msipic.c        |   12 ++--
 sys/arch/x86/x86/lapic.c         |   63 ++++++++++++---------
 3 files changed, 85 insertions(+), 100 deletions(-)

diffs (truncated from 354 to 300 lines):

diff -r a6915591d939 -r 97ae1c2de41e sys/arch/x86/include/i82489reg.h
--- a/sys/arch/x86/include/i82489reg.h  Fri Jun 14 04:48:34 2019 +0000
+++ b/sys/arch/x86/include/i82489reg.h  Fri Jun 14 05:59:39 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: i82489reg.h,v 1.18 2019/06/13 15:10:27 msaitoh Exp $   */
+/*     $NetBSD: i82489reg.h,v 1.19 2019/06/14 05:59:39 msaitoh Exp $   */
 
 /*-
  * Copyright (c) 1998, 2008 The NetBSD Foundation, Inc.
@@ -79,63 +79,60 @@
 #define LAPIC_IRR      0x200   /* Interrupt Req RO */
 #define LAPIC_ESR      0x280   /* Err status. RW */
 
-#define LAPIC_LVT_CMCI 0x2f0   /* Loc.vec (CMCI) RW */
+/* Common definitions for ICR, LVT and MSIDATA */
+#define LAPIC_VECTOR_MASK    __BITS(7, 0)
+#define LAPIC_DLMODE_MASK    __BITS(10, 8)     /* Delivery Mode */
+#define LAPIC_DLMODE_FIXED   __SHIFTIN(0, LAPIC_DLMODE_MASK)
+#define LAPIC_DLMODE_LOW     __SHIFTIN(1, LAPIC_DLMODE_MASK) /* NA in x2APIC */
+#define LAPIC_DLMODE_SMI     __SHIFTIN(2, LAPIC_DLMODE_MASK)
+#define LAPIC_DLMODE_NMI     __SHIFTIN(4, LAPIC_DLMODE_MASK)
+#define LAPIC_DLMODE_INIT    __SHIFTIN(5, LAPIC_DLMODE_MASK)
+#define LAPIC_DLMODE_STARTUP __SHIFTIN(6, LAPIC_DLMODE_MASK) /* NA in LVT,MSI*/
+#define LAPIC_DLMODE_EXTINT  __SHIFTIN(7, LAPIC_DLMODE_MASK) /* NA in x2APIC */
 
-#define LAPIC_ICRLO    0x300   /* Int. cmd. (xAPIC: RW, x2APIC: RW64) */
-#      define LAPIC_DLMODE_MASK        0x00000700      /* Delivery Mode */
-#      define LAPIC_DLMODE_FIXED       0x00000000
-#      define LAPIC_DLMODE_LOW         0x00000100      /* N/A in x2APIC mode */
-#      define LAPIC_DLMODE_SMI         0x00000200
-#      define LAPIC_DLMODE_NMI         0x00000400
-#      define LAPIC_DLMODE_INIT        0x00000500
-#      define LAPIC_DLMODE_STARTUP     0x00000600
-#      define LAPIC_DLMODE_EXTINT      0x00000700      /* N/A in x2APIC mode */
+#define LAPIC_DLSTAT_BUSY    __BIT(12) /* NA in x2APIC nor MSI */
+#define LAPIC_DLSTAT_IDLE    0x00000000
 
-#      define LAPIC_DSTMODE_PHYS       0x00000000
-#      define LAPIC_DSTMODE_LOG        0x00000800
+#define LAPIC_LEVEL_MASK     __BIT(14) /* LAPIC_LVT_LINT_RIRR in LVT LINT */
+#define LAPIC_LEVEL_ASSERT   LAPIC_LEVEL_MASK
+#define LAPIC_LEVEL_DEASSERT 0x00000000
 
-#      define LAPIC_DLSTAT_BUSY        0x00001000      /* N/A in x2APIC mode */
-#      define LAPIC_DLSTAT_IDLE        0x00000000      /* N/A in x2APIC mode */
+#define LAPIC_TRIGMODE_MASK   __BIT(15)
+#define LAPIC_TRIGMODE_EDGE   0x00000000
+#define LAPIC_TRIGMODE_LEVEL  LAPIC_TRIGMODE_MASK
 
-#      define LAPIC_LEVEL_MASK         0x00004000
-#      define LAPIC_LEVEL_ASSERT       0x00004000
-#      define LAPIC_LEVEL_DEASSERT     0x00000000
+/* Common definitions for LVT */
+#define LAPIC_LVT_MASKED     __BIT(16)
+
+#define LAPIC_LVT_CMCI 0x2f0   /* Loc.vec (CMCI) RW */
+#define LAPIC_ICRLO    0x300   /* Int. cmd. (xAPIC: RW, x2APIC: RW64) */
 
-#      define LAPIC_TRIGGER_MASK       0x00008000
-#      define LAPIC_TRIGGER_EDGE       0x00000000
-#      define LAPIC_TRIGGER_LEVEL      0x00008000
+#      define LAPIC_DSTMODE_MASK       __BIT(11)
+#      define LAPIC_DSTMODE_PHYS       __SHIFTIN(0, LAPIC_DSTMODE_MASK)
+#      define LAPIC_DSTMODE_LOG        __SHIFTIN(1, LAPIC_DSTMODE_MASK)
 
-#      define LAPIC_DEST_MASK          0x000c0000
-#      define LAPIC_DEST_DEFAULT       0x00000000
-#      define LAPIC_DEST_SELF          0x00040000
-#      define LAPIC_DEST_ALLINCL       0x00080000
-#      define LAPIC_DEST_ALLEXCL       0x000c0000
+#      define LAPIC_DEST_MASK          __BITS(19, 18)
+#      define LAPIC_DEST_DEFAULT       __SHIFTIN(0, LAPIC_DEST_MASK)
+#      define LAPIC_DEST_SELF          __SHIFTIN(1, LAPIC_DEST_MASK)
+#      define LAPIC_DEST_ALLINCL       __SHIFTIN(2, LAPIC_DEST_MASK)
+#      define LAPIC_DEST_ALLEXCL       __SHIFTIN(3, LAPIC_DEST_MASK)
 
 #define LAPIC_ICRHI    0x310   /* Int. cmd. (xAPIC: RW, x2APIC: NA) */
 
-#define LAPIC_LVTT     0x320   /* Loc.vec.(timer) RW */
-#      define LAPIC_LVTT_VEC_MASK      0x000000ff
-#      define LAPIC_LVTT_DS            0x00001000
-#      define LAPIC_LVTT_M             0x00010000
-#      define LAPIC_LVTT_TM            0x00020000
+#define LAPIC_LVT_TIMER        0x320   /* Loc.vec.(timer) RW */
+#      define LAPIC_LVT_TMM            __BITS(18, 17)
+#      define LAPIC_LVT_TMM_ONESHOT    __SHIFTIN(0, LAPIC_LVT_TMM)
+#      define LAPIC_LVT_TMM_PERIODIC   __SHIFTIN(1, LAPIC_LVT_TMM)
+#      define LAPIC_LVT_TMM_TSCDLT     __SHIFTIN(2, LAPIC_LVT_TMM)
 
-#define LAPIC_TMINT    0x330   /* Loc.vec (Thermal) RW */
-#define LAPIC_PCINT    0x340   /* Loc.vec (Perf Mon) RW */
-#define LAPIC_LVINT0   0x350   /* Loc.vec (LINT0) RW */
-#      define LAPIC_LVT_DM_MASK        0x00000700
-#      define LAPIC_LVT_DM_FIXED       0x00000000
-#      define LAPIC_LVT_DM_SMI         0x00000200
-#      define LAPIC_LVT_DM_NMI         0x00000400
-#      define LAPIC_LVT_DM_INIT        0x00000500
-#      define LAPIC_LVT_DM_EXTINT      0x00000700
-#      define LAPIC_LVT_MASKED         0x00010000
-#      define LAPIC_LVT_LEVTRIG        0x00008000
-#      define LAPIC_LVT_REMOTE_IRR     0x00004000
-#      define LAPIC_INP_POL            0x00002000
-#      define LAPIC_PEND_SEND          0x00001000
+#define LAPIC_LVT_THERM        0x330   /* Loc.vec (Thermal) RW */
+#define LAPIC_LVT_PCINT        0x340   /* Loc.vec (Perf Mon) RW */
+#define LAPIC_LVT_LINT0        0x350   /* Loc.vec (LINT0) RW */
+#      define LAPIC_LVT_LINT_INP_POL   __BIT(13)
+#      define LAPIC_LVT_LINT_RIRR      __BIT(14)
 
-#define LAPIC_LVINT1   0x360   /* Loc.vec (LINT1) RW */
-#define LAPIC_LVERR    0x370   /* Loc.vec (ERROR) RW */
+#define LAPIC_LVT_LINT1        0x360   /* Loc.vec (LINT1) RW */
+#define LAPIC_LVT_ERR  0x370   /* Loc.vec (ERROR) RW */
 #define LAPIC_ICR_TIMER        0x380   /* Initial count RW */
 #define LAPIC_CCR_TIMER        0x390   /* Current count RO */
 
@@ -159,25 +156,6 @@
 #define        LAPIC_MSIADDR_DM                __BIT(2)
 #define        LAPIC_MSIADDR_RSVD1_MASK        __BITS(1, 0)
 
-#define        LAPIC_MSIDATA_VECTOR_MASK       __BITS(7, 0)
-#define        LAPIC_MSIDATA_DM_MASK           __BITS(10, 8)
-#define        LAPIC_MSIDATA_DM_FIXED          __SHIFTIN(0, LAPIC_MSIDATA_DM_MASK)
-#define        LAPIC_MSIDATA_DM_LOPRI          __SHIFTIN(1, LAPIC_MSIDATA_DM_MASK)
-#define        LAPIC_MSIDATA_DM_SMI            __SHIFTIN(2, LAPIC_MSIDATA_DM_MASK)
-#define        LAPIC_MSIDATA_DM_RSVD0          __SHIFTIN(3, LAPIC_MSIDATA_DM_MASK)
-#define        LAPIC_MSIDATA_DM_NMI            __SHIFTIN(4, LAPIC_MSIDATA_DM_MASK)
-#define        LAPIC_MSIDATA_DM_INIT           __SHIFTIN(5, LAPIC_MSIDATA_DM_MASK)
-#define        LAPIC_MSIDATA_DM_RSVD1          __SHIFTIN(6, LAPIC_MSIDATA_DM_MASK)
-#define        LAPIC_MSIDATA_DM_EXTINT         __SHIFTIN(7, LAPIC_MSIDATA_DM_MASK)
-#define        LAPIC_MSIDATA_RSVD0_MASK        __BITS(13, 11)
-#define        LAPIC_MSIDATA_LEVEL_MASK        __BIT(14)
-#define        LAPIC_MSIDATA_LEVEL_DEASSERT    __SHIFTIN(0, LAPIC_MSIDATA_LEVEL_MASK)
-#define        LAPIC_MSIDATA_LEVEL_ASSERT      __SHIFTIN(1, LAPIC_MSIDATA_LEVEL_MASK)
-#define        LAPIC_MSIDATA_TRGMODE_MASK      __BIT(15)
-#define        LAPIC_MSIDATA_TRGMODE_EDGE      __SHIFTIN(0,LAPIC_MSIDATA_TRGMODE_MASK)
-#define        LAPIC_MSIDATA_TRGMODE_LEVEL     __SHIFTIN(1,LAPIC_MSIDATA_TRGMODE_MASK)
-#define        LAPIC_MSIDATA_RSVD1_MASK        __BITS(31, 16)
-
 #define LAPIC_BASE             0xfee00000
 
 #define LAPIC_IRQ_MASK(i)      (1 << ((i) + 1))
diff -r a6915591d939 -r 97ae1c2de41e sys/arch/x86/pci/msipic.c
--- a/sys/arch/x86/pci/msipic.c Fri Jun 14 04:48:34 2019 +0000
+++ b/sys/arch/x86/pci/msipic.c Fri Jun 14 05:59:39 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: msipic.c,v 1.12 2019/04/01 06:20:40 msaitoh Exp $      */
+/*     $NetBSD: msipic.c,v 1.13 2019/06/14 05:59:40 msaitoh Exp $      */
 
 /*
  * Copyright (c) 2015 Internet Initiative Japan Inc.
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: msipic.c,v 1.12 2019/04/01 06:20:40 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: msipic.c,v 1.13 2019/06/14 05:59:40 msaitoh Exp $");
 
 #include "opt_intrdebug.h"
 
@@ -384,8 +384,8 @@
        addr = LAPIC_MSIADDR_BASE | __SHIFTIN(ci->ci_cpuid,
            LAPIC_MSIADDR_DSTID_MASK);
        /* If trigger mode is edge, it don't care level for trigger mode. */
-       data = __SHIFTIN(idt_vec, LAPIC_MSIDATA_VECTOR_MASK)
-               | LAPIC_MSIDATA_TRGMODE_EDGE | LAPIC_MSIDATA_DM_FIXED;
+       data = __SHIFTIN(idt_vec, LAPIC_VECTOR_MASK)
+               | LAPIC_TRIGMODE_EDGE | LAPIC_DLMODE_FIXED;
 
        ctl = pci_conf_read(pc, tag, off + PCI_MSI_CTL);
        if (ctl & PCI_MSI_CTL_64BIT_ADDR) {
@@ -550,8 +550,8 @@
        addr = LAPIC_MSIADDR_BASE | __SHIFTIN(ci->ci_cpuid,
            LAPIC_MSIADDR_DSTID_MASK);
        /* If trigger mode is edge, it don't care level for trigger mode. */
-       data = __SHIFTIN(idt_vec, LAPIC_MSIDATA_VECTOR_MASK)
-               | LAPIC_MSIDATA_TRGMODE_EDGE | LAPIC_MSIDATA_DM_FIXED;
+       data = __SHIFTIN(idt_vec, LAPIC_VECTOR_MASK)
+               | LAPIC_TRIGMODE_EDGE | LAPIC_DLMODE_FIXED;
 
        bstag = pic->pic_msipic->mp_bstag;
        bshandle = pic->pic_msipic->mp_bshandle;
diff -r a6915591d939 -r 97ae1c2de41e sys/arch/x86/x86/lapic.c
--- a/sys/arch/x86/x86/lapic.c  Fri Jun 14 04:48:34 2019 +0000
+++ b/sys/arch/x86/x86/lapic.c  Fri Jun 14 05:59:39 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: lapic.c,v 1.73 2019/06/13 07:42:45 msaitoh Exp $       */
+/*     $NetBSD: lapic.c,v 1.74 2019/06/14 05:59:39 msaitoh Exp $       */
 
 /*-
  * Copyright (c) 2000, 2008 The NetBSD Foundation, Inc.
@@ -32,7 +32,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: lapic.c,v 1.73 2019/06/13 07:42:45 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: lapic.c,v 1.74 2019/06/14 05:59:39 msaitoh Exp $");
 
 #include "acpica.h"
 #include "ioapic.h"
@@ -423,9 +423,9 @@
 #ifdef MULTIPROCESSOR
        if (mp_verbose) {
                apic_format_redir(device_xname(ci->ci_dev), "prelint", 0, 0,
-                   lapic_readreg(LAPIC_LVINT0));
+                   lapic_readreg(LAPIC_LVT_LINT0));
                apic_format_redir(device_xname(ci->ci_dev), "prelint", 1, 0,
-                   lapic_readreg(LAPIC_LVINT1));
+                   lapic_readreg(LAPIC_LVT_LINT1));
        }
 #endif
 
@@ -434,18 +434,18 @@
         * the 8259A for interrupt delivery.  Otherwise request the LAPIC to
         * get external interrupts via LINT0 for the primary CPU.
         */
-       lint0 = LAPIC_LVT_DM_EXTINT;
+       lint0 = LAPIC_DLMODE_EXTINT;
        if (nioapics > 0 || !CPU_IS_PRIMARY(curcpu()))
                lint0 |= LAPIC_LVT_MASKED;
-       lapic_writereg(LAPIC_LVINT0, lint0);
+       lapic_writereg(LAPIC_LVT_LINT0, lint0);
 
        /*
         * Non Maskable Interrupts are to be delivered to the primary CPU.
         */
-       lint1 = LAPIC_LVT_DM_NMI;
+       lint1 = LAPIC_DLMODE_NMI;
        if (!CPU_IS_PRIMARY(curcpu()))
                lint1 |= LAPIC_LVT_MASKED;
-       lapic_writereg(LAPIC_LVINT1, lint1);
+       lapic_writereg(LAPIC_LVT_LINT1, lint1);
 
        for (i = 0; i < mp_nintr; i++) {
                mpi = &mp_intrs[i];
@@ -456,9 +456,9 @@
                                    "%s: WARNING: bad pin value %d\n",
                                    __func__, mpi->ioapic_pin);
                        if (mpi->ioapic_pin == 0)
-                               lapic_writereg(LAPIC_LVINT0, mpi->redir);
+                               lapic_writereg(LAPIC_LVT_LINT0, mpi->redir);
                        else
-                               lapic_writereg(LAPIC_LVINT1, mpi->redir);
+                               lapic_writereg(LAPIC_LVT_LINT1, mpi->redir);
                }
        }
 
@@ -588,10 +588,12 @@
         * then set divisor,
         * then unmask and set the vector.
         */
-       lapic_writereg(LAPIC_LVTT, LAPIC_LVTT_TM | LAPIC_LVTT_M);
+       lapic_writereg(LAPIC_LVT_TIMER,
+           LAPIC_LVT_TMM_PERIODIC | LAPIC_LVT_MASKED);
        lapic_writereg(LAPIC_DCR_TIMER, LAPIC_DCRT_DIV1);
        lapic_writereg(LAPIC_ICR_TIMER, lapic_tval);
-       lapic_writereg(LAPIC_LVTT, LAPIC_LVTT_TM | LAPIC_TIMER_VECTOR);
+       lapic_writereg(LAPIC_LVT_TIMER,
+           LAPIC_LVT_TMM_PERIODIC | LAPIC_TIMER_VECTOR);
        lapic_eoi();
 }
 
@@ -627,7 +629,7 @@
         * Configure timer to one-shot, interrupt masked,
         * large positive number.
         */
-       lapic_writereg(LAPIC_LVTT, LAPIC_LVTT_M);
+       lapic_writereg(LAPIC_LVT_TIMER, LAPIC_LVT_MASKED);
        lapic_writereg(LAPIC_DCR_TIMER, LAPIC_DCRT_DIV1);
        lapic_writereg(LAPIC_ICR_TIMER, 0x80000000);
 
@@ -664,8 +666,8 @@
                lapic_tval = (lapic_per_second * 2) / hz;
                lapic_tval = (lapic_tval / 2) + (lapic_tval & 0x1);
 
-               lapic_writereg(LAPIC_LVTT, LAPIC_LVTT_TM | LAPIC_LVTT_M
-                   | LAPIC_TIMER_VECTOR);
+               lapic_writereg(LAPIC_LVT_TIMER, LAPIC_LVT_TMM_PERIODIC
+                   | LAPIC_LVT_MASKED | LAPIC_TIMER_VECTOR);
                lapic_writereg(LAPIC_DCR_TIMER, LAPIC_DCRT_DIV1);
                lapic_writereg(LAPIC_ICR_TIMER, lapic_tval);
 
@@ -790,7 +792,7 @@
        i82489_icr_wait();
        x86_delay(10000);
        i82489_writereg(LAPIC_ICRLO,
-           LAPIC_DLMODE_INIT | LAPIC_TRIGGER_LEVEL | LAPIC_LEVEL_DEASSERT);
+           LAPIC_DLMODE_INIT | LAPIC_TRIGMODE_LEVEL | LAPIC_LEVEL_DEASSERT);
        i82489_icr_wait();
 
        if ((i82489_readreg(LAPIC_ICRLO) & LAPIC_DLSTAT_BUSY) != 0)
@@ -863,7 +865,7 @@
        x86_delay(10000);
 
        x2apic_write_icr(0,
-           LAPIC_DLMODE_INIT | LAPIC_TRIGGER_LEVEL | LAPIC_LEVEL_DEASSERT);
+           LAPIC_DLMODE_INIT | LAPIC_TRIGMODE_LEVEL | LAPIC_LEVEL_DEASSERT);
 
        return 0;
 }



Home | Main Index | Thread Index | Old Index