Module Name:    src
Committed By:   yamaguchi
Date:           Sat Mar 25 02:59:23 UTC 2023

Modified Files:
        src/sys/dev/pci: virtio.c

Log Message:
Setup virtqueues after registering them to virtio_softc


To generate a diff of this commit:
cvs rdiff -u -r1.68 -r1.69 src/sys/dev/pci/virtio.c

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/virtio.c
diff -u src/sys/dev/pci/virtio.c:1.68 src/sys/dev/pci/virtio.c:1.69
--- src/sys/dev/pci/virtio.c:1.68	Fri Mar 24 13:32:19 2023
+++ src/sys/dev/pci/virtio.c	Sat Mar 25 02:59:23 2023
@@ -1,4 +1,4 @@
-/*	$NetBSD: virtio.c,v 1.68 2023/03/24 13:32:19 yamaguchi Exp $	*/
+/*	$NetBSD: virtio.c,v 1.69 2023/03/25 02:59:23 yamaguchi Exp $	*/
 
 /*
  * Copyright (c) 2020 The NetBSD Foundation, Inc.
@@ -28,7 +28,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: virtio.c,v 1.68 2023/03/24 13:32:19 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: virtio.c,v 1.69 2023/03/25 02:59:23 yamaguchi Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -865,10 +865,6 @@ virtio_alloc_vq(struct virtio_softc *sc,
 
 	virtio_reset_vq(sc, vq);
 
-	/* set the vq address */
-	sc->sc_ops->setup_queue(sc, vq->vq_index,
-	    vq->vq_dmamap->dm_segs[0].ds_addr);
-
 	aprint_verbose_dev(sc->sc_dev,
 	    "allocated %zu byte for virtqueue %d for %s, size %d\n",
 	    allocsize, vq->vq_index, name, vq_num);
@@ -1301,6 +1297,7 @@ virtio_child_attach_finish(struct virtio
     virtio_callback config_change,
     int req_flags)
 {
+	size_t i;
 	int r;
 
 #ifdef DIAGNOSTIC
@@ -1309,11 +1306,11 @@ virtio_child_attach_finish(struct virtio
 	KASSERT((req_flags & VIRTIO_ASSERT_FLAGS) != VIRTIO_ASSERT_FLAGS);
 #undef VIRTIO_ASSERT_FLAGS
 
-	for (size_t _i = 0; _i < nvqs; _i++){
-		KASSERT(vqs[_i].vq_index == _i);
-		KASSERT(vqs[_i].vq_intrhand != NULL);
-		KASSERT(vqs[_i].vq_done == NULL ||
-		    vqs[_i].vq_intrhand == virtio_vq_done);
+	for (i = 0; i < nvqs; i++){
+		KASSERT(vqs[i].vq_index == i);
+		KASSERT(vqs[i].vq_intrhand != NULL);
+		KASSERT(vqs[i].vq_done == NULL ||
+		    vqs[i].vq_intrhand == virtio_vq_done);
 	}
 #endif
 
@@ -1325,6 +1322,12 @@ virtio_child_attach_finish(struct virtio
 	sc->sc_intrhand = virtio_vq_intr;
 	sc->sc_flags = req_flags;
 
+	/* set the vq address */
+	for (i = 0; i < nvqs; i++) {
+		sc->sc_ops->setup_queue(sc, vqs[i].vq_index,
+		    vqs[i].vq_dmamap->dm_segs[0].ds_addr);
+	}
+
 	r = sc->sc_ops->alloc_interrupts(sc);
 	if (r != 0) {
 		aprint_error_dev(sc->sc_dev,

Reply via email to