diff options
author | Eric Luehrsen <ericluehrsen@gmail.com> | 2020-06-23 00:58:38 -0400 |
---|---|---|
committer | Eric Luehrsen <ericluehrsen@gmail.com> | 2020-06-27 17:17:41 -0400 |
commit | 8e0b2d344ec79fd1f9906181cb9a3689b789538f (patch) | |
tree | 1550f54b370d31a88cca14708ddaa536fb71f448 /net/unbound/Makefile | |
parent | e2fe9bda3d6a2755f36031d8d69c6ea8e08ba715 (diff) |
unbound: refactor build options to select switches
The two unique packages "Unbound light" and "Unbound heavy"
were not working well due to the fact that Unbound is mostly
its library. Tools and helpers would crash. Instead a reasonable
default Unbound is built. Also up select options like python
are added. libevent and libpthreads are options to down select.
Signed-off-by: Eric Luehrsen <ericluehrsen@gmail.com>
Diffstat (limited to 'net/unbound/Makefile')
-rw-r--r-- | net/unbound/Makefile | 135 |
1 files changed, 62 insertions, 73 deletions
diff --git a/net/unbound/Makefile b/net/unbound/Makefile index fff82d1d1..12f0e3a8f 100644 --- a/net/unbound/Makefile +++ b/net/unbound/Makefile @@ -9,7 +9,7 @@ include $(TOPDIR)/rules.mk PKG_NAME:=unbound PKG_VERSION:=1.10.1 -PKG_RELEASE:=3 +PKG_RELEASE:=4 PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz PKG_SOURCE_URL:=https://nlnetlabs.nl/downloads/unbound @@ -24,6 +24,13 @@ PKG_BUILD_PARALLEL:=1 PKG_FIXUP:=autoreconf PKG_INSTALL:=1 +PKG_CONFIG_DEPENDS:=CONFIG_PACKAGE_libunbound_dnscrypt \ + CONFIG_PACKAGE_libunbound_ipset \ + CONFIG_PACKAGE_libunbound_libevent \ + CONFIG_PACKAGE_libunbound_libpthread \ + CONFIG_PACKAGE_libunbound_pythonmodule \ + CONFIG_PACKAGE_libunbound_subnet + include $(INCLUDE_DIR)/package.mk define Package/unbound/Default @@ -38,63 +45,34 @@ endef define Package/unbound-daemon $(call Package/unbound/Default) - TITLE+= (daemon, light traffic) - DEPENDS+= +libunbound-light - VARIANT:=light + TITLE+= (daemon) + DEPENDS+= +libunbound endef define Package/unbound-daemon/description - This package contains the Unbound daemon with basic includes - necessary to meet the needs of UCI/LuCI configuration optoins. + This package contains the Unbound daemon including 'libevent', 'libmnl', and + 'libpthread' to better handle large networks with heavy query loads. Options + are available under libraries/network/libunbound to custom trim Unbound for + smaller targets. endef -define Package/unbound-daemon-heavy - $(call Package/unbound/Default) - TITLE+= (daemon, heavy traffic) - URL:=https://nlnetlabs.nl/documentation/unbound/howto-optimise - DEPENDS+= +libunbound-heavy +libpthread +libevent2 +libevent2-pthreads +libmnl - VARIANT:=heavy - PROVIDES:=unbound-daemon -endef - -define Package/unbound-daemon-heavy/description - This package contains the Unbound daemon including 'libevent' and - 'libpthread' to better handle large networks with heavy query loads. - It also offers ipset support. -endef - -define Package/libunbound-light +define Package/libunbound $(call Package/unbound/Default) SECTION:=libs CATEGORY:=Libraries SUBMENU:=Networking - TITLE+= (library, light traffic) - VARIANT:=light - PROVIDES:=libunbound - DEFAULT_VARIANT:=1 + TITLE+= (library) + DEPENDS+=+PACKAGE_libunbound_dnscrypt:libsodium \ + +PACKAGE_libunbound_ipset:libmnl \ + +PACKAGE_libunbound_libevent:libevent2 \ + +PACKAGE_libunbound_libpthread:libpthread \ + +PACKAGE_libunbound_pythonmodule:python3-base endef -define Package/libunbound-light/description - This package contains the Unbound shared library with basic includes - necessary to meet the needs of UCI/LuCI configuration options. -endef - -define Package/libunbound-heavy - $(call Package/unbound/Default) - SECTION:=libs - CATEGORY:=Libraries - SUBMENU:=Networking - TITLE+= (library, heavy traffic) - URL:=https://nlnetlabs.nl/documentation/unbound/howto-optimise - DEPENDS+= +libpthread +libevent2 +libevent2-pthreads +libmnl - VARIANT:=heavy - PROVIDES:=libunbound -endef - -define Package/libunbound-heavy/description - This package contains the Unbound shared library including 'libevent' and - 'libpthread' to better handle large networks with heavy query loads. It - also offers ipset support. +define Package/libunbound/description + This package contains the Unbound library including 'libevent', 'libmnl', and + 'libpthread' to better handle large networks with heavy query loads. Options + are available to custom trim Unbound for smaller targets. endef define Package/unbound-anchor @@ -147,6 +125,29 @@ define Package/unbound-host/description This package contains the Unbound DNS lookup utility. endef +define Package/libunbound/config + if PACKAGE_libunbound + config PACKAGE_libunbound_dnscrypt + bool "Build with DNSCRYPT support." + default n + config PACKAGE_libunbound_ipset + bool "Build with IPSET (libmnl) support." + default y + config PACKAGE_libunbound_libevent + bool "Build with expanded network resource (libevent) support." + default y + config PACKAGE_libunbound_libpthread + bool "Build with POSIX threading (libpthread) support." + default y + config PACKAGE_libunbound_pythonmodule + bool "Build with PYTHON module for prototyping and data analysis." + default n + config PACKAGE_libunbound_subnet + bool "Build with SUBNET cache module support." + default n + endif +endef + CONFIGURE_ARGS += \ --disable-dsa \ --disable-gost \ @@ -159,21 +160,17 @@ CONFIGURE_ARGS += \ --with-user=unbound \ --with-run-dir=/var/lib/unbound \ --with-conf-file=/var/lib/unbound/unbound.conf \ - --with-pidfile=/var/run/unbound.pid - -ifeq ($(BUILD_VARIANT),heavy) - CONFIGURE_ARGS += \ - --enable-ipset \ - --with-pthreads \ - --with-libevent="$(STAGING_DIR)/usr" \ - --with-libmnl="$(STAGING_DIR)/usr" \ - --enable-event-api -else - CONFIGURE_ARGS += \ - --without-pthreads \ - --without-solaris-threads \ - --without-libevent -endif + --with-pidfile=/var/run/unbound.pid \ + $(if $(CONFIG_PACKAGE_libunbound_dnscrypt), \ + --enable-dnscrypt --with-libsodium="$(STAGING_DIR)/usr",) \ + $(if $(CONFIG_PACKAGE_libunbound_ipset), \ + --enable-ipset --with-libmnl="$(STAGING_DIR)/usr",) \ + $(if $(CONFIG_PACKAGE_libunbound_libevent), \ + --enable-event-api --with-libevent="$(STAGING_DIR)/usr",--without-libevent) \ + $(if $(CONFIG_PACKAGE_libunbound_libpthread), \ + --with-pthreads,--without-pthreads --without-solaris-threads) \ + $(if $(CONFIG_PACKAGE_libunbound_python),--with-pythonmodule,) \ + $(if $(CONFIG_PACKAGE_libunbound_subnet),--enable-subnet,) \ define Package/unbound-daemon/conffiles /etc/config/unbound @@ -182,14 +179,12 @@ define Package/unbound-daemon/conffiles /etc/unbound/unbound_srv.conf endef -Package/unbound-daemon-heavy/conffiles = $(Package/unbound-daemon/conffiles) - define Build/InstallDev $(INSTALL_DIR) $(1)/usr/lib $(INSTALL_DATA) $(PKG_INSTALL_DIR)/usr/lib/libunbound.{so*,a,la} $(1)/usr/lib/ $(INSTALL_DIR) $(1)/usr/include $(INSTALL_DATA) $(PKG_INSTALL_DIR)/usr/include/unbound.h $(1)/usr/include/ -ifeq ($(BUILD_VARIANT),heavy) +ifneq ($(CONFIG_PACKAGE_libunbound_libevent),) $(INSTALL_DATA) $(PKG_INSTALL_DIR)/usr/include/unbound-event.h $(1)/usr/include/ endif endef @@ -221,15 +216,11 @@ define Package/unbound-daemon/install $(INSTALL_DATA) ./files/unbound.sh $(1)/usr/lib/unbound/unbound.sh endef -Package/unbound-daemon-heavy/install = $(Package/unbound-daemon/install) - -define Package/libunbound-light/install +define Package/libunbound/install $(INSTALL_DIR) $(1)/usr/lib $(CP) $(PKG_INSTALL_DIR)/usr/lib/libunbound.so.* $(1)/usr/lib/ endef -Package/libunbound-heavy/install = $(Package/libunbound-light/install) - define Package/unbound-anchor/install $(INSTALL_DIR) $(1)/usr/sbin $(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/sbin/unbound-anchor $(1)/usr/sbin/ @@ -256,9 +247,7 @@ define Package/unbound-host/install endef $(eval $(call BuildPackage,unbound-daemon)) -$(eval $(call BuildPackage,unbound-daemon-heavy)) -$(eval $(call BuildPackage,libunbound-light)) -$(eval $(call BuildPackage,libunbound-heavy)) +$(eval $(call BuildPackage,libunbound)) $(eval $(call BuildPackage,unbound-anchor)) $(eval $(call BuildPackage,unbound-checkconf)) $(eval $(call BuildPackage,unbound-control)) |