summaryrefslogtreecommitdiffstats
path: root/pimd
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
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')
-rw-r--r--pimd/Makefile.am6
-rw-r--r--pimd/pim_igmp_join.c71
-rw-r--r--pimd/pim_igmp_join.h46
-rw-r--r--pimd/test_igmpv3_join.c2
4 files changed, 45 insertions, 80 deletions
diff --git a/pimd/Makefile.am b/pimd/Makefile.am
index 115d73678..d578c9736 100644
--- a/pimd/Makefile.am
+++ b/pimd/Makefile.am
@@ -43,7 +43,7 @@ AM_CFLAGS = $(WERROR)
noinst_LIBRARIES = libpim.a
sbin_PROGRAMS = pimd
-bin_PROGRAMS = test_igmpv3_join
+noinst_PROGRAMS = test_igmpv3_join
libpim_a_SOURCES = \
pimd.c pim_version.c pim_cmd.c pim_signals.c pim_iface.c \
@@ -52,7 +52,7 @@ libpim_a_SOURCES = \
pim_oil.c pim_zlookup.c pim_pim.c pim_tlv.c pim_neighbor.c \
pim_hello.c pim_ifchannel.c pim_join.c pim_assert.c \
pim_msg.c pim_upstream.c pim_rpf.c pim_macro.c \
- pim_igmp_join.c pim_ssmpingd.c pim_int.c pim_rp.c \
+ pim_ssmpingd.c pim_int.c pim_rp.c \
pim_static.c pim_br.c pim_register.c pim_routemap.c
noinst_HEADERS = \
@@ -69,7 +69,7 @@ pimd_SOURCES = \
pim_main.c $(libpim_a_SOURCES)
test_igmpv3_join_SOURCES = \
- test_igmpv3_join.c pim_igmp_join.c
+ test_igmpv3_join.c
pimd_LDADD = ../lib/libzebra.la @LIBCAP@
test_igmpv3_join_LDADD = ../lib/libzebra.la
diff --git a/pimd/pim_igmp_join.c b/pimd/pim_igmp_join.c
deleted file mode 100644
index 62e32c601..000000000
--- a/pimd/pim_igmp_join.c
+++ /dev/null
@@ -1,71 +0,0 @@
-/*
- PIM for Quagga
- Copyright (C) 2008 Everton da Silva Marques
-
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 2 of the License, or
- (at your option) any later version.
-
- This program is distributed in the hope that it will be useful, but
- WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program; see the file COPYING; if not, write to the
- Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
- MA 02110-1301 USA
-
- $QuaggaId: $Format:%an, %ai, %h$ $
-*/
-
-#include <zebra.h>
-
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <string.h>
-
-#include "pim_igmp_join.h"
-
-#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
-
-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;
-}
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 */
diff --git a/pimd/test_igmpv3_join.c b/pimd/test_igmpv3_join.c
index 6f1e34de8..fe64fbc00 100644
--- a/pimd/test_igmpv3_join.c
+++ b/pimd/test_igmpv3_join.c
@@ -30,10 +30,8 @@
#include <net/if.h>
#include <arpa/inet.h>
-#include "thread.h"
#include "pim_igmp_join.h"
-struct thread_master *master;
const char *prog_name = 0;
static int iface_solve_index(const char *ifname)