2
0

Makefile 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. #
  2. # Copyright (C) 2006-2016 OpenWrt.org
  3. #
  4. # This is free software, licensed under the GNU General Public License v2.
  5. # See /LICENSE for more information.
  6. #
  7. include $(TOPDIR)/rules.mk
  8. PKG_NAME:=dnsmasq
  9. PKG_UPSTREAM_VERSION:=2.92
  10. PKG_VERSION:=$(subst test,~~test,$(subst rc,~rc,$(PKG_UPSTREAM_VERSION)))
  11. PKG_RELEASE:=1
  12. PKG_SOURCE:=$(PKG_NAME)-$(PKG_UPSTREAM_VERSION).tar.xz
  13. PKG_SOURCE_URL:=https://thekelleys.org.uk/dnsmasq/
  14. PKG_HASH:=4bf50c2c1018f9fbc26037df51b90ecea0cb73d46162846763b92df0d6c3a458
  15. PKG_LICENSE:=GPL-2.0
  16. PKG_LICENSE_FILES:=COPYING
  17. PKG_CPE_ID:=cpe:/a:thekelleys:dnsmasq
  18. PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(BUILD_VARIANT)/$(PKG_NAME)-$(PKG_UPSTREAM_VERSION)
  19. PKG_INSTALL:=1
  20. PKG_BUILD_PARALLEL:=1
  21. PKG_BUILD_FLAGS:=lto
  22. PKG_ASLR_PIE_REGULAR:=1
  23. PKG_CONFIG_DEPENDS:= CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dhcp \
  24. CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dhcpv6 \
  25. CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dnssec \
  26. CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_auth \
  27. CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_ipset \
  28. CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_nftset \
  29. CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_conntrack \
  30. CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_noid \
  31. CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_broken_rtc \
  32. CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_tftp
  33. include $(INCLUDE_DIR)/package.mk
  34. define Package/dnsmasq/Default
  35. SECTION:=net
  36. CATEGORY:=Base system
  37. TITLE:=DNS and DHCP server
  38. URL:=http://www.thekelleys.org.uk/dnsmasq/
  39. DEPENDS:=+libubus
  40. USERID:=dnsmasq=453:dnsmasq=453
  41. endef
  42. define Package/dnsmasq
  43. $(call Package/dnsmasq/Default)
  44. VARIANT:=nodhcpv6
  45. DEFAULT_VARIANT:=1
  46. endef
  47. define Package/dnsmasq-dhcpv6
  48. $(call Package/dnsmasq/Default)
  49. TITLE += (with DHCPv6 support)
  50. DEPENDS+=@IPV6
  51. VARIANT:=dhcpv6
  52. PROVIDES:=dnsmasq
  53. endef
  54. define Package/dnsmasq-full
  55. $(call Package/dnsmasq/Default)
  56. TITLE += (with DNSSEC, DHCPv6, Auth DNS, IPset, Nftset, Conntrack, NO_ID enabled by default)
  57. DEPENDS+=+PACKAGE_dnsmasq_full_dnssec:libnettle \
  58. +PACKAGE_dnsmasq_full_ipset:kmod-ipt-ipset \
  59. +PACKAGE_dnsmasq_full_conntrack:libnetfilter-conntrack \
  60. +PACKAGE_dnsmasq_full_nftset:nftables-json
  61. VARIANT:=full
  62. PROVIDES:=dnsmasq
  63. endef
  64. define Package/dnsmasq/description
  65. It is intended to provide coupled DNS and DHCP service to a LAN.
  66. endef
  67. define Package/dnsmasq-dhcpv6/description
  68. $(call Package/dnsmasq/description)
  69. This is a variant with DHCPv6 support
  70. endef
  71. define Package/dnsmasq-full/description
  72. $(call Package/dnsmasq/description)
  73. This is a fully configurable variant with DHCPv4, DHCPv6, DNSSEC, Authoritative DNS
  74. and nftset, Conntrack support & NO_ID enabled by default.
  75. endef
  76. define Package/dnsmasq/conffiles
  77. /etc/config/dhcp
  78. /etc/dnsmasq.conf
  79. /etc/dnsmasq.d/
  80. endef
  81. define Package/dnsmasq-full/config
  82. if PACKAGE_dnsmasq-full
  83. config PACKAGE_dnsmasq_full_dhcp
  84. bool "Build with DHCP support."
  85. default y
  86. config PACKAGE_dnsmasq_full_dhcpv6
  87. bool "Build with DHCPv6 support."
  88. depends on IPV6 && PACKAGE_dnsmasq_full_dhcp
  89. default y
  90. config PACKAGE_dnsmasq_full_dnssec
  91. bool "Build with DNSSEC support."
  92. default y
  93. config PACKAGE_dnsmasq_full_auth
  94. bool "Build with the facility to act as an authoritative DNS server."
  95. default y
  96. config PACKAGE_dnsmasq_full_ipset
  97. bool "Build with IPset support."
  98. default n
  99. config PACKAGE_dnsmasq_full_nftset
  100. bool "Build with Nftset support."
  101. default y
  102. config PACKAGE_dnsmasq_full_conntrack
  103. bool "Build with Conntrack support."
  104. default y
  105. config PACKAGE_dnsmasq_full_noid
  106. bool "Build with NO_ID. (hide *.bind pseudo domain)"
  107. default y
  108. config PACKAGE_dnsmasq_full_broken_rtc
  109. bool "Build with HAVE_BROKEN_RTC."
  110. default n
  111. config PACKAGE_dnsmasq_full_tftp
  112. bool "Build with TFTP server support."
  113. default y
  114. endif
  115. endef
  116. Package/dnsmasq-dhcpv6/conffiles = $(Package/dnsmasq/conffiles)
  117. Package/dnsmasq-full/conffiles = $(Package/dnsmasq/conffiles)
  118. COPTS = -DHAVE_UBUS -DHAVE_POLL_H \
  119. $(if $(CONFIG_IPV6),,-DNO_IPV6)
  120. ifeq ($(BUILD_VARIANT),nodhcpv6)
  121. COPTS += -DNO_DHCP6
  122. endif
  123. ifeq ($(BUILD_VARIANT),full)
  124. COPTS += $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dhcp),,-DNO_DHCP) \
  125. $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dhcpv6),,-DNO_DHCP6) \
  126. $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dnssec),-DHAVE_DNSSEC) \
  127. $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_auth),,-DNO_AUTH) \
  128. $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_ipset),,-DNO_IPSET) \
  129. $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_nftset),-DHAVE_NFTSET,) \
  130. $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_conntrack),-DHAVE_CONNTRACK,) \
  131. $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_noid),-DNO_ID,) \
  132. $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_broken_rtc),-DHAVE_BROKEN_RTC) \
  133. $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_tftp),,-DNO_TFTP)
  134. COPTS += $(if $(CONFIG_LIBNETTLE_MINI),-DNO_GMP,)
  135. else
  136. COPTS += -DNO_AUTH -DNO_IPSET -DNO_ID
  137. endif
  138. MAKE_FLAGS := \
  139. $(TARGET_CONFIGURE_OPTS) \
  140. CFLAGS="$(TARGET_CFLAGS) $(TARGET_CPPFLAGS)" \
  141. LDFLAGS="$(TARGET_LDFLAGS)" \
  142. COPTS="$(COPTS)" \
  143. PREFIX="/usr"
  144. define Package/dnsmasq/install
  145. $(INSTALL_DIR) $(1)/usr/sbin
  146. $(CP) $(PKG_INSTALL_DIR)/usr/sbin/dnsmasq $(1)/usr/sbin/
  147. $(INSTALL_DIR) $(1)/etc/config
  148. $(INSTALL_CONF) ./files/dhcp.conf $(1)/etc/config/dhcp
  149. $(INSTALL_CONF) ./files/dnsmasq.conf $(1)/etc/dnsmasq.conf
  150. $(INSTALL_DIR) $(1)/etc/init.d
  151. $(INSTALL_BIN) ./files/dnsmasq.init $(1)/etc/init.d/dnsmasq
  152. $(INSTALL_DIR) $(1)/etc/hotplug.d/dhcp
  153. $(INSTALL_DIR) $(1)/etc/hotplug.d/neigh
  154. $(INSTALL_DIR) $(1)/etc/hotplug.d/ntp
  155. $(INSTALL_DIR) $(1)/etc/hotplug.d/tftp
  156. $(INSTALL_DATA) ./files/dnsmasqsec.hotplug $(1)/etc/hotplug.d/ntp/25-dnsmasqsec
  157. $(INSTALL_DIR) $(1)/usr/share/dnsmasq
  158. $(INSTALL_CONF) ./files/dhcpbogushostname.conf $(1)/usr/share/dnsmasq/
  159. $(INSTALL_CONF) ./files/rfc6761.conf $(1)/usr/share/dnsmasq/
  160. $(INSTALL_DIR) $(1)/usr/lib/dnsmasq
  161. $(INSTALL_BIN) ./files/dhcp-script.sh $(1)/usr/lib/dnsmasq/dhcp-script.sh
  162. $(INSTALL_DIR) $(1)/usr/share/acl.d
  163. $(INSTALL_DATA) ./files/dnsmasq_acl.json $(1)/usr/share/acl.d/
  164. $(INSTALL_DIR) $(1)/etc/uci-defaults
  165. $(INSTALL_BIN) ./files/50-dnsmasq-migrate-resolv-conf-auto.sh $(1)/etc/uci-defaults
  166. $(INSTALL_BIN) ./files/50-dnsmasq-migrate-ipset.sh $(1)/etc/uci-defaults
  167. endef
  168. Package/dnsmasq-dhcpv6/install = $(Package/dnsmasq/install)
  169. define Package/dnsmasq-full/install
  170. $(call Package/dnsmasq/install,$(1))
  171. ifneq ($(CONFIG_PACKAGE_dnsmasq_full_dnssec),)
  172. $(INSTALL_DIR) $(1)/usr/share/dnsmasq
  173. $(INSTALL_CONF) $(PKG_BUILD_DIR)/trust-anchors.conf $(1)/usr/share/dnsmasq
  174. endif
  175. endef
  176. $(eval $(call BuildPackage,dnsmasq))
  177. $(eval $(call BuildPackage,dnsmasq-dhcpv6))
  178. $(eval $(call BuildPackage,dnsmasq-full))