ifnet: Split ringmap declaration into their own header.
authorSepherosa Ziehau <sephe@dragonflybsd.org>
Fri, 26 May 2017 11:01:52 +0000 (19:01 +0800)
committerSepherosa Ziehau <sephe@dragonflybsd.org>
Fri, 26 May 2017 11:01:52 +0000 (19:01 +0800)
Avoid bus.h -> device_if.h+bus_if.h pollution.

Suggested-by: swildner
sys/dev/netif/bnx/if_bnx.c
sys/dev/netif/emx/if_emx.c
sys/dev/netif/igb/if_igb.c
sys/dev/netif/ix/if_ix.c
sys/dev/netif/mxge/if_mxge.c
sys/net/if.c
sys/net/if_ringmap.h [new file with mode: 0644]
sys/net/if_var.h
tools/tools/netrate/pktgen/Makefile

index 4d25d05..6008db8 100644 (file)
@@ -62,6 +62,7 @@
 #include <net/if_poll.h>
 #include <net/if_types.h>
 #include <net/ifq_var.h>
+#include <net/if_ringmap.h>
 #include <net/toeplitz.h>
 #include <net/toeplitz2.h>
 #include <net/vlan/if_vlan_var.h>
index e54e620..397fb87 100644 (file)
@@ -91,6 +91,7 @@
 #include <net/if_dl.h>
 #include <net/if_media.h>
 #include <net/ifq_var.h>
+#include <net/if_ringmap.h>
 #include <net/toeplitz.h>
 #include <net/toeplitz2.h>
 #include <net/vlan/if_vlan_var.h>
index 82d55fa..f33bb4b 100644 (file)
@@ -55,6 +55,7 @@
 #include <net/if_dl.h>
 #include <net/if_media.h>
 #include <net/ifq_var.h>
+#include <net/if_ringmap.h>
 #include <net/toeplitz.h>
 #include <net/toeplitz2.h>
 #include <net/vlan/if_vlan_var.h>
index 2604b34..626539f 100644 (file)
@@ -55,6 +55,7 @@
 #include <net/if_dl.h>
 #include <net/if_media.h>
 #include <net/ifq_var.h>
+#include <net/if_ringmap.h>
 #include <net/toeplitz.h>
 #include <net/toeplitz2.h>
 #include <net/vlan/if_vlan_var.h>
index fb51a9a..318b746 100644 (file)
@@ -50,6 +50,7 @@ $FreeBSD: head/sys/dev/mxge/if_mxge.c 254263 2013-08-12 23:30:01Z scottl $
 #include <net/if.h>
 #include <net/if_arp.h>
 #include <net/ifq_var.h>
+#include <net/if_ringmap.h>
 #include <net/ethernet.h>
 #include <net/if_dl.h>
 #include <net/if_media.h>
index 82c21b9..2825d1d 100644 (file)
@@ -64,6 +64,7 @@
 #include <net/if_dl.h>
 #include <net/if_types.h>
 #include <net/if_var.h>
+#include <net/if_ringmap.h>
 #include <net/ifq_var.h>
 #include <net/radix.h>
 #include <net/route.h>
diff --git a/sys/net/if_ringmap.h b/sys/net/if_ringmap.h
new file mode 100644 (file)
index 0000000..956a2c2
--- /dev/null
@@ -0,0 +1,59 @@
+/*
+ * Copyright (c) 2017 The DragonFly Project.  All rights reserved.
+ *
+ * This code is derived from software contributed to The DragonFly Project
+ * by Sepherosa Ziehau <sepherosa@gmail.com>
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in
+ *    the documentation and/or other materials provided with the
+ *    distribution.
+ * 3. Neither the name of The DragonFly Project nor the names of its
+ *    contributors may be used to endorse or promote products derived
+ *    from this software without specific, prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE
+ * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+ * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#ifndef        _NET_IF_RINGMAP_H_
+#define        _NET_IF_RINGMAP_H_
+
+#ifndef _KERNEL
+#error "kernel only header file"
+#endif
+
+#include <sys/bus.h>
+#include <sys/sysctl.h>
+
+struct if_ringmap;
+
+struct if_ringmap *if_ringmap_alloc(device_t dev, int cnt, int cnt_max);
+void   if_ringmap_free(struct if_ringmap *rm);
+void   if_ringmap_match(device_t dev, struct if_ringmap *rm0,
+           struct if_ringmap *rm1);
+void   if_ringmap_align(device_t dev, struct if_ringmap *rm0,
+           struct if_ringmap *rm1);
+int    if_ringmap_count(const struct if_ringmap *rm);
+int    if_ringmap_cpumap(const struct if_ringmap *rm, int ring);
+void   if_ringmap_rdrtable(const struct if_ringmap *rm, int table[],
+           int table_nent);
+int    if_ringmap_cpumap_sysctl(SYSCTL_HANDLER_ARGS);
+
+#endif /* !_NET_IF_RINGMAP_H_ */
index 7a955f5..4021554 100644 (file)
@@ -659,9 +659,6 @@ struct ifmultiaddr {
 
 #ifdef _KERNEL
 
-#include <sys/bus.h>
-#include <sys/sysctl.h>
-
 struct ifaddr_marker {
        struct ifaddr           ifa;
        struct ifaddr_container ifac;
@@ -974,19 +971,6 @@ int        if_simloop(struct ifnet *ifp, struct mbuf *m, int af, int hlen);
 void   if_devstart(struct ifnet *ifp); /* COMPAT */
 void   if_devstart_sched(struct ifnet *ifp); /* COMPAT */
 
-struct if_ringmap;
-
-struct if_ringmap *if_ringmap_alloc(device_t dev, int cnt, int cnt_max);
-void   if_ringmap_free(struct if_ringmap *rm);
-void   if_ringmap_match(device_t dev, struct if_ringmap *rm0,
-           struct if_ringmap *rm1);
-void   if_ringmap_align(device_t dev, struct if_ringmap *rm0,
-           struct if_ringmap *rm1);
-int    if_ringmap_count(const struct if_ringmap *rm);
-int    if_ringmap_cpumap(const struct if_ringmap *rm, int ring);
-void   if_ringmap_rdrtable(const struct if_ringmap *rm, int table[],
-           int table_nent);
-int    if_ringmap_cpumap_sysctl(SYSCTL_HANDLER_ARGS);
 int    if_ring_count2(int cnt, int cnt_max);
 
 void   ifnet_lock(void);
index 7716878..b5430cb 100644 (file)
@@ -1,5 +1,5 @@
 KMOD=  pktgen
-SRCS=  pktgen.c device_if.h bus_if.h
+SRCS=  pktgen.c
 
 KCFLAGS+= -g
 KCFLAGS+= -DINVARIANTS