Bruce M Simpson 443fc3176d Introduce a number of changes to the MROUTING code.
This is purely a forwarding plane cleanup; no control plane
code is involved.

Summary:
 * Split IPv4 and IPv6 MROUTING support. The static compile-time
   kernel option remains the same, however, the modules may now
   be built for IPv4 and IPv6 separately as ip_mroute_mod and
   ip6_mroute_mod.
 * Clean up the IPv4 multicast forwarding code to use BSD queue
   and hash table constructs. Don't build our own timer abstractions
   when ratecheck() and timevalclear() etc will do.
 * Expose the multicast forwarding cache (MFC) and virtual interface
   table (VIF) as sysctls, to reduce netstat's dependence on libkvm
   for this information for running kernels.
   * bandwidth meters however still require libkvm.
 * Make the MFC hash table size a boot/load-time tunable ULONG,
   net.inet.ip.mfchashsize (defaults to 256).
 * Remove unused members from struct vif and struct mfc.
 * Kill RSVP support, as no current RSVP implementation uses it.
   These stubs could be moved to raw_ip.c.
 * Don't share locks or initialization between IPv4 and IPv6.
 * Don't use a static struct route_in6 in ip6_mroute.c.
   The v6 code is still using a cached struct route_in6, this is
   moved to mif6 for the time being.
 * More cleanup remains to be merged from ip_mroute.c to ip6_mroute.c.

v4 path tested using ports/net/mcast-tools.
v6 changes are mostly mechanical locking and *have not* been tested.
As these changes partially break some kernel ABIs, they will not
be MFCed. There is a lot more work to be done here.

Reviewed by:	Pavlin Radoslavov
2009-03-19 01:43:03 +00:00
..
2008-05-19 01:53:47 +00:00
2008-04-07 11:26:13 +00:00
2006-07-27 19:12:49 +00:00
2008-12-15 06:10:57 +00:00
2006-02-26 17:51:22 +00:00
2006-11-11 15:02:04 +00:00
2006-09-22 22:11:29 +00:00
2006-03-12 19:06:06 +00:00
2008-05-22 21:53:15 +00:00
2008-05-27 01:54:45 +00:00
2008-11-06 10:53:35 +00:00
2009-02-07 18:49:42 +00:00
2006-12-13 02:37:48 +00:00
2007-03-11 15:20:04 +00:00
2006-06-18 05:04:42 +00:00
2008-05-05 20:19:33 +00:00
2008-08-07 20:51:51 +00:00
2008-11-05 15:04:03 +00:00
2006-07-25 00:45:55 +00:00
2007-06-29 05:23:15 +00:00
2009-02-23 18:32:59 +00:00