diff options
Diffstat (limited to 'sys/netinet/in_var.h')
-rw-r--r-- | sys/netinet/in_var.h | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/sys/netinet/in_var.h b/sys/netinet/in_var.h index 7605199..47a160a 100644 --- a/sys/netinet/in_var.h +++ b/sys/netinet/in_var.h @@ -147,6 +147,12 @@ struct router_info { int rti_type; /* type of router which is querier on this interface */ int rti_time; /* # of slow timeouts since last old query */ SLIST_ENTRY(router_info) rti_list; +#ifdef notyet + int rti_timev1; /* IGMPv1 querier present */ + int rti_timev2; /* IGMPv2 querier present */ + int rti_timer; /* report to general query */ + int rti_qrv; /* querier robustness */ +#endif }; /* @@ -166,7 +172,43 @@ struct in_multi { u_int inm_state; /* state of the membership */ struct router_info *inm_rti; /* router info*/ u_int inm_refcount; /* reference count */ +#ifdef notyet /* IGMPv3 source-specific multicast fields */ + TAILQ_HEAD(, in_msfentry) inm_msf; /* all active source filters */ + TAILQ_HEAD(, in_msfentry) inm_msf_record; /* recorded sources */ + TAILQ_HEAD(, in_msfentry) inm_msf_exclude; /* exclude sources */ + TAILQ_HEAD(, in_msfentry) inm_msf_include; /* include sources */ + /* XXX: should this lot go to the router_info structure? */ + /* XXX: can/should these be callouts? */ + /* IGMP protocol timers */ + int32_t inm_ti_curstate; /* current state timer */ + int32_t inm_ti_statechg; /* state change timer */ + /* IGMP report timers */ + uint16_t inm_rpt_statechg; /* state change report timer */ + uint16_t inm_rpt_toxx; /* fmode change report timer */ + /* IGMP protocol state */ + uint16_t inm_fmode; /* filter mode */ + uint32_t inm_recsrc_count; /* # of recorded sources */ + uint16_t inm_exclude_sock_count; /* # of exclude-mode sockets */ + uint16_t inm_gass_count; /* # of g-a-s queries */ +#endif +}; + +#ifdef notyet +/* + * Internet multicast source filter list. This list is used to store + * IP multicast source addresses for each membership on an interface. + * TODO: Allocate these structures using UMA. + * TODO: Find an easier way of linking the struct into two lists at once. + */ +struct in_msfentry { + TAILQ_ENTRY(in_msfentry) isf_link; /* next filter in all-list */ + TAILQ_ENTRY(in_msfentry) isf_next; /* next filter in queue */ + struct in_addr isf_addr; /* the address of this source */ + uint16_t isf_refcount; /* reference count */ + uint16_t isf_reporttag; /* what to report to the IGMP router */ + uint16_t isf_rexmit; /* retransmission state/count */ }; +#endif #ifdef _KERNEL @@ -246,6 +288,12 @@ do { \ } while(0) struct route; +struct ip_moptions; + +size_t imo_match_group(struct ip_moptions *, struct ifnet *, + struct sockaddr *); +struct in_msource *imo_match_source(struct ip_moptions *, size_t, + struct sockaddr *); struct in_multi *in_addmulti(struct in_addr *, struct ifnet *); void in_delmulti(struct in_multi *); void in_delmulti_locked(struct in_multi *); |