Source-Changes-HG archive

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

[src/trunk]: src/sys Add kernel code to support intrctl(8).



details:   https://anonhg.NetBSD.org/src/rev/d4b9f5a3cb2f
branches:  trunk
changeset: 810049:d4b9f5a3cb2f
user:      knakahara <knakahara%NetBSD.org@localhost>
date:      Mon Aug 17 06:16:02 2015 +0000

description:
Add kernel code to support intrctl(8).

diffstat:

 sys/arch/x86/include/intr.h               |    7 +-
 sys/arch/x86/include/intr_distribute.h    |    3 +-
 sys/arch/x86/include/pci_machdep_common.h |    3 +-
 sys/arch/x86/pci/pci_intr_machdep.c       |   35 +-
 sys/arch/x86/pci/pci_msi_machdep.c        |   19 +-
 sys/arch/x86/pci/pci_msi_machdep.h        |    6 +-
 sys/arch/x86/x86/intr.c                   |  300 ++++++++++++++++-
 sys/conf/files                            |    5 +-
 sys/dev/pci/if_wm.c                       |   24 +-
 sys/dev/pci/ixgbe/ixgbe.c                 |    6 +-
 sys/dev/pci/ixgbe/ixgbe.h                 |    3 +-
 sys/dev/pci/ixgbe/ixv.c                   |    6 +-
 sys/dev/pci/ixgbe/ixv.h                   |    3 +-
 sys/dev/pci/pci_stub.c                    |   14 +-
 sys/dev/pci/pcivar.h                      |    4 +-
 sys/kern/files.kern                       |    3 +-
 sys/kern/kern_stub.c                      |   13 +-
 sys/kern/subr_interrupt.c                 |  513 ++++++++++++++++++++++++++++++
 sys/secmodel/suser/secmodel_suser.c       |   18 +-
 sys/sys/Makefile                          |    4 +-
 sys/sys/interrupt.h                       |   56 +++
 sys/sys/intr.h                            |    3 +-
 sys/sys/intrio.h                          |   68 +++
 sys/sys/kauth.h                           |    4 +-
 24 files changed, 1045 insertions(+), 75 deletions(-)

diffs (truncated from 1678 to 300 lines):

diff -r dfe450708f92 -r d4b9f5a3cb2f sys/arch/x86/include/intr.h
--- a/sys/arch/x86/include/intr.h       Sun Aug 16 19:22:33 2015 +0000
+++ b/sys/arch/x86/include/intr.h       Mon Aug 17 06:16:02 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: intr.h,v 1.47 2015/04/27 06:51:40 knakahara Exp $      */
+/*     $NetBSD: intr.h,v 1.48 2015/08/17 06:16:02 knakahara Exp $      */
 
 /*-
  * Copyright (c) 1998, 2001, 2006, 2007, 2008 The NetBSD Foundation, Inc.
@@ -86,13 +86,14 @@
        void *is_recurse;               /* entry for spllower */
        void *is_resume;                /* entry for doreti */
        lwp_t *is_lwp;                  /* for soft interrupts */
-       struct evcnt is_evcnt;          /* interrupt counter */
+       struct evcnt is_evcnt;          /* interrupt counter per cpu */
        int is_flags;                   /* see below */
        int is_type;                    /* level, edge */
        int is_idtvec;
        int is_minlevel;
        char is_evname[32];             /* event counter name */
        char is_intrid[INTRIDBUF];      /* intrid created by create_intrid() */
+       char is_xname[INTRDEVNAMEBUF];  /* device names */
        cpuid_t is_active_cpu;          /* active cpuid */
        struct percpu_evcnt *is_saved_evcnt;    /* interrupt count of deactivated cpus */
        SIMPLEQ_ENTRY(intrsource) is_list;      /* link of intrsources */
@@ -185,6 +186,8 @@
 
 void intr_default_setup(void);
 void x86_nmi(void);
+void *intr_establish_xname(int, struct pic *, int, int, int, int (*)(void *),
+                          void *, bool, const char *);
 void *intr_establish(int, struct pic *, int, int, int, int (*)(void *), void *, bool);
 void intr_disestablish(struct intrhand *);
 void intr_add_pcibus(struct pcibus_attach_args *);
diff -r dfe450708f92 -r d4b9f5a3cb2f sys/arch/x86/include/intr_distribute.h
--- a/sys/arch/x86/include/intr_distribute.h    Sun Aug 16 19:22:33 2015 +0000
+++ b/sys/arch/x86/include/intr_distribute.h    Mon Aug 17 06:16:02 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: intr_distribute.h,v 1.1 2015/04/27 06:42:52 knakahara Exp $    */
+/*     $NetBSD: intr_distribute.h,v 1.2 2015/08/17 06:16:02 knakahara Exp $    */
 
 /*
  * Copyright (c) 2015 Internet Initiative Japan Inc.
@@ -34,6 +34,7 @@
 #include <sys/kcpuset.h>
 
 int intr_distribute(struct intrhand *, const kcpuset_t *, kcpuset_t *);
+int intr_distribute_handler(const char *, const kcpuset_t *, kcpuset_t *);
 
 #endif /* _KERNEL */
 
diff -r dfe450708f92 -r d4b9f5a3cb2f sys/arch/x86/include/pci_machdep_common.h
--- a/sys/arch/x86/include/pci_machdep_common.h Sun Aug 16 19:22:33 2015 +0000
+++ b/sys/arch/x86/include/pci_machdep_common.h Mon Aug 17 06:16:02 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pci_machdep_common.h,v 1.20 2015/08/13 04:39:33 msaitoh Exp $  */
+/*     $NetBSD: pci_machdep_common.h,v 1.21 2015/08/17 06:16:02 knakahara Exp $        */
 
 /*
  * Copyright (c) 1996 Christopher G. Demetriou.  All rights reserved.
@@ -118,7 +118,6 @@
 void           *pci_intr_establish(pci_chipset_tag_t, pci_intr_handle_t,
                    int, int (*)(void *), void *);
 void           pci_intr_disestablish(pci_chipset_tag_t, void *);
-int            pci_intr_distribute(void *, const kcpuset_t *, kcpuset_t *);
 
 typedef enum {
        PCI_INTR_TYPE_INTX = 0,
diff -r dfe450708f92 -r d4b9f5a3cb2f sys/arch/x86/pci/pci_intr_machdep.c
--- a/sys/arch/x86/pci/pci_intr_machdep.c       Sun Aug 16 19:22:33 2015 +0000
+++ b/sys/arch/x86/pci/pci_intr_machdep.c       Mon Aug 17 06:16:02 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pci_intr_machdep.c,v 1.36 2015/08/13 04:39:33 msaitoh Exp $    */
+/*     $NetBSD: pci_intr_machdep.c,v 1.37 2015/08/17 06:16:03 knakahara Exp $  */
 
 /*-
  * Copyright (c) 1997, 1998, 2009 The NetBSD Foundation, Inc.
@@ -73,7 +73,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pci_intr_machdep.c,v 1.36 2015/08/13 04:39:33 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pci_intr_machdep.c,v 1.37 2015/08/17 06:16:03 knakahara Exp $");
 
 #include <sys/types.h>
 #include <sys/param.h>
@@ -275,8 +275,8 @@
 }
 
 void *
-pci_intr_establish(pci_chipset_tag_t pc, pci_intr_handle_t ih,
-    int level, int (*func)(void *), void *arg)
+pci_intr_establish_xname(pci_chipset_tag_t pc, pci_intr_handle_t ih,
+    int level, int (*func)(void *), void *arg, const char *xname)
 {
        int pin, irq;
        struct pic *pic;
@@ -295,9 +295,11 @@
 
        if (INT_VIA_MSI(ih)) {
                if (MSI_INT_IS_MSIX(ih))
-                       return x86_pci_msix_establish(pc, ih, level, func, arg);
+                       return x86_pci_msix_establish(pc, ih, level, func, arg,
+                           xname);
                else
-                       return x86_pci_msi_establish(pc, ih, level, func, arg);
+                       return x86_pci_msi_establish(pc, ih, level, func, arg,
+                           xname);
        }
 
        pic = &i8259_pic;
@@ -320,8 +322,16 @@
        }
 #endif
 
-       return intr_establish(irq, pic, pin, IST_LEVEL, level, func, arg,
-           mpsafe);
+       return intr_establish_xname(irq, pic, pin, IST_LEVEL, level, func, arg,
+           mpsafe, xname);
+}
+
+void *
+pci_intr_establish(pci_chipset_tag_t pc, pci_intr_handle_t ih,
+    int level, int (*func)(void *), void *arg)
+{
+
+       return pci_intr_establish_xname(pc, ih, level, func, arg, "unknown");
 }
 
 void
@@ -340,15 +350,6 @@
        intr_disestablish(cookie);
 }
 
-int
-pci_intr_distribute(void *cookie, const kcpuset_t *newset, kcpuset_t *oldset)
-{
-
-       /* XXX Is pc_ov->ov_intr_distribute required? */
-
-       return intr_distribute(cookie, newset, oldset);
-}
-
 #if NIOAPIC > 0
 pci_intr_type_t
 pci_intr_type(pci_intr_handle_t ih)
diff -r dfe450708f92 -r d4b9f5a3cb2f sys/arch/x86/pci/pci_msi_machdep.c
--- a/sys/arch/x86/pci/pci_msi_machdep.c        Sun Aug 16 19:22:33 2015 +0000
+++ b/sys/arch/x86/pci/pci_msi_machdep.c        Mon Aug 17 06:16:02 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pci_msi_machdep.c,v 1.8 2015/08/13 04:39:33 msaitoh Exp $      */
+/*     $NetBSD: pci_msi_machdep.c,v 1.9 2015/08/17 06:16:03 knakahara Exp $    */
 
 /*
  * Copyright (c) 2015 Internet Initiative Japan Inc.
@@ -34,7 +34,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pci_msi_machdep.c,v 1.8 2015/08/13 04:39:33 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pci_msi_machdep.c,v 1.9 2015/08/17 06:16:03 knakahara Exp $");
 
 #include "opt_intrdebug.h"
 
@@ -208,7 +208,8 @@
 
 static void *
 pci_msi_common_establish(pci_chipset_tag_t pc, pci_intr_handle_t ih,
-    int level, int (*func)(void *), void *arg, struct pic *pic)
+    int level, int (*func)(void *), void *arg, struct pic *pic,
+    const char *xname)
 {
        int irq, pin;
        bool mpsafe;
@@ -219,8 +220,8 @@
        pin = MSI_INT_VEC(ih);
        mpsafe = ((ih & MPSAFE_MASK) != 0);
 
-       return intr_establish(irq, pic, pin, IST_EDGE, level, func, arg,
-           mpsafe);
+       return intr_establish_xname(irq, pic, pin, IST_EDGE, level, func, arg,
+           mpsafe, xname);
 }
 
 static void
@@ -396,7 +397,7 @@
  */
 void *
 x86_pci_msi_establish(pci_chipset_tag_t pc, pci_intr_handle_t ih,
-    int level, int (*func)(void *), void *arg)
+    int level, int (*func)(void *), void *arg, const char *xname)
 {
        struct pic *pic;
 
@@ -406,7 +407,7 @@
                return NULL;
        }
 
-       return pci_msi_common_establish(pc, ih, level, func, arg, pic);
+       return pci_msi_common_establish(pc, ih, level, func, arg, pic, xname);
 }
 
 /*
@@ -441,7 +442,7 @@
  */
 void *
 x86_pci_msix_establish(pci_chipset_tag_t pc, pci_intr_handle_t ih,
-    int level, int (*func)(void *), void *arg)
+    int level, int (*func)(void *), void *arg, const char *xname)
 {
        struct pic *pic;
 
@@ -451,7 +452,7 @@
                return NULL;
        }
 
-       return pci_msi_common_establish(pc, ih, level, func, arg, pic);
+       return pci_msi_common_establish(pc, ih, level, func, arg, pic, xname);
 }
 
 /*
diff -r dfe450708f92 -r d4b9f5a3cb2f sys/arch/x86/pci/pci_msi_machdep.h
--- a/sys/arch/x86/pci/pci_msi_machdep.h        Sun Aug 16 19:22:33 2015 +0000
+++ b/sys/arch/x86/pci/pci_msi_machdep.h        Mon Aug 17 06:16:02 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pci_msi_machdep.h,v 1.2 2015/05/15 08:36:41 knakahara Exp $    */
+/*     $NetBSD: pci_msi_machdep.h,v 1.3 2015/08/17 06:16:03 knakahara Exp $    */
 
 /*
  * Copyright (c) 2015 Internet Initiative Japan Inc.
@@ -34,13 +34,13 @@
 void           x86_pci_msi_release(pci_chipset_tag_t, pci_intr_handle_t *,
                    int);
 void           *x86_pci_msi_establish(pci_chipset_tag_t, pci_intr_handle_t,
-                   int, int (*)(void *), void *);
+                   int, int (*)(void *), void *, const char *);
 void           x86_pci_msi_disestablish(pci_chipset_tag_t, void *);
 
 void           x86_pci_msix_release(pci_chipset_tag_t, pci_intr_handle_t *,
                    int);
 void           *x86_pci_msix_establish(pci_chipset_tag_t, pci_intr_handle_t,
-                   int, int (*)(void *), void *);
+                   int, int (*)(void *), void *, const char *xname);
 void           x86_pci_msix_disestablish(pci_chipset_tag_t, void *);
 
 #endif /* _X86_PCI_PCI_MSI_MACHDEP_H_ */
diff -r dfe450708f92 -r d4b9f5a3cb2f sys/arch/x86/x86/intr.c
--- a/sys/arch/x86/x86/intr.c   Sun Aug 16 19:22:33 2015 +0000
+++ b/sys/arch/x86/x86/intr.c   Mon Aug 17 06:16:02 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: intr.c,v 1.86 2015/06/23 10:00:13 msaitoh Exp $        */
+/*     $NetBSD: intr.c,v 1.87 2015/08/17 06:16:03 knakahara Exp $      */
 
 /*-
  * Copyright (c) 2007, 2008, 2009 The NetBSD Foundation, Inc.
@@ -133,7 +133,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: intr.c,v 1.86 2015/06/23 10:00:13 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: intr.c,v 1.87 2015/08/17 06:16:03 knakahara Exp $");
 
 #include "opt_intrdebug.h"
 #include "opt_multiprocessor.h"
@@ -151,6 +151,10 @@
 #include <sys/cpu.h>
 #include <sys/atomic.h>
 #include <sys/xcall.h>
+#include <sys/interrupt.h>
+
+#include <sys/kauth.h>
+#include <sys/conf.h>
 
 #include <uvm/uvm_extern.h>
 
@@ -224,6 +228,8 @@
 static void intr_establish_xcall(void *, void *);
 static void intr_disestablish_xcall(void *, void *);
 
+static const char *legacy_intr_string(int, char *, size_t, struct pic *);
+
 static inline bool redzone_const_or_false(bool);
 static inline int redzone_const_or_zero(int);
 
@@ -829,6 +835,19 @@
 }
 
 /*
+ * Append device name to intrsource. If device A and device B share IRQ number,
+ * the device name of the interrupt id is "device A, device B".
+ */
+static void
+intr_append_intrsource_xname(struct intrsource *isp, const char *xname)
+{
+
+       if (isp->is_xname[0] != '\0')
+               strlcat(isp->is_xname, ", ", sizeof(isp->is_xname));
+       strlcat(isp->is_xname, xname, sizeof(isp->is_xname));
+}
+



Home | Main Index | Thread Index | Old Index