summaryrefslogtreecommitdiffstats
path: root/sys/net/if.c
diff options
context:
space:
mode:
authorglebius <glebius@FreeBSD.org>2006-01-30 13:45:15 +0000
committerglebius <glebius@FreeBSD.org>2006-01-30 13:45:15 +0000
commit19f8b36e662bea1b79c01dab7717540417040328 (patch)
tree411b1579c38fee9f7f11cf8181e2190d0215dd36 /sys/net/if.c
parenta388ebb962934fe140e9559cc12ca537afae2187 (diff)
downloadFreeBSD-src-19f8b36e662bea1b79c01dab7717540417040328.zip
FreeBSD-src-19f8b36e662bea1b79c01dab7717540417040328.tar.gz
Merge the //depot/user/yar/vlan branch into CVS. It contains some collective
work by yar, thompsa and myself. The checksum offloading part also involves work done by Mihail Balikov. The most important changes: o Instead of global linked list of all vlan softc use a per-trunk hash. The size of hash is dynamically adjusted, depending on number of entries. This changes struct ifnet, replacing counter of vlans with a pointer to trunk structure. This change is an improvement for setups with big number of VLANs, several interfaces and several CPUs. It is a small regression for a setup with a single VLAN interface. An alternative to dynamic hash is a per-trunk static array with 4096 entries, which is a compile time option - VLAN_ARRAY. In my experiments the array is not an improvement, probably because such a big trunk structure doesn't fit into CPU cache. o Introduce an UMA zone for VLAN tags. Since drivers depend on it, the zone is declared in kern_mbuf.c, not in optional vlan(4) driver. This change is a big improvement for any setup utilizing vlan(4). o Use rwlock(9) instead of mutex(9) for locking. We are the first ones to do this! :) o Some drivers can do hardware VLAN tagging + hardware checksum offloading. Add an infrastructure for this. Whenever vlan(4) is attached to a parent or parent configuration is changed, the flags on vlan(4) interface are updated. In collaboration with: yar, thompsa In collaboration with: Mihail Balikov <mihail.balikov interbgc.com>
Diffstat (limited to 'sys/net/if.c')
-rw-r--r--sys/net/if.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/sys/net/if.c b/sys/net/if.c
index 733a77e..814815b 100644
--- a/sys/net/if.c
+++ b/sys/net/if.c
@@ -1040,6 +1040,7 @@ if_route(struct ifnet *ifp, int flag, int fam)
}
void (*vlan_link_state_p)(struct ifnet *, int); /* XXX: private from if_vlan */
+void (*vlan_trunk_cap_p)(struct ifnet *); /* XXX: private from if_vlan */
/*
* Handle a change in the interface link state. To avoid LORs
@@ -1075,7 +1076,7 @@ do_link_state_change(void *arg, int pending)
else
link = NOTE_LINKINV;
KNOTE_UNLOCKED(&ifp->if_klist, link);
- if (ifp->if_nvlans != 0)
+ if (ifp->if_vlantrunk != NULL)
(*vlan_link_state_p)(ifp, link);
if ((ifp->if_type == IFT_ETHER || ifp->if_type == IFT_L2VLAN) &&
OpenPOWER on IntegriCloud