Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/pci Set handlers implemented in child device of virt...
details: https://anonhg.NetBSD.org/src/rev/e2b1e2a8d87e
branches: trunk
changeset: 972378:e2b1e2a8d87e
user: yamaguchi <yamaguchi%NetBSD.org@localhost>
date: Mon May 25 07:52:16 2020 +0000
description:
Set handlers implemented in child device of virtio(4) to virtqueue
instead of the commonized function
diffstat:
sys/dev/pci/if_vioif.c | 59 +++++++++++++++++++++++++++--------------------
sys/dev/pci/virtio.c | 36 +++++++++++++++-------------
sys/dev/pci/virtio_pci.c | 6 ++--
sys/dev/pci/virtiovar.h | 6 +++-
4 files changed, 60 insertions(+), 47 deletions(-)
diffs (truncated from 340 to 300 lines):
diff -r 1321b8dc1e99 -r e2b1e2a8d87e sys/dev/pci/if_vioif.c
--- a/sys/dev/pci/if_vioif.c Mon May 25 07:37:47 2020 +0000
+++ b/sys/dev/pci/if_vioif.c Mon May 25 07:52:16 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_vioif.c,v 1.53 2020/05/25 07:20:15 yamaguchi Exp $ */
+/* $NetBSD: if_vioif.c,v 1.54 2020/05/25 07:52:16 yamaguchi Exp $ */
/*
* Copyright (c) 2010 Minoura Makoto.
@@ -26,7 +26,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_vioif.c,v 1.53 2020/05/25 07:20:15 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_vioif.c,v 1.54 2020/05/25 07:52:16 yamaguchi Exp $");
#ifdef _KERNEL_OPT
#include "opt_net_mpsafe.h"
@@ -313,13 +313,13 @@
static void vioif_populate_rx_mbufs_locked(struct vioif_rxqueue *);
static int vioif_rx_deq(struct vioif_rxqueue *);
static int vioif_rx_deq_locked(struct vioif_rxqueue *);
-static int vioif_rx_vq_done(struct virtqueue *);
+static int vioif_rx_intr(void *);
static void vioif_rx_softint(void *);
static void vioif_rx_drain(struct vioif_rxqueue *);
/* tx */
-static int vioif_tx_vq_done(struct virtqueue *);
-static int vioif_tx_vq_done_locked(struct virtqueue *);
+static int vioif_tx_intr(void *);
+static int vioif_tx_deq_locked(struct virtqueue *);
static void vioif_tx_drain(struct vioif_txqueue *);
static void vioif_deferred_transmit(void *);
@@ -331,7 +331,7 @@
static int vioif_set_allmulti(struct vioif_softc *, bool);
static int vioif_set_rx_filter(struct vioif_softc *);
static int vioif_rx_filter(struct vioif_softc *);
-static int vioif_ctrl_vq_done(struct virtqueue *);
+static int vioif_ctrl_intr(void *);
static int vioif_config_change(struct virtio_softc *);
static void vioif_ctl_softint(void *);
static int vioif_ctrl_mq_vq_pairs_set(struct vioif_softc *, int);
@@ -701,7 +701,7 @@
req_features |= VIRTIO_NET_F_MQ;
#endif
virtio_child_attach_start(vsc, self, IPL_NET, NULL,
- vioif_config_change, virtio_vq_intr, req_flags,
+ vioif_config_change, virtio_vq_intrhand, req_flags,
req_features, VIRTIO_NET_FLAG_BITS);
features = virtio_features(vsc);
@@ -780,8 +780,8 @@
if (r != 0)
goto err;
nvqs++;
- rxq->rxq_vq->vq_done = vioif_rx_vq_done;
- rxq->rxq_vq->vq_done_ctx = (void *)rxq;
+ rxq->rxq_vq->vq_intrhand = vioif_rx_intr;
+ rxq->rxq_vq->vq_intrhand_arg = (void *)rxq;
rxq->rxq_stopping = true;
txq->txq_lock = mutex_obj_alloc(MUTEX_DEFAULT, IPL_NET);
@@ -799,8 +799,8 @@
if (r != 0)
goto err;
nvqs++;
- txq->txq_vq->vq_done = vioif_tx_vq_done;
- txq->txq_vq->vq_done_ctx = (void *)txq;
+ txq->txq_vq->vq_intrhand = vioif_tx_intr;
+ txq->txq_vq->vq_intrhand_arg = (void *)txq;
txq->txq_link_active = sc->sc_link_active;
txq->txq_stopping = false;
txq->txq_intrq = pcq_create(txq->txq_vq->vq_num, KM_SLEEP);
@@ -822,8 +822,8 @@
mutex_destroy(&ctrlq->ctrlq_wait_lock);
} else {
nvqs++;
- ctrlq->ctrlq_vq->vq_done = vioif_ctrl_vq_done;
- ctrlq->ctrlq_vq->vq_done_ctx = (void *) ctrlq;
+ ctrlq->ctrlq_vq->vq_intrhand = vioif_ctrl_intr;
+ ctrlq->ctrlq_vq->vq_intrhand_arg = (void *) ctrlq;
}
}
@@ -1290,11 +1290,10 @@
if (ifp->if_flags & IFF_RUNNING) {
for (i = 0; i < sc->sc_act_nvq_pairs; i++)
- vioif_tx_vq_done(sc->sc_txq[i].txq_vq);
+ vioif_tx_intr(sc->sc_txq[i].txq_vq);
}
}
-
/*
* Receive implementation
*/
@@ -1426,6 +1425,9 @@
KASSERT(mutex_owned(rxq->rxq_lock));
+ if (virtio_vq_is_enqueued(vsc, vq) == false)
+ return r;
+
while (virtio_dequeue(vsc, vq, &slot, &len) == 0) {
len -= sizeof(struct virtio_net_hdr);
r = 1;
@@ -1454,9 +1456,9 @@
/* rx interrupt; call _dequeue above and schedule a softint */
static int
-vioif_rx_vq_done(struct virtqueue *vq)
+vioif_rx_intr(void *arg)
{
- struct vioif_rxqueue *rxq = vq->vq_done_ctx;
+ struct vioif_rxqueue *rxq = arg;
int r = 0;
mutex_enter(rxq->rxq_lock);
@@ -1496,7 +1498,6 @@
}
}
-
/*
* Transmition implementation
*/
@@ -1507,12 +1508,13 @@
* tx vq full and watchdog
*/
static int
-vioif_tx_vq_done(struct virtqueue *vq)
+vioif_tx_intr(void *arg)
{
+ struct vioif_txqueue *txq = arg;
+ struct virtqueue *vq = txq->txq_vq;
struct virtio_softc *vsc = vq->vq_owner;
struct vioif_softc *sc = device_private(virtio_child(vsc));
struct ifnet *ifp = &sc->sc_ethercom.ec_if;
- struct vioif_txqueue *txq = vq->vq_done_ctx;
int r = 0;
mutex_enter(txq->txq_lock);
@@ -1520,7 +1522,7 @@
if (txq->txq_stopping)
goto out;
- r = vioif_tx_vq_done_locked(vq);
+ r = vioif_tx_deq_locked(vq);
out:
mutex_exit(txq->txq_lock);
@@ -1534,11 +1536,11 @@
}
static int
-vioif_tx_vq_done_locked(struct virtqueue *vq)
+vioif_tx_deq_locked(struct virtqueue *vq)
{
struct virtio_softc *vsc = vq->vq_owner;
struct vioif_softc *sc = device_private(virtio_child(vsc));
- struct vioif_txqueue *txq = vq->vq_done_ctx;
+ struct vioif_txqueue *txq = vq->vq_intrhand_arg;
struct ifnet *ifp = &sc->sc_ethercom.ec_if;
struct mbuf *m;
int r = 0;
@@ -1546,6 +1548,9 @@
KASSERT(mutex_owned(txq->txq_lock));
+ if (virtio_vq_is_enqueued(vsc, vq) == false)
+ return r;
+
while (virtio_dequeue(vsc, vq, &slot, &len) == 0) {
r++;
bus_dmamap_sync(virtio_dmat(vsc), txq->txq_hdr_dmamaps[slot],
@@ -1831,12 +1836,16 @@
/* ctrl vq interrupt; wake up the command issuer */
static int
-vioif_ctrl_vq_done(struct virtqueue *vq)
+vioif_ctrl_intr(void *arg)
{
+ struct vioif_ctrlqueue *ctrlq = arg;
+ struct virtqueue *vq = ctrlq->ctrlq_vq;
struct virtio_softc *vsc = vq->vq_owner;
- struct vioif_ctrlqueue *ctrlq = vq->vq_done_ctx;
int r, slot;
+ if (virtio_vq_is_enqueued(vsc, vq) == false)
+ return 0;
+
r = virtio_dequeue(vsc, vq, &slot, NULL);
if (r == ENOENT)
return 0;
diff -r 1321b8dc1e99 -r e2b1e2a8d87e sys/dev/pci/virtio.c
--- a/sys/dev/pci/virtio.c Mon May 25 07:37:47 2020 +0000
+++ b/sys/dev/pci/virtio.c Mon May 25 07:52:16 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: virtio.c,v 1.40 2020/05/25 07:37:47 yamaguchi Exp $ */
+/* $NetBSD: virtio.c,v 1.41 2020/05/25 07:52:16 yamaguchi Exp $ */
/*
* Copyright (c) 2010 Minoura Makoto.
@@ -26,7 +26,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: virtio.c,v 1.40 2020/05/25 07:37:47 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: virtio.c,v 1.41 2020/05/25 07:52:16 yamaguchi Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -242,11 +242,9 @@
* Scan vq, bus_dmamap_sync for the vqs (not for the payload),
* and calls (*vq_done)() if some entries are consumed.
*/
-static int
-virtio_vq_intr_common(struct virtqueue *vq)
+bool
+virtio_vq_is_enqueued(struct virtio_softc *sc, struct virtqueue *vq)
{
- struct virtio_softc *sc = vq->vq_owner;
- int r = 0;
if (vq->vq_queued) {
vq->vq_queued = 0;
@@ -254,12 +252,8 @@
}
vq_sync_uring(sc, vq, BUS_DMASYNC_POSTREAD);
membar_consumer();
- if (vq->vq_used_idx != vq->vq_used->idx) {
- if (vq->vq_done)
- r |= (vq->vq_done)(vq);
- }
- return r;
+ return (vq->vq_used_idx != vq->vq_used->idx) ? 1 : 0;
}
int
@@ -270,18 +264,27 @@
for (i = 0; i < sc->sc_nvqs; i++) {
vq = &sc->sc_vqs[i];
- r |= virtio_vq_intr_common(vq);
+ if (virtio_vq_is_enqueued(sc, vq) == 1) {
+ if (vq->vq_done)
+ r |= (vq->vq_done)(vq);
+ }
}
return r;
}
-static int
-virtio_vq_mq_intr(void *arg)
+int
+virtio_vq_intrhand(struct virtio_softc *sc)
{
- struct virtqueue *vq = arg;
+ struct virtqueue *vq;
+ int i, r = 0;
- return virtio_vq_intr_common(vq);
+ for (i = 0; i < sc->sc_nvqs; i++) {
+ vq = &sc->sc_vqs[i];
+ r |= (vq->vq_intrhand)(vq->vq_intrhand_arg);
+ }
+
+ return r;
}
/*
@@ -428,7 +431,6 @@
/* remember addresses and offsets for later use */
vq->vq_owner = sc;
- vq->vq_intrhand = virtio_vq_mq_intr;
vq->vq_num = vq_size;
vq->vq_index = index;
vq->vq_desc = vq->vq_vaddr;
diff -r 1321b8dc1e99 -r e2b1e2a8d87e sys/dev/pci/virtio_pci.c
--- a/sys/dev/pci/virtio_pci.c Mon May 25 07:37:47 2020 +0000
+++ b/sys/dev/pci/virtio_pci.c Mon May 25 07:52:16 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: virtio_pci.c,v 1.9 2020/05/25 07:37:47 yamaguchi Exp $ */
+/* $NetBSD: virtio_pci.c,v 1.10 2020/05/25 07:52:16 yamaguchi Exp $ */
/*
* Copyright (c) 2010 Minoura Makoto.
@@ -26,7 +26,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: virtio_pci.c,v 1.9 2020/05/25 07:37:47 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: virtio_pci.c,v 1.10 2020/05/25 07:52:16 yamaguchi Exp $");
Home |
Main Index |
Thread Index |
Old Index