summaryrefslogtreecommitdiffstats
path: root/pimd/pim_igmp_join.h
diff options
context:
space:
mode:
authorDavid Lamparter <equinox@opensourcerouting.org>2016-07-28 17:23:48 +0200
committerDonald Sharp <sharpd@cumulusnetwroks.com>2016-07-28 13:27:47 +0200
commit5ef104fc4131cacaf1843bb32e19d4b681fc5214 (patch)
tree949ad77cae64df24ace365ed449eb48e38c8bf4d /pimd/pim_igmp_join.h
parentlib: add 3-byte stream functions (diff)
downloadfrr-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.h46
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 */