2005-01-07 01:45:51 +00:00
|
|
|
/*-
|
1994-05-24 10:09:53 +00:00
|
|
|
* Copyright (c) 1988 Stephen Deering.
|
|
|
|
* Copyright (c) 1992, 1993
|
|
|
|
* The Regents of the University of California. All rights reserved.
|
|
|
|
*
|
|
|
|
* This code is derived from software contributed to Berkeley by
|
|
|
|
* Stephen Deering of Stanford University.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
* 4. Neither the name of the University 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 REGENTS 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 REGENTS 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.
|
|
|
|
*
|
|
|
|
* @(#)igmp.h 8.1 (Berkeley) 6/10/93
|
1999-08-28 01:08:13 +00:00
|
|
|
* $FreeBSD$
|
1994-05-24 10:09:53 +00:00
|
|
|
*/
|
|
|
|
|
1994-08-21 05:27:42 +00:00
|
|
|
#ifndef _NETINET_IGMP_H_
|
|
|
|
#define _NETINET_IGMP_H_
|
|
|
|
|
1994-09-06 22:42:31 +00:00
|
|
|
/*
|
|
|
|
* Internet Group Management Protocol (IGMP) definitions.
|
|
|
|
*
|
|
|
|
* Written by Steve Deering, Stanford, May 1988.
|
|
|
|
*
|
1996-03-14 16:59:20 +00:00
|
|
|
* MULTICAST Revision: 3.5.1.2
|
1994-09-06 22:42:31 +00:00
|
|
|
*/
|
1994-05-24 10:09:53 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* IGMP packet format.
|
|
|
|
*/
|
|
|
|
struct igmp {
|
|
|
|
u_char igmp_type; /* version & type of IGMP message */
|
1995-06-13 17:51:16 +00:00
|
|
|
u_char igmp_code; /* subtype for routing msgs */
|
1994-05-24 10:09:53 +00:00
|
|
|
u_short igmp_cksum; /* IP-style checksum */
|
|
|
|
struct in_addr igmp_group; /* group address being reported */
|
|
|
|
}; /* (zero for queries) */
|
|
|
|
|
Import rewrite of IPv4 socket multicast layer to support source-specific
and protocol-independent host mode multicast. The code is written to
accomodate IPv6, IGMPv3 and MLDv2 with only a little additional work.
This change only pertains to FreeBSD's use as a multicast end-station and
does not concern multicast routing; for an IGMPv3/MLDv2 router
implementation, consider the XORP project.
The work is based on Wilbert de Graaf's IGMPv3 code drop for FreeBSD 4.6,
which is available at: http://www.kloosterhof.com/wilbert/igmpv3.html
Summary
* IPv4 multicast socket processing is now moved out of ip_output.c
into a new module, in_mcast.c.
* The in_mcast.c module implements the IPv4 legacy any-source API in
terms of the protocol-independent source-specific API.
* Source filters are lazy allocated as the common case does not use them.
They are part of per inpcb state and are covered by the inpcb lock.
* struct ip_mreqn is now supported to allow applications to specify
multicast joins by interface index in the legacy IPv4 any-source API.
* In UDP, an incoming multicast datagram only requires that the source
port matches the 4-tuple if the socket was already bound by source port.
An unbound socket SHOULD be able to receive multicasts sent from an
ephemeral source port.
* The UDP socket multicast filter mode defaults to exclusive, that is,
sources present in the per-socket list will be blocked from delivery.
* The RFC 3678 userland functions have been added to libc: setsourcefilter,
getsourcefilter, setipv4sourcefilter, getipv4sourcefilter.
* Definitions for IGMPv3 are merged but not yet used.
* struct sockaddr_storage is now referenced from <netinet/in.h>. It
is therefore defined there if not already declared in the same way
as for the C99 types.
* The RFC 1724 hack (specify 0.0.0.0/8 addresses to IP_MULTICAST_IF
which are then interpreted as interface indexes) is now deprecated.
* A patch for the Rhyolite.com routed in the FreeBSD base system
is available in the -net archives. This only affects individuals
running RIPv1 or RIPv2 via point-to-point and/or unnumbered interfaces.
* Make IPv6 detach path similar to IPv4's in code flow; functionally same.
* Bump __FreeBSD_version to 700048; see UPDATING.
This work was financially supported by another FreeBSD committer.
Obtained from: p4://bms_netdev
Submitted by: Wilbert de Graaf (original work)
Reviewed by: rwatson (locking), silence from fenner,
net@ (but with encouragement)
2007-06-12 16:24:56 +00:00
|
|
|
struct igmpv3 {
|
|
|
|
u_char igmp_type; /* version & type of IGMP message */
|
|
|
|
u_char igmp_code; /* subtype for routing msgs */
|
|
|
|
u_short igmp_cksum; /* IP-style checksum */
|
|
|
|
struct in_addr igmp_group; /* group address being reported */
|
|
|
|
/* (zero for queries) */
|
|
|
|
u_char igmp_misc; /* reserved/suppress/robustness */
|
|
|
|
u_char igmp_qqi; /* querier's query interval */
|
|
|
|
u_short igmp_numsrc; /* number of sources */
|
|
|
|
/*struct in_addr igmp_sources[1];*/ /* source addresses */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct igmp_grouprec {
|
|
|
|
u_char ig_type; /* record type */
|
|
|
|
u_char ig_datalen; /* length of auxiliary data */
|
|
|
|
u_short ig_numsrc; /* number of sources */
|
|
|
|
struct in_addr ig_group; /* group address being reported */
|
|
|
|
/*struct in_addr ig_sources[1];*/ /* source addresses */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct igmp_report {
|
|
|
|
u_char ir_type; /* record type */
|
|
|
|
u_char ir_rsv1; /* reserved */
|
|
|
|
u_short ir_cksum; /* checksum */
|
|
|
|
u_short ir_rsv2; /* reserved */
|
|
|
|
u_short ir_numgrps; /* number of group records */
|
|
|
|
struct igmp_grouprec ir_groups[1]; /* group records */
|
|
|
|
};
|
|
|
|
|
|
|
|
#define IGMP_MINLEN 8
|
|
|
|
#define IGMP_HDRLEN 8
|
|
|
|
#define IGMP_GRPREC_HDRLEN 8
|
|
|
|
#define IGMP_PREPEND 0
|
|
|
|
|
|
|
|
#define IGMP_QRV(pigmp) ((pigmp)->igmp_misc & (0x07)) /* XXX */
|
|
|
|
#define IGMP_MAXSOURCES(len) (((len) - 12) >> 2) /* XXX */
|
1994-05-24 10:09:53 +00:00
|
|
|
|
1995-06-13 17:51:16 +00:00
|
|
|
/*
|
|
|
|
* Message types, including version number.
|
|
|
|
*/
|
2004-08-16 18:32:07 +00:00
|
|
|
#define IGMP_MEMBERSHIP_QUERY 0x11 /* membership query */
|
1996-03-14 16:59:20 +00:00
|
|
|
#define IGMP_V1_MEMBERSHIP_REPORT 0x12 /* Ver. 1 membership report */
|
|
|
|
#define IGMP_V2_MEMBERSHIP_REPORT 0x16 /* Ver. 2 membership report */
|
|
|
|
#define IGMP_V2_LEAVE_GROUP 0x17 /* Leave-group message */
|
1995-06-13 17:51:16 +00:00
|
|
|
|
1996-03-14 16:59:20 +00:00
|
|
|
#define IGMP_DVMRP 0x13 /* DVMRP routing message */
|
|
|
|
#define IGMP_PIM 0x14 /* PIM routing message */
|
1995-06-13 17:51:16 +00:00
|
|
|
|
1996-03-14 16:59:20 +00:00
|
|
|
#define IGMP_MTRACE_RESP 0x1e /* traceroute resp.(to sender)*/
|
|
|
|
#define IGMP_MTRACE 0x1f /* mcast traceroute messages */
|
1995-06-13 17:51:16 +00:00
|
|
|
|
Import rewrite of IPv4 socket multicast layer to support source-specific
and protocol-independent host mode multicast. The code is written to
accomodate IPv6, IGMPv3 and MLDv2 with only a little additional work.
This change only pertains to FreeBSD's use as a multicast end-station and
does not concern multicast routing; for an IGMPv3/MLDv2 router
implementation, consider the XORP project.
The work is based on Wilbert de Graaf's IGMPv3 code drop for FreeBSD 4.6,
which is available at: http://www.kloosterhof.com/wilbert/igmpv3.html
Summary
* IPv4 multicast socket processing is now moved out of ip_output.c
into a new module, in_mcast.c.
* The in_mcast.c module implements the IPv4 legacy any-source API in
terms of the protocol-independent source-specific API.
* Source filters are lazy allocated as the common case does not use them.
They are part of per inpcb state and are covered by the inpcb lock.
* struct ip_mreqn is now supported to allow applications to specify
multicast joins by interface index in the legacy IPv4 any-source API.
* In UDP, an incoming multicast datagram only requires that the source
port matches the 4-tuple if the socket was already bound by source port.
An unbound socket SHOULD be able to receive multicasts sent from an
ephemeral source port.
* The UDP socket multicast filter mode defaults to exclusive, that is,
sources present in the per-socket list will be blocked from delivery.
* The RFC 3678 userland functions have been added to libc: setsourcefilter,
getsourcefilter, setipv4sourcefilter, getipv4sourcefilter.
* Definitions for IGMPv3 are merged but not yet used.
* struct sockaddr_storage is now referenced from <netinet/in.h>. It
is therefore defined there if not already declared in the same way
as for the C99 types.
* The RFC 1724 hack (specify 0.0.0.0/8 addresses to IP_MULTICAST_IF
which are then interpreted as interface indexes) is now deprecated.
* A patch for the Rhyolite.com routed in the FreeBSD base system
is available in the -net archives. This only affects individuals
running RIPv1 or RIPv2 via point-to-point and/or unnumbered interfaces.
* Make IPv6 detach path similar to IPv4's in code flow; functionally same.
* Bump __FreeBSD_version to 700048; see UPDATING.
This work was financially supported by another FreeBSD committer.
Obtained from: p4://bms_netdev
Submitted by: Wilbert de Graaf (original work)
Reviewed by: rwatson (locking), silence from fenner,
net@ (but with encouragement)
2007-06-12 16:24:56 +00:00
|
|
|
#define IGMP_V3_MEMBERSHIP_REPORT 0x22 /* Ver. 3 membership report */
|
|
|
|
|
1996-03-14 16:59:20 +00:00
|
|
|
#define IGMP_MAX_HOST_REPORT_DELAY 10 /* max delay for response to */
|
|
|
|
/* query (in seconds) according */
|
|
|
|
/* to RFC1112 */
|
1995-06-13 17:51:16 +00:00
|
|
|
|
1994-05-24 10:09:53 +00:00
|
|
|
|
1996-03-14 16:59:20 +00:00
|
|
|
#define IGMP_TIMER_SCALE 10 /* denotes that the igmp code field */
|
|
|
|
/* specifies time in 10th of seconds*/
|
1994-09-06 22:42:31 +00:00
|
|
|
|
1995-06-13 17:51:16 +00:00
|
|
|
/*
|
1996-03-14 16:59:20 +00:00
|
|
|
* The following four defininitions are for backwards compatibility.
|
|
|
|
* They should be removed as soon as all applications are updated to
|
|
|
|
* use the new constant names.
|
1995-06-13 17:51:16 +00:00
|
|
|
*/
|
1996-03-14 16:59:20 +00:00
|
|
|
#define IGMP_HOST_MEMBERSHIP_QUERY IGMP_MEMBERSHIP_QUERY
|
|
|
|
#define IGMP_HOST_MEMBERSHIP_REPORT IGMP_V1_MEMBERSHIP_REPORT
|
|
|
|
#define IGMP_HOST_NEW_MEMBERSHIP_REPORT IGMP_V2_MEMBERSHIP_REPORT
|
|
|
|
#define IGMP_HOST_LEAVE_MESSAGE IGMP_V2_LEAVE_GROUP
|
1994-08-21 05:27:42 +00:00
|
|
|
|
1994-09-06 22:42:31 +00:00
|
|
|
#endif /* _NETINET_IGMP_H_ */
|