2 # Copyright (C) 2006-2016 OpenWrt.org
4 # This is free software, licensed under the GNU General Public License v2.
5 # See /LICENSE for more information.
8 include $(TOPDIR)/rules.mk
14 PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.xz
15 PKG_SOURCE_URL:=http://thekelleys.org.uk/dnsmasq
16 PKG_HASH:=cdaba2785e92665cf090646cba6f94812760b9d7d8c8d0cfb07ac819377a63bb
19 PKG_LICENSE_FILES:=COPYING
20 PKG_CPE_ID:=cpe:/a:thekelleys:dnsmasq
22 PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(BUILD_VARIANT)/$(PKG_NAME)-$(PKG_VERSION)
26 PKG_CONFIG_DEPENDS:= CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dhcp \
27 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dhcpv6 \
28 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dnssec \
29 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_auth \
30 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_ipset \
31 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_conntrack \
32 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_noid \
33 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_broken_rtc \
34 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_tftp
36 include $(INCLUDE_DIR)/package.mk
38 define Package/dnsmasq/Default
41 TITLE:=DNS and DHCP server
42 URL:=http://www.thekelleys.org.uk/dnsmasq/
44 USERID:=dnsmasq=453:dnsmasq=453
47 define Package/dnsmasq
48 $(call Package/dnsmasq/Default)
52 define Package/dnsmasq-dhcpv6
53 $(call Package/dnsmasq/Default)
54 TITLE += (with DHCPv6 support)
60 define Package/dnsmasq-full
61 $(call Package/dnsmasq/Default)
62 TITLE += (with DNSSEC, DHCPv6, Auth DNS, IPset, Conntrack, NO_ID enabled by default)
63 DEPENDS+=+PACKAGE_dnsmasq_full_dnssec:libnettle \
64 +PACKAGE_dnsmasq_full_ipset:kmod-ipt-ipset \
65 +PACKAGE_dnsmasq_full_conntrack:libnetfilter-conntrack
70 define Package/dnsmasq/description
71 It is intended to provide coupled DNS and DHCP service to a LAN.
74 define Package/dnsmasq-dhcpv6/description
75 $(call Package/dnsmasq/description)
77 This is a variant with DHCPv6 support
80 define Package/dnsmasq-full/description
81 $(call Package/dnsmasq/description)
83 This is a fully configurable variant with DHCPv4, DHCPv6, DNSSEC, Authoritative DNS
84 and IPset, Conntrack support & NO_ID enabled by default.
87 define Package/dnsmasq/conffiles
92 define Package/dnsmasq-full/config
93 if PACKAGE_dnsmasq-full
94 config PACKAGE_dnsmasq_full_dhcp
95 bool "Build with DHCP support."
97 config PACKAGE_dnsmasq_full_dhcpv6
98 bool "Build with DHCPv6 support."
99 depends on IPV6 && PACKAGE_dnsmasq_full_dhcp
101 config PACKAGE_dnsmasq_full_dnssec
102 bool "Build with DNSSEC support."
104 config PACKAGE_dnsmasq_full_auth
105 bool "Build with the facility to act as an authoritative DNS server."
107 config PACKAGE_dnsmasq_full_ipset
108 bool "Build with IPset support."
110 config PACKAGE_dnsmasq_full_conntrack
111 bool "Build with Conntrack support."
113 config PACKAGE_dnsmasq_full_noid
114 bool "Build with NO_ID. (hide *.bind pseudo domain)"
116 config PACKAGE_dnsmasq_full_broken_rtc
117 bool "Build with HAVE_BROKEN_RTC."
119 config PACKAGE_dnsmasq_full_tftp
120 bool "Build with TFTP server support."
125 Package/dnsmasq-dhcpv6/conffiles = $(Package/dnsmasq/conffiles)
126 Package/dnsmasq-full/conffiles = $(Package/dnsmasq/conffiles)
128 TARGET_CFLAGS += -ffunction-sections -fdata-sections
129 TARGET_LDFLAGS += -Wl,--gc-sections
131 COPTS = -DHAVE_UBUS \
132 $(if $(CONFIG_IPV6),,-DNO_IPV6)
134 ifeq ($(BUILD_VARIANT),nodhcpv6)
138 ifeq ($(BUILD_VARIANT),full)
139 COPTS += $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dhcp),,-DNO_DHCP) \
140 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dhcpv6),,-DNO_DHCP6) \
141 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dnssec),-DHAVE_DNSSEC) \
142 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_auth),,-DNO_AUTH) \
143 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_ipset),,-DNO_IPSET) \
144 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_conntrack),-DHAVE_CONNTRACK,) \
145 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_noid),-DNO_ID,) \
146 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_broken_rtc),-DHAVE_BROKEN_RTC) \
147 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_tftp),,-DNO_TFTP)
148 COPTS += $(if $(CONFIG_LIBNETTLE_MINI),-DNO_GMP,)
150 COPTS += -DNO_AUTH -DNO_IPSET -DNO_ID
154 $(TARGET_CONFIGURE_OPTS) \
155 CFLAGS="$(TARGET_CFLAGS) $(TARGET_CPPFLAGS)" \
156 LDFLAGS="$(TARGET_LDFLAGS)" \
160 define Package/dnsmasq/install
161 $(INSTALL_DIR) $(1)/usr/sbin
162 $(CP) $(PKG_INSTALL_DIR)/usr/sbin/dnsmasq $(1)/usr/sbin/
163 $(INSTALL_DIR) $(1)/etc/config
164 $(INSTALL_CONF) ./files/dhcp.conf $(1)/etc/config/dhcp
165 $(INSTALL_CONF) ./files/dnsmasq.conf $(1)/etc/dnsmasq.conf
166 $(INSTALL_DIR) $(1)/etc/init.d
167 $(INSTALL_BIN) ./files/dnsmasq.init $(1)/etc/init.d/dnsmasq
168 $(INSTALL_DIR) $(1)/etc/hotplug.d/dhcp
169 $(INSTALL_DIR) $(1)/etc/hotplug.d/neigh
170 $(INSTALL_DIR) $(1)/etc/hotplug.d/ntp
171 $(INSTALL_DIR) $(1)/etc/hotplug.d/tftp
172 $(INSTALL_CONF) ./files/dnsmasqsec.hotplug $(1)/etc/hotplug.d/ntp/25-dnsmasqsec
173 $(INSTALL_DIR) $(1)/usr/share/dnsmasq
174 $(INSTALL_CONF) ./files/dhcpbogushostname.conf $(1)/usr/share/dnsmasq/
175 $(INSTALL_CONF) ./files/rfc6761.conf $(1)/usr/share/dnsmasq/
176 $(INSTALL_DIR) $(1)/usr/lib/dnsmasq
177 $(INSTALL_BIN) ./files/dhcp-script.sh $(1)/usr/lib/dnsmasq/dhcp-script.sh
178 $(INSTALL_DIR) $(1)/usr/share/acl.d
179 $(INSTALL_DATA) ./files/dnsmasq_acl.json $(1)/usr/share/acl.d/
182 Package/dnsmasq-dhcpv6/install = $(Package/dnsmasq/install)
184 define Package/dnsmasq-full/install
185 $(call Package/dnsmasq/install,$(1))
186 ifneq ($(CONFIG_PACKAGE_dnsmasq_full_dnssec),)
187 $(INSTALL_DIR) $(1)/usr/share/dnsmasq
188 $(INSTALL_CONF) $(PKG_BUILD_DIR)/trust-anchors.conf $(1)/usr/share/dnsmasq
192 $(eval $(call BuildPackage,dnsmasq))
193 $(eval $(call BuildPackage,dnsmasq-dhcpv6))
194 $(eval $(call BuildPackage,dnsmasq-full))