Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/pci Make macros not depend on vioif_softc



details:   https://anonhg.NetBSD.org/src/rev/54a01be4d98b
branches:  trunk
changeset: 995997:54a01be4d98b
user:      yamaguchi <yamaguchi%NetBSD.org@localhost>
date:      Mon Jan 14 14:32:13 2019 +0000

description:
Make macros not depend on vioif_softc

diffstat:

 sys/dev/pci/if_vioif.c |  163 +++++++++++++++++++++---------------------------
 1 files changed, 72 insertions(+), 91 deletions(-)

diffs (229 lines):

diff -r c827440bcdb0 -r 54a01be4d98b sys/dev/pci/if_vioif.c
--- a/sys/dev/pci/if_vioif.c    Mon Jan 14 12:23:53 2019 +0000
+++ b/sys/dev/pci/if_vioif.c    Mon Jan 14 14:32:13 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_vioif.c,v 1.41 2018/06/26 06:48:01 msaitoh Exp $    */
+/*     $NetBSD: if_vioif.c,v 1.42 2019/01/14 14:32:13 yamaguchi Exp $  */
 
 /*
  * Copyright (c) 2010 Minoura Makoto.
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_vioif.c,v 1.41 2018/06/26 06:48:01 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_vioif.c,v 1.42 2019/01/14 14:32:13 yamaguchi Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_net_mpsafe.h"
@@ -357,65 +357,56 @@
                                 "error code %d\n", r);
                goto err_dmamem_alloc;
        }
-       sc->sc_hdrs = vaddr;
+
+#define P(p, p0, p0size)       do { p0 = (void *) p;           \
+                                    p += p0size; } while (0)
        memset(vaddr, 0, allocsize);
        p = (intptr_t) vaddr;
-       p += sizeof(struct virtio_net_hdr) * rxqsize;
-#define P(name,size)   do { sc->sc_ ##name = (void*) p;        \
-                            p += size; } while (0)
-       P(tx_hdrs, sizeof(struct virtio_net_hdr) * txqsize);
+
+       P(p, sc->sc_rx_hdrs, sizeof(sc->sc_rx_hdrs[0]) * rxqsize);
+       P(p, sc->sc_tx_hdrs, sizeof(sc->sc_tx_hdrs[0]) * txqsize);
        if (sc->sc_has_ctrl) {
-               P(ctrl_cmd, sizeof(struct virtio_net_ctrl_cmd));
-               P(ctrl_status, sizeof(struct virtio_net_ctrl_status));
-               P(ctrl_rx, sizeof(struct virtio_net_ctrl_rx));
-               P(ctrl_mac_tbl_uc, sizeof(struct virtio_net_ctrl_mac_tbl));
-               P(ctrl_mac_tbl_mc,
-                 (sizeof(struct virtio_net_ctrl_mac_tbl)
-                  + ETHER_ADDR_LEN * VIRTIO_NET_CTRL_MAC_MAXENTRIES));
+               P(p, sc->sc_ctrl_cmd, sizeof(*sc->sc_ctrl_cmd));
+               P(p, sc->sc_ctrl_status, sizeof(*sc->sc_ctrl_status));
+               P(p, sc->sc_ctrl_rx, sizeof(*sc->sc_ctrl_rx));
+               P(p, sc->sc_ctrl_mac_tbl_uc, sizeof(*sc->sc_ctrl_mac_tbl_uc) + 0);
+               P(p, sc->sc_ctrl_mac_tbl_mc,
+                   (sizeof(*sc->sc_ctrl_mac_tbl_mc)
+                   + ETHER_ADDR_LEN * VIRTIO_NET_CTRL_MAC_MAXENTRIES));
        }
-#undef P
 
        allocsize2 = sizeof(bus_dmamap_t) * (rxqsize + txqsize);
        allocsize2 += sizeof(bus_dmamap_t) * (rxqsize + txqsize);
        allocsize2 += sizeof(struct mbuf*) * (rxqsize + txqsize);
-       sc->sc_arrays = kmem_zalloc(allocsize2, KM_SLEEP);
-       sc->sc_txhdr_dmamaps = sc->sc_arrays + rxqsize;
-       sc->sc_rx_dmamaps = sc->sc_txhdr_dmamaps + txqsize;
-       sc->sc_tx_dmamaps = sc->sc_rx_dmamaps + rxqsize;
-       sc->sc_rx_mbufs = (void*) (sc->sc_tx_dmamaps + txqsize);
-       sc->sc_tx_mbufs = sc->sc_rx_mbufs + rxqsize;
+       vaddr = kmem_zalloc(allocsize2, KM_SLEEP);
+       p = (intptr_t) vaddr;
+
+       P(p, sc->sc_rxhdr_dmamaps, sizeof(sc->sc_rxhdr_dmamaps[0]) * rxqsize);
+       P(p, sc->sc_txhdr_dmamaps, sizeof(sc->sc_txhdr_dmamaps[0]) * txqsize);
+       P(p, sc->sc_rx_dmamaps, sizeof(sc->sc_rx_dmamaps[0]) * rxqsize);
+       P(p, sc->sc_tx_dmamaps, sizeof(sc->sc_tx_dmamaps[0]) * txqsize);
+       P(p, sc->sc_rx_mbufs, sizeof(sc->sc_rx_mbufs[0]) * rxqsize);
+       P(p, sc->sc_tx_mbufs, sizeof(sc->sc_tx_mbufs[0]) * txqsize);
+#undef P
 
-#define C(map, buf, size, nsegs, rw, usage)                            \
-       do {                                                            \
-               r = bus_dmamap_create(virtio_dmat(vsc), size, nsegs, size, 0, \
-                                     BUS_DMA_NOWAIT|BUS_DMA_ALLOCNOW,  \
-                                     &sc->sc_ ##map);                  \
-               if (r != 0) {                                           \
-                       aprint_error_dev(sc->sc_dev,                    \
-                                        usage " dmamap creation failed, " \
-                                        "error code %d\n", r);         \
-                                        goto err_reqs;                 \
-               }                                                       \
+#define C(map, size, nsegs, usage)                                             \
+       do {                                                                    \
+               r = bus_dmamap_create(virtio_dmat(vsc), size, nsegs, size, 0,   \
+                                     BUS_DMA_NOWAIT|BUS_DMA_ALLOCNOW,          \
+                                     &map);                                    \
+               if (r != 0) {                                                   \
+                       aprint_error_dev(sc->sc_dev,                            \
+                           "%s dmamap creation failed, "                       \
+                           "error code %d\n", usage, r);                       \
+                       goto err_reqs;                                          \
+               }                                                               \
        } while (0)
-#define C_L1(map, buf, size, nsegs, rw, usage)                         \
-       C(map, buf, size, nsegs, rw, usage);                            \
+#define C_L(map, buf, size, nsegs, rw, usage)                          \
+       C(map, size, nsegs, usage);                                     \
        do {                                                            \
-               r = bus_dmamap_load(virtio_dmat(vsc), sc->sc_ ##map,    \
-                                   &sc->sc_ ##buf, size, NULL,         \
-                                   BUS_DMA_ ##rw | BUS_DMA_NOWAIT);    \
-               if (r != 0) {                                           \
-                       aprint_error_dev(sc->sc_dev,                    \
-                                        usage " dmamap load failed, "  \
-                                        "error code %d\n", r);         \
-                       goto err_reqs;                                  \
-               }                                                       \
-       } while (0)
-#define C_L2(map, buf, size, nsegs, rw, usage)                         \
-       C(map, buf, size, nsegs, rw, usage);                            \
-       do {                                                            \
-               r = bus_dmamap_load(virtio_dmat(vsc), sc->sc_ ##map,    \
-                                   sc->sc_ ##buf, size, NULL,          \
-                                   BUS_DMA_ ##rw | BUS_DMA_NOWAIT);    \
+               r = bus_dmamap_load(virtio_dmat(vsc), map,              \
+                                   buf, size, NULL,                    \
+                                   rw | BUS_DMA_NOWAIT);               \
                if (r != 0) {                                           \
                        aprint_error_dev(sc->sc_dev,                    \
                                         usage " dmamap load failed, "  \
@@ -424,50 +415,40 @@
                }                                                       \
        } while (0)
        for (i = 0; i < rxqsize; i++) {
-               C_L1(rxhdr_dmamaps[i], rx_hdrs[i],
-                   sizeof(struct virtio_net_hdr), 1,
-                   READ, "rx header");
-               C(rx_dmamaps[i], NULL, MCLBYTES, 1, 0, "rx payload");
+               C_L(sc->sc_rxhdr_dmamaps[i], &sc->sc_rx_hdrs[i], sizeof(sc->sc_rx_hdrs[0]), 1,
+                   BUS_DMA_READ, "rx header");
+               C(sc->sc_rx_dmamaps[i], MCLBYTES, 1, "rx payload");
        }
 
        for (i = 0; i < txqsize; i++) {
-               C_L1(txhdr_dmamaps[i], tx_hdrs[i],
-                   sizeof(struct virtio_net_hdr), 1,
-                   WRITE, "tx header");
-               C(tx_dmamaps[i], NULL, ETHER_MAX_LEN, VIRTIO_NET_TX_MAXNSEGS, 0,
-                 "tx payload");
+               C_L(sc->sc_txhdr_dmamaps[i], &sc->sc_tx_hdrs[i], sizeof(sc->sc_tx_hdrs[0]), 1,
+                   BUS_DMA_READ, "tx header");
+               C(sc->sc_tx_dmamaps[i], ETHER_MAX_LEN, VIRTIO_NET_TX_MAXNSEGS, "tx payload");
        }
 
        if (sc->sc_has_ctrl) {
                /* control vq class & command */
-               C_L2(ctrl_cmd_dmamap, ctrl_cmd,
-                   sizeof(struct virtio_net_ctrl_cmd), 1, WRITE,
-                   "control command");
-       
-               /* control vq status */
-               C_L2(ctrl_status_dmamap, ctrl_status,
-                   sizeof(struct virtio_net_ctrl_status), 1, READ,
-                   "control status");
+               C_L(sc->sc_ctrl_cmd_dmamap,  sc->sc_ctrl_cmd, sizeof(*sc->sc_ctrl_cmd), 1,
+                   BUS_DMA_WRITE, "control command");
+               C_L(sc->sc_ctrl_status_dmamap, sc->sc_ctrl_status, sizeof(*sc->sc_ctrl_status), 1,
+                   BUS_DMA_READ, "control status");
 
                /* control vq rx mode command parameter */
-               C_L2(ctrl_rx_dmamap, ctrl_rx,
-                   sizeof(struct virtio_net_ctrl_rx), 1, WRITE,
-                   "rx mode control command");
+               C_L(sc->sc_ctrl_rx_dmamap, sc->sc_ctrl_rx, sizeof(*sc->sc_ctrl_rx), 1,
+                   BUS_DMA_WRITE, "rx mode control command");
 
                /* control vq MAC filter table for unicast */
                /* do not load now since its length is variable */
-               C(ctrl_tbl_uc_dmamap, NULL,
-                 sizeof(struct virtio_net_ctrl_mac_tbl) + 0, 1, WRITE,
-                 "unicast MAC address filter command");
+               C(sc->sc_ctrl_tbl_uc_dmamap, sizeof(*sc->sc_ctrl_mac_tbl_uc) + 0, 1,
+                   "unicast MAC address filter command");
 
                /* control vq MAC filter table for multicast */
-               C(ctrl_tbl_mc_dmamap, NULL,
-                 (sizeof(struct virtio_net_ctrl_mac_tbl)
-                  + ETHER_ADDR_LEN * VIRTIO_NET_CTRL_MAC_MAXENTRIES),
-                 1, WRITE, "multicast MAC address filter command");
+               C(sc->sc_ctrl_tbl_mc_dmamap,
+                   sizeof(*sc->sc_ctrl_mac_tbl_mc)
+                   + ETHER_ADDR_LEN * VIRTIO_NET_CTRL_MAC_MAXENTRIES, 1,
+                   "multicast MAC address filter command");
        }
-#undef C_L2
-#undef C_L1
+#undef C_L
 #undef C
 
        return 0;
@@ -475,23 +456,23 @@
 err_reqs:
 #define D(map)                                                         \
        do {                                                            \
-               if (sc->sc_ ##map) {                                    \
-                       bus_dmamap_destroy(virtio_dmat(vsc), sc->sc_ ##map); \
-                       sc->sc_ ##map = NULL;                           \
+               if (map) {                                              \
+                       bus_dmamap_destroy(virtio_dmat(vsc), map);      \
+                       map = NULL;                                     \
                }                                                       \
        } while (0)
-       D(ctrl_tbl_mc_dmamap);
-       D(ctrl_tbl_uc_dmamap);
-       D(ctrl_rx_dmamap);
-       D(ctrl_status_dmamap);
-       D(ctrl_cmd_dmamap);
+       D(sc->sc_ctrl_tbl_mc_dmamap);
+       D(sc->sc_ctrl_tbl_uc_dmamap);
+       D(sc->sc_ctrl_rx_dmamap);
+       D(sc->sc_ctrl_status_dmamap);
+       D(sc->sc_ctrl_cmd_dmamap);
        for (i = 0; i < txqsize; i++) {
-               D(tx_dmamaps[i]);
-               D(txhdr_dmamaps[i]);
+               D(sc->sc_tx_dmamaps[i]);
+               D(sc->sc_txhdr_dmamaps[i]);
        }
        for (i = 0; i < rxqsize; i++) {
-               D(rx_dmamaps[i]);
-               D(rxhdr_dmamaps[i]);
+               D(sc->sc_rx_dmamaps[i]);
+               D(sc->sc_rxhdr_dmamaps[i]);
        }
 #undef D
        if (sc->sc_arrays) {



Home | Main Index | Thread Index | Old Index