summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--package/Config.in1
-rw-r--r--package/quagga/Config.in113
-rw-r--r--package/quagga/quagga.mk181
3 files changed, 295 insertions, 0 deletions
diff --git a/package/Config.in b/package/Config.in
index 50cfc4e86..88a8e10cb 100644
--- a/package/Config.in
+++ b/package/Config.in
@@ -163,6 +163,7 @@ source "package/openswan/Config.in"
source "package/portmap/Config.in"
source "package/pppd/Config.in"
source "package/proftpd/Config.in"
+source "package/quagga/Config.in"
source "package/rsync/Config.in"
source "package/samba/Config.in"
source "package/socat/Config.in"
diff --git a/package/quagga/Config.in b/package/quagga/Config.in
new file mode 100644
index 000000000..880147aa4
--- /dev/null
+++ b/package/quagga/Config.in
@@ -0,0 +1,113 @@
+config BR2_PACKAGE_QUAGGA
+ bool
+ default n
+
+comment "quagga suite"
+
+config BR2_PACKAGE_QUAGGA_ZEBRA
+ bool "quagga zebra"
+ default n
+ select BR2_PACKAGE_QUAGGA
+ help
+ routing software suite, providing implementations of
+ OSPFv2, OSPFv3, RIP v1 and v2, RIPng and BGP-4.
+
+ http://www.quagga.net/
+
+config BR2_PACKAGE_QUAGGA_BGPD
+ bool "quagga bgpd"
+ default n
+ select BR2_PACKAGE_QUAGGA
+ help
+ routing software suite, providing implementations of
+ OSPFv2, OSPFv3, RIP v1 and v2, RIPng and BGP-4.
+
+ http://www.quagga.net/
+
+config BR2_PACKAGE_QUAGGA_RIPD
+ bool "quagga ripd"
+ default n
+ select BR2_PACKAGE_QUAGGA
+ help
+ routing software suite, providing implementations of
+ OSPFv2, OSPFv3, RIP v1 and v2, RIPng and BGP-4.
+
+ http://www.quagga.net/
+
+config BR2_PACKAGE_QUAGGA_RIPNGD
+ bool "quagga ripngd"
+ default n
+ select BR2_PACKAGE_QUAGGA
+ help
+ routing software suite, providing implementations of
+ OSPFv2, OSPFv3, RIP v1 and v2, RIPng and BGP-4.
+
+ http://www.quagga.net/
+
+config BR2_PACKAGE_QUAGGA_OSPFD
+ bool "quagga ospfd"
+ default n
+ select BR2_PACKAGE_QUAGGA
+ help
+ routing software suite, providing implementations of
+ OSPFv2, OSPFv3, RIP v1 and v2, RIPng and BGP-4.
+
+ http://www.quagga.net/
+
+config BR2_PACKAGE_QUAGGA_OSPF6D
+ bool "quagga ospf6d"
+ default n
+ select BR2_PACKAGE_QUAGGA
+ depends BR2_INET_IPV6
+ help
+ routing software suite, providing implementations of
+ OSPFv2, OSPFv3, RIP v1 and v2, RIPng and BGP-4.
+
+ http://www.quagga.net/
+
+config BR2_PACKAGE_QUAGGA_WATCHQUAGGA
+ bool "quagga watchquagga"
+ default n
+ select BR2_PACKAGE_QUAGGA
+ help
+ routing software suite, providing implementations of
+ OSPFv2, OSPFv3, RIP v1 and v2, RIPng and BGP-4.
+
+ http://www.quagga.net/
+
+config BR2_PACKAGE_QUAGGA_ISISD
+ bool "isisd"
+ default n
+ select BR2_PACKAGE_QUAGGA
+ help
+ routing software suite, providing implementations of
+ OSPFv2, OSPFv3, RIP v1 and v2, RIPng and BGP-4.
+
+ http://www.quagga.net/
+
+if BR2_PACKAGE_QUAGGA
+comment "common options for quagga suite"
+config BR2_PACKAGE_QUAGGA_BGP_ANNOUNCE
+ bool "BGP route announcement"
+ default n
+
+config BR2_PACKAGE_QUAGGA_NETLINK
+ bool "quagga: use linux netlink interface"
+ default y
+
+config BR2_PACKAGE_QUAGGA_SNMP
+ bool "quagga: SNMP support"
+ default n
+
+config BR2_PACKAGE_QUAGGA_TCP_ZEBRA
+ bool "quagga: TCP/IP socket connection between zebra and proto daemon"
+ default n
+
+config BR2_PACKAGE_QUAGGA_OPAGUE_LSA
+ bool "quagga: OSPF Opaque-LSA with OSPFAPI support (RFC2370)"
+ default n
+
+config BR2_PACKAGE_QUAGGA_CONFIGURE
+ string "quagga: extra configure options"
+ default ""
+endif
diff --git a/package/quagga/quagga.mk b/package/quagga/quagga.mk
new file mode 100644
index 000000000..3344d1bb2
--- /dev/null
+++ b/package/quagga/quagga.mk
@@ -0,0 +1,181 @@
+#############################################################
+#
+# quagga suite
+#
+#############################################################
+QUAGGA_VER:=0.99.7
+QUAGGA_SOURCE:=quagga-$(QUAGGA_VER).tar.gz
+QUAGGA_SITE:=http://www.quagga.net/download
+QUAGGA_DIR:=$(BUILD_DIR)/quagga-$(QUAGGA_VER)
+QUAGGA_CAT:=$(ZCAT)
+
+QUAGGA_CONFIGURE:=
+ifeq ($(BR2_PACKAGE_QUAGGA_ZEBRA),y)
+QUAGGA_CONFIGURE+=--enable-zebra
+ifndef QUAGGA_TARGET_BINARY
+QUAGGA_TARGET_BINARY=zebra
+QUAGGA_BINARY=$(QUAGGA_DIR)/zebra/.libs/zebra
+endif
+else
+QUAGGA_CONFIGURE+=--disable-zebra
+endif
+ifeq ($(BR2_PACKAGE_QUAGGA_BGPD),y)
+QUAGGA_CONFIGURE+=--enable-bgpd
+ifndef QUAGGA_TARGET_BINARY
+QUAGGA_TARGET_BINARY=bgpd
+QUAGGA_BINARY=$(QUAGGA_DIR)/bgpd/.libs/bgpd
+endif
+else
+QUAGGA_CONFIGURE+=--disable-bgpd
+endif
+ifeq ($(BR2_PACKAGE_QUAGGA_RIPD),y)
+QUAGGA_CONFIGURE+=--enable-ripd
+ifndef QUAGGA_TARGET_BINARY
+QUAGGA_TARGET_BINARY=ripd
+QUAGGA_BINARY=$(QUAGGA_DIR)/ripd/.libs/ripd
+endif
+else
+QUAGGA_CONFIGURE+=--disable-ripd
+endif
+ifeq ($(BR2_PACKAGE_QUAGGA_RIPNGD),y)
+QUAGGA_CONFIGURE+=--enable-ripngd
+ifndef QUAGGA_TARGET_BINARY
+QUAGGA_TARGET_BINARY=ripngd
+QUAGGA_BINARY=$(QUAGGA_DIR)/ripngd/.libs/ripngd
+endif
+else
+QUAGGA_CONFIGURE+=--disable-ripngd
+endif
+ifeq ($(BR2_PACKAGE_QUAGGA_OSPFD),y)
+QUAGGA_CONFIGURE+=--enable-ospfd
+ifndef QUAGGA_TARGET_BINARY
+QUAGGA_TARGET_BINARY=ospfd
+QUAGGA_BINARY=$(QUAGGA_DIR)/ospfd/.libs/ospfd
+endif
+else
+QUAGGA_CONFIGURE+=--disable-ospfd
+endif
+ifeq ($(BR2_PACKAGE_QUAGGA_OSPF6D),y)
+QUAGGA_CONFIGURE+=--enable-ospf6d
+ifndef QUAGGA_TARGET_BINARY
+QUAGGA_TARGET_BINARY=ospf6d
+QUAGGA_BINARY=$(QUAGGA_DIR)/ospf6d/.libs/ospf6d
+endif
+else
+QUAGGA_CONFIGURE+=--disable-ospf6d
+endif
+ifeq ($(BR2_PACKAGE_QUAGGA_WATCHQUAGGA),y)
+QUAGGA_CONFIGURE+=--enable-watchquagga
+ifndef QUAGGA_TARGET_BINARY
+QUAGGA_TARGET_BINARY=watchquagga
+QUAGGA_BINARY=$(QUAGGA_DIR)/watchquagga/.libs/watchquagga
+endif
+else
+QUAGGA_CONFIGURE+=--disable-watchquagga
+endif
+ifeq ($(BR2_PACKAGE_QUAGGA_ISISD),y)
+QUAGGA_CONFIGURE+=--enable-isisd
+ifndef QUAGGA_TARGET_BINARY
+QUAGGA_TARGET_BINARY=isisd
+QUAGGA_BINARY=$(QUAGGA_DIR)/isisd/.libs/isisd
+endif
+else
+QUAGGA_CONFIGURE+=--disable-isisd
+endif
+
+
+ifeq ($(BR2_PACKAGE_QUAGGA_BGP_ANNOUNCE),y)
+QUAGGA_CONFIGURE+=--enable-bgp-announce
+else
+QUAGGA_CONFIGURE+=--disable-bgp-announce
+endif
+ifeq ($(BR2_PACKAGE_QUAGGA_NETLINK),y)
+QUAGGA_CONFIGURE+=--enable-netlink
+else
+QUAGGA_CONFIGURE+=--disable-netlink
+endif
+ifeq ($(BR2_PACKAGE_QUAGGA_SNMP),y)
+QUAGGA_CONFIGURE+=--enable-snmp
+else
+QUAGGA_CONFIGURE+=--disable-snmp
+endif
+ifeq ($(BR2_PACKAGE_QUAGGA_TCP_ZEBRA),y)
+QUAGGA_CONFIGURE+=--enable-tcp-zebra
+else
+QUAGGA_CONFIGURE+=--disable-tcp-zebra
+endif
+ifeq ($(BR2_PACKAGE_QUAGGA_OPAGUE_LSA),y)
+QUAGGA_CONFIGURE+=--enable-opaque-lsa
+else
+QUAGGA_CONFIGURE+=--disable-opaque-lsa
+endif
+
+QUAGGA_CONFIGURE+=$(subst ",,$(BR2_PACKAGE_QUAGGA_CONFIGURE))
+# ")
+
+$(DL_DIR)/$(QUAGGA_SOURCE):
+ $(WGET) -P $(DL_DIR) $(QUAGGA_SITE)/$(QUAGGA_SOURCE)
+
+ifneq ($(QUAGGA_PATCH),)
+QUAGGA_PATCH_FILE=$(DL_DIR)/$(QUAGGA_PATCH)
+$(DL_DIR)/$(QUAGGA_PATCH):
+ $(WGET) -P $(DL_DIR) $(QUAGGA_SITE)/$(QUAGGA_PATCH)
+endif
+quagga-source: $(DL_DIR)/$(QUAGGA_SOURCE) $(QUAGGA_PATCH_FILE)
+
+$(QUAGGA_DIR)/.unpacked: $(DL_DIR)/$(QUAGGA_SOURCE) $(DL_DIR)/$(QUAGGA_PATCH)
+ $(QUAGGA_CAT) $(DL_DIR)/$(QUAGGA_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) -
+ toolchain/patch-kernel.sh $(QUAGGA_DIR) package/quagga/ quagga\*.patch
+ifneq ($(QUAGGA_PATCH),)
+ (cd $(QUAGGA_DIR) && $(QUAGGA_CAT) $(DL_DIR)/$(QUAGGA_PATCH) | patch -p1)
+ if [ -d $(QUAGGA_DIR)/debian/patches ]; then \
+ toolchain/patch-kernel.sh $(QUAGGA_DIR) $(QUAGGA_DIR)/debian/patches \*.patch ; \
+ fi
+endif
+ touch $@
+
+$(QUAGGA_DIR)/.configured: $(QUAGGA_DIR)/.unpacked
+ (cd $(QUAGGA_DIR); rm -rf config.cache; \
+ $(TARGET_CONFIGURE_OPTS) \
+ $(TARGET_CONFIGURE_ARGS) \
+ ./configure \
+ --target=$(GNU_TARGET_NAME) \
+ --host=$(GNU_TARGET_NAME) \
+ --build=$(GNU_HOST_NAME) \
+ --prefix=/usr \
+ --sysconfdir=/etc \
+ $(DISABLE_LARGEFILE) \
+ $(DISABLE_IPV6) \
+ $(QUAGGA_CONFIGURE) \
+ --program-transform-name='' \
+ );
+ touch $@
+
+$(QUAGGA_BINARY): $(QUAGGA_DIR)/.configured
+ $(TARGET_CONFIGURE_OPTS) $(MAKE) CC=$(TARGET_CC) -C $(QUAGGA_DIR)
+
+$(TARGET_DIR)/usr/sbin/$(QUAGGA_TARGET_BINARY): $(QUAGGA_BINARY)
+ $(MAKE) DESTDIR=$(TARGET_DIR) -C $(QUAGGA_DIR) install
+ifneq ($(BR2_PACKAGE_QUAGGA_HEADERS),y)
+ rm -rf $(TARGET_DIR)/usr/include/quagga
+endif
+ifneq ($(BR2_HAVE_MANPAGES),y)
+ rm -rf $(TARGET_DIR)/usr/man $(TARGET_DIR)/usr/info
+endif
+
+quagga: uclibc $(TARGET_DIR)/usr/sbin/$(QUAGGA_TARGET_BINARY)
+
+quagga-clean:
+ -$(MAKE) DESTDIR=$(TARGET_DIR) -C $(QUAGGA_DIR) uninstall
+ -$(MAKE) -C $(QUAGGA_DIR) clean
+
+quagga-dirclean:
+ rm -rf $(QUAGGA_DIR)
+#############################################################
+#
+# Toplevel Makefile options
+#
+#############################################################
+ifeq ($(strip $(BR2_PACKAGE_QUAGGA)),y)
+TARGETS+=quagga
+endif