Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/pci Use evcnt(9) to record error status in vioif(4)
details: https://anonhg.NetBSD.org/src/rev/c57d04a0d457
branches: trunk
changeset: 972387:c57d04a0d457
user: yamaguchi <yamaguchi%NetBSD.org@localhost>
date: Mon May 25 09:41:27 2020 +0000
description:
Use evcnt(9) to record error status in vioif(4)
diffstat:
sys/dev/pci/if_vioif.c | 78 +++++++++++++++++++++++++++++++++++++------------
1 files changed, 59 insertions(+), 19 deletions(-)
diffs (192 lines):
diff -r 8c5c4d8f48d0 -r c57d04a0d457 sys/dev/pci/if_vioif.c
--- a/sys/dev/pci/if_vioif.c Mon May 25 09:36:18 2020 +0000
+++ b/sys/dev/pci/if_vioif.c Mon May 25 09:41:27 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_vioif.c,v 1.62 2020/05/25 09:36:18 yamaguchi Exp $ */
+/* $NetBSD: if_vioif.c,v 1.63 2020/05/25 09:41:27 yamaguchi Exp $ */
/*
* Copyright (c) 2010 Minoura Makoto.
@@ -26,7 +26,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_vioif.c,v 1.62 2020/05/25 09:36:18 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_vioif.c,v 1.63 2020/05/25 09:41:27 yamaguchi Exp $");
#ifdef _KERNEL_OPT
#include "opt_net_mpsafe.h"
@@ -39,6 +39,7 @@
#include <sys/bus.h>
#include <sys/condvar.h>
#include <sys/device.h>
+#include <sys/evcnt.h>
#include <sys/intr.h>
#include <sys/kmem.h>
#include <sys/mbuf.h>
@@ -236,6 +237,10 @@
struct vioif_work txq_work;
bool txq_workqueue;
bool txq_active;
+
+ struct evcnt txq_defrag_failed;
+ struct evcnt txq_mbuf_load_failed;
+ struct evcnt txq_enqueue_reserve_failed;
};
struct vioif_rxqueue {
@@ -254,6 +259,8 @@
struct vioif_work rxq_work;
bool rxq_workqueue;
bool rxq_active;
+
+ struct evcnt rxq_mbuf_add_failed;
};
struct vioif_ctrlqueue {
@@ -278,6 +285,9 @@
bus_dmamap_t ctrlq_tbl_uc_dmamap;
bus_dmamap_t ctrlq_tbl_mc_dmamap;
bus_dmamap_t ctrlq_mq_dmamap;
+
+ struct evcnt ctrlq_cmd_load_failed;
+ struct evcnt ctrlq_cmd_failed;
};
struct vioif_softc {
@@ -390,6 +400,7 @@
static void vioif_enable_interrupt_vqpairs(struct vioif_softc *);
static void vioif_disable_interrupt_vqpairs(struct vioif_softc *);
static int vioif_setup_sysctl(struct vioif_softc *);
+static void vioif_setup_stats(struct vioif_softc *);
CFATTACH_DECL_NEW(vioif, sizeof(struct vioif_softc),
vioif_match, vioif_attach, NULL, NULL);
@@ -974,6 +985,8 @@
/* continue */
}
+ vioif_setup_stats(sc);
+
strlcpy(ifp->if_xname, device_xname(self), IFNAMSIZ);
ifp->if_softc = sc;
ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST;
@@ -1292,8 +1305,7 @@
newm = m_defrag(m, M_NOWAIT);
if (newm == NULL) {
- aprint_error_dev(sc->sc_dev,
- "m_defrag() failed\n");
+ txq->txq_defrag_failed.ev_count++;
goto skip;
}
@@ -1302,9 +1314,7 @@
txq->txq_dmamaps[slot], m,
BUS_DMA_WRITE | BUS_DMA_NOWAIT);
if (r != 0) {
- aprint_error_dev(sc->sc_dev,
- "tx dmamap load failed, error code %d\n",
- r);
+ txq->txq_mbuf_load_failed.ev_count++;
skip:
m_freem(m);
virtio_enqueue_abort(vsc, vq, slot);
@@ -1314,13 +1324,11 @@
/* This should actually never fail */
r = virtio_enqueue_reserve(vsc, vq, slot,
- txq->txq_dmamaps[slot]->dm_nsegs + 1);
+ txq->txq_dmamaps[slot]->dm_nsegs + 1);
if (r != 0) {
- aprint_error_dev(sc->sc_dev,
- "virtio_enqueue_reserve failed, error code %d\n",
- r);
+ txq->txq_enqueue_reserve_failed.ev_count++;
bus_dmamap_unload(virtio_dmat(vsc),
- txq->txq_dmamaps[slot]);
+ txq->txq_dmamaps[slot]);
/* slot already freed by virtio_enqueue_reserve */
m_freem(m);
continue;
@@ -1516,7 +1524,6 @@
{
struct virtqueue *vq = rxq->rxq_vq;
struct virtio_softc *vsc = vq->vq_owner;
- struct vioif_softc *sc = device_private(virtio_child(vsc));
int i, r, ndone = 0;
KASSERT(mutex_owned(rxq->rxq_lock));
@@ -1534,9 +1541,7 @@
if (rxq->rxq_mbufs[slot] == NULL) {
r = vioif_add_rx_mbuf(rxq, slot);
if (r != 0) {
- aprint_error_dev(sc->sc_dev,
- "rx mbuf allocation failed, "
- "error code %d\n", r);
+ rxq->rxq_mbuf_add_failed.ev_count++;
break;
}
}
@@ -1946,8 +1951,7 @@
specs[i].dmamap, specs[i].buf, specs[i].bufsize,
NULL, BUS_DMA_WRITE | BUS_DMA_NOWAIT);
if (r) {
- aprint_error_dev(sc->sc_dev, "control command dmamap"
- " load failed, error code %d\n", r);
+ sc->sc_ctrlq.ctrlq_cmd_load_failed.ev_count++;
goto err;
}
loaded++;
@@ -2029,7 +2033,8 @@
if (ctrlq->ctrlq_status->ack == VIRTIO_NET_OK)
r = 0;
else {
- aprint_error_dev(sc->sc_dev, "failed setting rx mode\n");
+ device_printf(sc->sc_dev, "failed setting rx mode\n");
+ sc->sc_ctrlq.ctrlq_cmd_failed.ev_count++;
r = EIO;
}
@@ -2468,6 +2473,41 @@
return error;
}
+static void
+vioif_setup_stats(struct vioif_softc *sc)
+{
+ struct vioif_rxqueue *rxq;
+ struct vioif_txqueue *txq;
+
+ char namebuf[16];
+ int i;
+
+ for (i = 0; i < sc->sc_max_nvq_pairs; i++) {
+ rxq = &sc->sc_rxq[i];
+ txq = &sc->sc_txq[i];
+
+ snprintf(namebuf, sizeof(namebuf), "%s-TX%d",
+ device_xname(sc->sc_dev), i);
+ evcnt_attach_dynamic(&txq->txq_defrag_failed, EVCNT_TYPE_MISC,
+ NULL, namebuf, "tx m_defrag() failed");
+ evcnt_attach_dynamic(&txq->txq_mbuf_load_failed, EVCNT_TYPE_MISC,
+ NULL, namebuf, "tx dmamap load failed");
+ evcnt_attach_dynamic(&txq->txq_enqueue_reserve_failed, EVCNT_TYPE_MISC,
+ NULL, namebuf, "virtio_enqueue_reserve failed");
+
+ snprintf(namebuf, sizeof(namebuf), "%s-RX%d",
+ device_xname(sc->sc_dev), i);
+ evcnt_attach_dynamic(&rxq->rxq_mbuf_add_failed, EVCNT_TYPE_MISC,
+ NULL, namebuf, "rx mbuf allocation failed");
+ }
+
+ snprintf(namebuf, sizeof(namebuf), "%s-CTRL", device_xname(sc->sc_dev));
+ evcnt_attach_dynamic(&sc->sc_ctrlq.ctrlq_cmd_load_failed, EVCNT_TYPE_MISC,
+ NULL, namebuf, "control command dmamap load failed");
+ evcnt_attach_dynamic(&sc->sc_ctrlq.ctrlq_cmd_failed, EVCNT_TYPE_MISC,
+ NULL, namebuf, "control command failed");
+}
+
MODULE(MODULE_CLASS_DRIVER, if_vioif, "virtio");
#ifdef _MODULE
Home |
Main Index |
Thread Index |
Old Index