Module Name:    src
Committed By:   ozaki-r
Date:           Tue Jul 22 01:55:54 UTC 2014

Modified Files:
        src/sys/dev/pci: if_vioif.c ld_virtio.c viomb.c virtio.c virtiovar.h

Log Message:
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.


To generate a diff of this commit:
cvs rdiff -u -r1.5 -r1.6 src/sys/dev/pci/if_vioif.c \
    src/sys/dev/pci/ld_virtio.c src/sys/dev/pci/virtio.c
cvs rdiff -u -r1.2 -r1.3 src/sys/dev/pci/viomb.c src/sys/dev/pci/virtiovar.h

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/dev/pci/if_vioif.c
diff -u src/sys/dev/pci/if_vioif.c:1.5 src/sys/dev/pci/if_vioif.c:1.6
--- src/sys/dev/pci/if_vioif.c:1.5	Fri Jul 18 02:10:55 2014
+++ src/sys/dev/pci/if_vioif.c	Tue Jul 22 01:55:54 2014
@@ -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 @@ vioif_attach(device_t parent, device_t s
 	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 |
Index: src/sys/dev/pci/ld_virtio.c
diff -u src/sys/dev/pci/ld_virtio.c:1.5 src/sys/dev/pci/ld_virtio.c:1.6
--- src/sys/dev/pci/ld_virtio.c:1.5	Thu Feb  2 19:43:06 2012
+++ src/sys/dev/pci/ld_virtio.c	Tue Jul 22 01:55:54 2014
@@ -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 @@ ld_virtio_attach(device_t parent, device
 	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 |
Index: src/sys/dev/pci/virtio.c
diff -u src/sys/dev/pci/virtio.c:1.5 src/sys/dev/pci/virtio.c:1.6
--- src/sys/dev/pci/virtio.c:1.5	Sat Mar 29 19:28:25 2014
+++ src/sys/dev/pci/virtio.c	Tue Jul 22 01:55:54 2014
@@ -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_attach(device_t parent, device_t 
 		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)

Index: src/sys/dev/pci/viomb.c
diff -u src/sys/dev/pci/viomb.c:1.2 src/sys/dev/pci/viomb.c:1.3
--- src/sys/dev/pci/viomb.c:1.2	Thu Oct 17 21:06:15 2013
+++ src/sys/dev/pci/viomb.c	Tue Jul 22 01:55:54 2014
@@ -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 @@ viomb_attach(device_t parent, device_t s
 	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);
Index: src/sys/dev/pci/virtiovar.h
diff -u src/sys/dev/pci/virtiovar.h:1.2 src/sys/dev/pci/virtiovar.h:1.3
--- src/sys/dev/pci/virtiovar.h:1.2	Fri Dec  6 02:39:58 2013
+++ src/sys/dev/pci/virtiovar.h	Tue Jul 22 01:55:54 2014
@@ -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 @@ struct virtio_softc {
 	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 @@ struct virtio_softc {
 					 /* set by child */
 };
 
+#define VIRTIO_F_PCI_INTR_MPSAFE	(1 << 0)
+
 /* public interface */
 uint32_t virtio_negotiate_features(struct virtio_softc*, uint32_t);
 

Reply via email to