Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/pci Introduce VIRTIO_F_PCI_INTR_MPSAFE for virtio



details:   https://anonhg.NetBSD.org/src/rev/38a92c721e3f
branches:  trunk
changeset: 330794:38a92c721e3f
user:      ozaki-r <ozaki-r%NetBSD.org@localhost>
date:      Tue Jul 22 01:55:54 2014 +0000

description:
Introduce VIRTIO_F_PCI_INTR_MPSAFE for virtio

It is set by a child driver, e.g., if_vioif. If set, virtio sets
PCI_INTR_MPSAFE for pci_intr_establish.

diffstat:

 sys/dev/pci/if_vioif.c  |   5 +++--
 sys/dev/pci/ld_virtio.c |   5 +++--
 sys/dev/pci/viomb.c     |   5 +++--
 sys/dev/pci/virtio.c    |  10 ++++++++--
 sys/dev/pci/virtiovar.h |   6 +++++-
 5 files changed, 22 insertions(+), 9 deletions(-)

diffs (138 lines):

diff -r 7804629963b7 -r 38a92c721e3f sys/dev/pci/if_vioif.c
--- a/sys/dev/pci/if_vioif.c    Tue Jul 22 01:03:22 2014 +0000
+++ b/sys/dev/pci/if_vioif.c    Tue Jul 22 01:55:54 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_vioif.c,v 1.5 2014/07/18 02:10:55 ozaki-r Exp $     */
+/*     $NetBSD: if_vioif.c,v 1.6 2014/07/22 01:55:54 ozaki-r Exp $     */
 
 /*
  * Copyright (c) 2010 Minoura Makoto.
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_vioif.c,v 1.5 2014/07/18 02:10:55 ozaki-r Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_vioif.c,v 1.6 2014/07/22 01:55:54 ozaki-r Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -476,6 +476,7 @@
        vsc->sc_vqs = &sc->sc_vq[0];
        vsc->sc_config_change = 0;
        vsc->sc_intrhand = virtio_vq_intr;
+       vsc->sc_flags = 0;
 
        features = virtio_negotiate_features(vsc,
                                             (VIRTIO_NET_F_MAC |
diff -r 7804629963b7 -r 38a92c721e3f sys/dev/pci/ld_virtio.c
--- a/sys/dev/pci/ld_virtio.c   Tue Jul 22 01:03:22 2014 +0000
+++ b/sys/dev/pci/ld_virtio.c   Tue Jul 22 01:55:54 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ld_virtio.c,v 1.5 2012/02/02 19:43:06 tls Exp $        */
+/*     $NetBSD: ld_virtio.c,v 1.6 2014/07/22 01:55:54 ozaki-r Exp $    */
 
 /*
  * Copyright (c) 2010 Minoura Makoto.
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ld_virtio.c,v 1.5 2012/02/02 19:43:06 tls Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ld_virtio.c,v 1.6 2014/07/22 01:55:54 ozaki-r Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -250,6 +250,7 @@
        vsc->sc_nvqs = 1;
        vsc->sc_config_change = 0;
        vsc->sc_intrhand = virtio_vq_intr;
+       vsc->sc_flags = 0;
 
        features = virtio_negotiate_features(vsc,
                                             (VIRTIO_BLK_F_SIZE_MAX |
diff -r 7804629963b7 -r 38a92c721e3f sys/dev/pci/viomb.c
--- a/sys/dev/pci/viomb.c       Tue Jul 22 01:03:22 2014 +0000
+++ b/sys/dev/pci/viomb.c       Tue Jul 22 01:55:54 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: viomb.c,v 1.2 2013/10/17 21:06:15 christos Exp $       */
+/*     $NetBSD: viomb.c,v 1.3 2014/07/22 01:55:54 ozaki-r Exp $        */
 
 /*
  * Copyright (c) 2010 Minoura Makoto.
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: viomb.c,v 1.2 2013/10/17 21:06:15 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: viomb.c,v 1.3 2014/07/22 01:55:54 ozaki-r Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -140,6 +140,7 @@
        vsc->sc_nvqs = 2;
        vsc->sc_config_change = viomb_config_change;
        vsc->sc_intrhand = virtio_vq_intr;
+       vsc->sc_flags = 0;
 
        virtio_negotiate_features(vsc,
                                  VIRTIO_CONFIG_DEVICE_FEATURES);
diff -r 7804629963b7 -r 38a92c721e3f sys/dev/pci/virtio.c
--- a/sys/dev/pci/virtio.c      Tue Jul 22 01:03:22 2014 +0000
+++ b/sys/dev/pci/virtio.c      Tue Jul 22 01:55:54 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: virtio.c,v 1.5 2014/03/29 19:28:25 christos Exp $      */
+/*     $NetBSD: virtio.c,v 1.6 2014/07/22 01:55:54 ozaki-r Exp $       */
 
 /*
  * Copyright (c) 2010 Minoura Makoto.
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: virtio.c,v 1.5 2014/03/29 19:28:25 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: virtio.c,v 1.6 2014/07/22 01:55:54 ozaki-r Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -170,8 +170,14 @@
                virtio_set_status(sc, VIRTIO_CONFIG_DEVICE_STATUS_FAILED);
                return;
        }
+
        intrstr = pci_intr_string(pc, ih, intrbuf, sizeof(intrbuf));
+
+       if (sc->sc_flags & VIRTIO_F_PCI_INTR_MPSAFE)
+               pci_intr_setattr(pc, &ih, PCI_INTR_MPSAFE, true);
+
        sc->sc_ih = pci_intr_establish(pc, ih, sc->sc_ipl, virtio_intr, sc);
+
        if (sc->sc_ih == NULL) {
                aprint_error_dev(self, "couldn't establish interrupt");
                if (intrstr != NULL)
diff -r 7804629963b7 -r 38a92c721e3f sys/dev/pci/virtiovar.h
--- a/sys/dev/pci/virtiovar.h   Tue Jul 22 01:03:22 2014 +0000
+++ b/sys/dev/pci/virtiovar.h   Tue Jul 22 01:55:54 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: virtiovar.h,v 1.2 2013/12/06 02:39:58 yamt Exp $       */
+/*     $NetBSD: virtiovar.h,v 1.3 2014/07/22 01:55:54 ozaki-r Exp $    */
 
 /*
  * Copyright (c) 2010 Minoura Makoto.
@@ -127,6 +127,8 @@
        int                     sc_ipl; /* set by child */
        void                    *sc_ih;
 
+       int                     sc_flags; /* set by child */
+
        bus_space_tag_t         sc_iot;
        bus_space_handle_t      sc_ioh;
        bus_size_t              sc_iosize;
@@ -146,6 +148,8 @@
                                         /* set by child */
 };
 
+#define VIRTIO_F_PCI_INTR_MPSAFE       (1 << 0)
+
 /* public interface */
 uint32_t virtio_negotiate_features(struct virtio_softc*, uint32_t);
 



Home | Main Index | Thread Index | Old Index