diff options
author | David Lamparter <equinox@opensourcerouting.org> | 2016-07-28 17:23:48 +0200 |
---|---|---|
committer | Donald Sharp <sharpd@cumulusnetwroks.com> | 2016-07-28 13:27:47 +0200 |
commit | 5ef104fc4131cacaf1843bb32e19d4b681fc5214 (patch) | |
tree | 949ad77cae64df24ace365ed449eb48e38c8bf4d /pimd/pim_igmp_join.h | |
parent | lib: add 3-byte stream functions (diff) | |
download | frr-5ef104fc4131cacaf1843bb32e19d4b681fc5214.tar.xz frr-5ef104fc4131cacaf1843bb32e19d4b681fc5214.zip |
pimd: relegate pim_igmp_join.c into a header file
pim_igmp_join.c only exists to make some portability hacks available to
test_igmpv3_join. The function only has 1 call site in each pimd and
the test tool, so it's nicely served as a simple static function in a
header file.
This removes a MTYPE related compiler/linker issue from referencing
lib/if.h in a binary that doesn't link libzebra, as test_igmpv3_join is
now fully independent of lib/.
(Fix by Christian Franke: remove stray leftover ifindex_t)
Signed-off-by: David Lamparter <equinox@opensourcerouting.org>
Diffstat (limited to 'pimd/pim_igmp_join.h')
-rw-r--r-- | pimd/pim_igmp_join.h | 46 |
1 files changed, 42 insertions, 4 deletions
diff --git a/pimd/pim_igmp_join.h b/pimd/pim_igmp_join.h index 1127af120..95519ff97 100644 --- a/pimd/pim_igmp_join.h +++ b/pimd/pim_igmp_join.h @@ -23,10 +23,48 @@ #ifndef PIM_IGMP_JOIN_H #define PIM_IGMP_JOIN_H -#include <netinet/in.h> +/* required headers #include'd by caller */ -int pim_igmp_join_source(int fd, int ifindex, - struct in_addr group_addr, - struct in_addr source_addr); +#ifndef SOL_IP +#define SOL_IP IPPROTO_IP +#endif + +#ifndef MCAST_JOIN_SOURCE_GROUP +#define MCAST_JOIN_SOURCE_GROUP 46 +struct group_source_req +{ + uint32_t gsr_interface; + struct sockaddr_storage gsr_group; + struct sockaddr_storage gsr_source; +}; +#endif + +static int pim_igmp_join_source(int fd, int ifindex, + struct in_addr group_addr, + struct in_addr source_addr) +{ + struct group_source_req req; + struct sockaddr_in group; + struct sockaddr_in source; + + memset(&group, 0, sizeof(group)); + group.sin_family = AF_INET; + group.sin_addr = group_addr; + group.sin_port = htons(0); + memcpy(&req.gsr_group, &group, sizeof(struct sockaddr_in)); + + memset(&source, 0, sizeof(source)); + source.sin_family = AF_INET; + source.sin_addr = source_addr; + source.sin_port = htons(0); + memcpy(&req.gsr_source, &source, sizeof(struct sockaddr_in)); + + req.gsr_interface = ifindex; + + return setsockopt(fd, SOL_IP, MCAST_JOIN_SOURCE_GROUP, + &req, sizeof(req)); + + return 0; +} #endif /* PIM_IGMP_JOIN_H */ |