2 # Copyright (C) 2006-2015 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_MD5SUM
:=887236f1ddde6eb57cdb9d01916c9f72
19 PKG_LICENSE_FILES
:=COPYING
21 PKG_BUILD_DIR
:=$(BUILD_DIR
)/$(PKG_NAME
)-$(BUILD_VARIANT
)/$(PKG_NAME
)-$(PKG_VERSION
)
25 PKG_CONFIG_DEPENDS
:=CONFIG_PACKAGE_dnsmasq_
$(BUILD_VARIANT
)_dhcpv6 \
26 CONFIG_PACKAGE_dnsmasq_
$(BUILD_VARIANT
)_dnssec \
27 CONFIG_PACKAGE_dnsmasq_
$(BUILD_VARIANT
)_auth \
28 CONFIG_PACKAGE_dnsmasq_
$(BUILD_VARIANT
)_ipset
30 include $(INCLUDE_DIR
)/package.mk
32 define Package
/dnsmasq
/Default
35 TITLE
:=DNS and DHCP server
36 URL
:=http
://www.thekelleys.org.uk
/dnsmasq
/
39 define Package
/dnsmasq
40 $(call Package
/dnsmasq
/Default
)
44 define Package
/dnsmasq-dhcpv6
45 $(call Package
/dnsmasq
/Default
)
46 TITLE
+= (with DHCPv6 support
)
51 define Package
/dnsmasq-full
52 $(call Package
/dnsmasq
/Default
)
53 TITLE
+= (with DNSSEC
, DHCPv6
, Auth DNS
, IPset enabled by default
)
54 DEPENDS
:=+PACKAGE_dnsmasq_full_dnssec
:libnettle \
55 +PACKAGE_dnsmasq_full_ipset
:kmod-ipt-ipset
59 define Package
/dnsmasq
/description
60 It is intended to provide coupled DNS and DHCP service to a LAN.
63 define Package
/dnsmasq-dhcpv6
/description
64 $(call Package
/dnsmasq
/description
)
66 This is a variant with DHCPv6 support
69 define Package
/dnsmasq-full
/description
70 $(call Package
/dnsmasq
/description
)
72 This is a fully configurable variant with DHCPv6
, DNSSEC
, Authroitative DNS and
73 IPset support enabled by default.
76 define Package
/dnsmasq
/conffiles
81 define Package
/dnsmasq-full
/config
82 if PACKAGE_dnsmasq-full
83 config PACKAGE_dnsmasq_full_dhcpv6
84 bool
"Build with DHCPv6 support."
87 config PACKAGE_dnsmasq_full_dnssec
88 bool
"Build with DNSSEC support."
90 config PACKAGE_dnsmasq_full_auth
91 bool
"Build with the facility to act as an authoritative DNS server."
93 config PACKAGE_dnsmasq_full_ipset
94 bool
"Build with IPset support."
99 Package
/dnsmasq-dhcpv6
/conffiles
= $(Package
/dnsmasq
/conffiles
)
100 Package
/dnsmasq-full
/conffiles
= $(Package
/dnsmasq
/conffiles
)
102 TARGET_CFLAGS
+= -ffunction-sections
-fdata-sections
103 TARGET_LDFLAGS
+= -Wl
,--gc-sections
105 COPTS
= $(if
$(CONFIG_IPV6
),,-DNO_IPV6
)
107 ifeq ($(BUILD_VARIANT
),nodhcpv6
)
111 ifeq ($(BUILD_VARIANT
),full
)
112 COPTS
+= $(if
$(CONFIG_PACKAGE_dnsmasq_
$(BUILD_VARIANT
)_dhcpv6
),,-DNO_DHCP6
) \
113 $(if
$(CONFIG_PACKAGE_dnsmasq_
$(BUILD_VARIANT
)_dnssec
),-DHAVE_DNSSEC
) \
114 $(if
$(CONFIG_PACKAGE_dnsmasq_
$(BUILD_VARIANT
)_auth
),,-DNO_AUTH
) \
115 $(if
$(CONFIG_PACKAGE_dnsmasq_
$(BUILD_VARIANT
)_ipset
),,-DNO_IPSET
)
116 COPTS
+= $(if
$(CONFIG_LIBNETTLE_MINI
),-DNO_GMP
,)
118 COPTS
+= -DNO_AUTH
-DNO_IPSET
122 $(TARGET_CONFIGURE_OPTS
) \
123 CFLAGS
="$(TARGET_CFLAGS)" \
124 LDFLAGS
="$(TARGET_LDFLAGS)" \
128 define Package
/dnsmasq
/install
129 $(INSTALL_DIR
) $(1)/usr
/sbin
130 $(CP
) $(PKG_INSTALL_DIR
)/usr
/sbin
/dnsmasq
$(1)/usr
/sbin
/
131 $(INSTALL_DIR
) $(1)/etc
/config
132 $(INSTALL_DATA
) .
/files
/dhcp.conf
$(1)/etc
/config
/dhcp
133 $(INSTALL_DATA
) .
/files
/dnsmasq.conf
$(1)/etc
/dnsmasq.conf
134 $(INSTALL_DIR
) $(1)/etc
/init.d
135 $(INSTALL_BIN
) .
/files
/dnsmasq.init
$(1)/etc
/init.d
/dnsmasq
136 $(INSTALL_DIR
) $(1)/etc
/hotplug.d
/iface
137 $(INSTALL_DATA
) .
/files
/dnsmasq.hotplug
$(1)/etc
/hotplug.d
/iface
/25-dnsmasq
140 Package
/dnsmasq-dhcpv6
/install = $(Package
/dnsmasq
/install)
142 define Package
/dnsmasq-full
/install
143 $(call Package
/dnsmasq
/install,$(1))
144 ifneq ($(CONFIG_PACKAGE_dnsmasq_full_dnssec
),)
145 $(INSTALL_DIR
) $(1)/usr
/share
/dnsmasq
146 $(INSTALL_DATA
) $(PKG_BUILD_DIR
)/trust-anchors.conf
$(1)/usr
/share
/dnsmasq
150 $(eval
$(call BuildPackage
,dnsmasq
))
151 $(eval
$(call BuildPackage
,dnsmasq-dhcpv6
))
152 $(eval
$(call BuildPackage
,dnsmasq-full
))